Function DateAttribute

  • A decorator for marking class fields as date attributes within the context of a single-table design entity

    Because dates are not natively supported data types in dynamo, they will be converted to iso string's within dynamo, and serialized to date objects on the entity class

    Can be set to nullable via decorator props

    Type Parameters

    • T extends default

      The class type that the decorator is applied to, ensuring type safety and integration within specific class instances.

    • K extends Date

      A type constraint extending Date, ensuring that the decorator is only applied to class fields specifically intended to represent dates.

    • P extends AttributeOptions

    Parameters

    • Optionalprops: P

      An AttributeOptions object providing configuration options for the attribute, such as its alias which allows the attribute to be referred to by an alternative name in the database context. The nullable property is also set to false by default.

    Returns (_value: undefined, context: AttributeDecoratorContext<T, K, P>) => void

    A class field decorator function that operates within the class field's context. It configures the field as a date attribute and defines how it should be serialized and deserialized to/from DynamoDB.

    Usage example:

    class MyEntity extends MyTable {
    @DateAttribute({ alias: 'MyField' })
    public myField: Date;

    @DateAttribute({ alias: 'MyNullableField', nullable: true })
    public myField?: Date; // Set to Optional
    }

    Here, @DateAttribute decorates myField of MyEntity, marking it as an entity attribute with an alias 'MyField' for ORM purposes.