npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

dynamoose-decorator

v1.0.3

Published

generate a dynamoose schema with the decorator

Downloads

16

Readme

This library provides decorators to enhance the usability of dynamoose, a Node.js object data modeling library for AWS DynamoDB.

import { Item } from 'dynamoose/dist/Item';
import {
  HashKey,
  Attribute,
  Required,
  Index,
  CreatedAt,
  UpdatedAt,
  Model,
  Storage,
  getModel,
} from 'dynamoose-decorator';

@Model({ throughput: 'ON_DEMAND', waitForActive: false })
@Schema({ saveUnknown: true })
class UserSchema extends Item {
  @HashKey()
  @Attribute()
  id: string;

  @Index({ name: 'emailIndex' })
  @Required()
  @Attribute()
  email: string;

  @Index({ name: 'nameIndex' })
  @Required()
  @Attribute()
  name: string;

  @Index({ name: 'companyAndScoreIndex', rangeKey: 'score' })
  @Attribute()
  company: string;

  @Attribute()
  score: number;

  @Storage('milliseconds')
  @CreatedAt()
  @Attribute()
  createdAt: Date;

  @Storage('milliseconds')
  @UpdatedAt()
  @Attribute()
  updatedAt: Date;
}

export const UserModel = getModel(UserSchema)

const user = new UserModel();
user.id = 'bf02318d-4029-4474-a7a0-e957eb176d75';
user.email = '[email protected]';
user.name = 'DYNAMOOSE';
user.company = 'Amazon';
user.score = 3;

await user.save();

Getting started

install using npm

npm install dynamoose-decorator dynamoose

install using yarn

yarn add dynamoose-decorator dynamoose

install using pnpm

pnpm add dynamoose-decorator dynamoose

and then modify the tsconfig.json

{
  "compilerOptions": {
    "experimentalDecorators": true,
    "emitDecoratorMetadata": true,
  }
}

Attribute

@Attribute

Define attribute for a Dynamoose model.

⚠️ Note: Ensure that all attributes in your Dynamoose model are decorated with @Attribute for the settings to take effect.

import { Attribute } from 'dynamoose-decorator';

@Attribute()
name: string;

⚠️ Note: You have to set true saveUnknown in @Schema when use object field.

interface RoleInterface {
  name: string;
  grade: string;
}

@Schema({ saveUnknown: true })
class UserModel {
  @Attribute()
  role: RoleInterface;
}

@HashKey

You can set this decorator to overwrite what the Hash Key for the Model will be. Hash Key is commonly called a Partition Key in the AWS Documentation.

⚠️ Note: Hash keys can only be specified for attributes of types Number, String, and Binary.

import { HashKey, Attribute } from 'dynamoose-decorator';

@HashKey()
@Attribute()
id: string;

@RangeKey

You can set this decorator to overwrite what the Range Key for the Model will be. By default the @RangeKey won't exist. Range Key is commonly called a Sort Key in the AWS Documentation.

import { RangeKey, Attribute } from 'dynamoose-decorator';

@RangeKey()
@Attribute()
score: number;

@Required

You can set this decorator to be required when saving items to DynamoDB. By default this setting is false.

import { Required, Attribute } from 'dynamoose-decorator';

@Required()
@Attribute()
email: string;

@Default

It is decorate Dynamoose default. You can set this decorator for an attribute that will be applied upon save if the given attribute value is null or undefined. The value for the default property can either be a value or a function that will be executed when needed that should return the default value. By default there is no default value for attributes.

Default values will only be applied if the parent object exists. This means for values where you apply a default value to a nested attribute, it will only be applied if the parent object exists. If you do not want this behavior, consider setting a default value for the parent object to an empty object ({}) or an empty array ([]).

import { Default, Attribute } from 'dynamoose-decorator';

@Default(5)
@Attribute()
age: number;

@Default(async () => {
  const response = await axios("https://myurl.com/config.json").data;
  return response.defaults.age;
})
@Attribute()
state: string;

@ForceDefault

You can set this property to always use the default value, even if a value is already set. This can be used for data that will be used as sort or secondary indexes. The default for this property is false.

import { ForceDefault, Default, Attribute } from 'dynamoose-decorator';

@ForceDefault()
@Default(5)
@Attribute()
age: number;

@Enum

You can set an attribute to have an enum array, which means it must match one of the values specified in the enum array. By default this setting is undefined and not set to anything.

This property is not a replacement for required. If the value is undefined or null, the enum will not be checked. If you want to require the property and also have an enum you must use both enum & required.

import { Enum, Attribute } from 'dynamoose-decorator';

@Enum(['amazon', 'apple'])
company: string;

@Storage

Set storage settings for an attribute of type Date.
By default this setting is milliseconds.

import { Storage, Attribute } from 'dynamoose-decorator';

// Stored as a timestamp in DynamoDB.
// It is saved as number type.
@Storage('milliseconds')
@Attribute()
timestamp: Date;

// Stored as a iso date in DynamoDB.
// It is saved as string type.
@Storage('iso')
@Attribute()
isodate: Date;

@CreatedAt, @UpdatedAt

Special column that is automatically set to the entity's insertion or update time. You don't need to write a value into this column.

⚠️ Note: These features are not features of DynamoDB. it will set by the Dynamoose.

import { CreatedAt, UpdatedAt, Storage, Attribute } from 'dynamoose-decorator';

@CreatedAt()
@Attribute()
createdAt: Date;

@UpdatedAt()
@Attribute()
updatedAt: Date;

@Storage('iso')
@CreatedAt()
@Attribute()
createdIsoDate: Date;

@Storage('iso')
@UpdatedAt()
@Attribute()
updatedIsoDate: Date;

Schema

It is decorate Dynamoose schema.
Please refer to the Dynamoose documentation for options.

import { Schema } from 'dynamoose-decorator';
import { Item } from 'dynamoose/dist/Item';

@Schema({ saveUnknown: true })
class UserSchema extends Item {
  // attributes ..
}

Model

You can set this decorator to table options.
However, we automatically set the name of the table to the class name. If you want to change the table name, use the tableName option.

You must use the Schema class by converting it to a Dynamoose Model object through the getModel function.

import { Schema, getModel, HashKey, RangeKey, Attribute } from 'dynamoose-decorator';
import { Item } from 'dynamoose/dist/Item';

// The table name for this entity is `User`.
@Model({ throughput: 'ON_DEMAND' })
@Schema()
class UserSchema {
  @HashKey()
  @Attribute()
  id: string;

  @RangeKey()
  @Attribute()
  score: number;
}

// Set the table name you want!
@Model({ tableName: 'prod-Order', throughput: { read: 1, write: 1 } })
@Schema()
class OrderSchema {

}

// Convert to Dynamoose Model
const UserModel = getModel(UserSchema);
const OrderModel = getModel(OrderSchema);

// Same use as Dynamoose!
await UserModel.create({
  id: 'hello',
  score: 100,
});

const user = new UserModel();
user.id = 'world';
user.score = 200;
await user.save();

Maintainer