Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/kdcio/ddb

Lightweight DynamoDB ODM
https://github.com/kdcio/ddb

aws ddb dynamodb kdc kdcio nosql odm

Last synced: about 1 month ago
JSON representation

Lightweight DynamoDB ODM

Awesome Lists containing this project

README

        

# KDC DDB

A lightweight object modeling for [DynamoDB](https://aws.amazon.com/dynamodb/) inspired by [Mongoose](https://mongoosejs.com/).

The default database operations of this package assumes [single table design](https://www.alexdebrie.com/posts/dynamodb-single-table/) but all can be overridden by writing your own.

[![ver](https://img.shields.io/npm/v/@kdcio/ddb)](https://www.npmjs.com/package/@kdcio/ddb) [![size](https://badgen.net/bundlephobia/minzip/@kdcio/ddb)](https://bundlephobia.com/result?p=@kdcio/ddb) [![build](https://img.shields.io/github/workflow/status/kdcio/ddb/build)](https://github.com/kdcio/ddb/actions?query=workflow%3Abuild) [![Known Vulnerabilities](https://snyk.io/test/github/kdcio/ddb/badge.svg?targetFile=package.json)](https://snyk.io/test/github/kdcio/ddb?targetFile=package.json) [![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=alert_status)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Code Smells](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=code_smells)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Coverage](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=coverage)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![license](https://img.shields.io/github/license/kdcio/ddb)](https://github.com/kdcio/ddb/blob/master/LICENSE)

## Installation

```bash
npm i @kdcio/ddb
```

## Quick Start

1. Define database table name in environment variable.

In code:

```js
process.env.DDB_TABLE = 'my-dynamodb-table';
```

or in serverless.yml:

```yaml
provider:
environment:
DDB_TABLE: 'my-dynamodb-table'
```

or in package.json:

```json
"scripts": {
"start": "DDB_TABLE='my-dynamodb-table' node index.js"
}
```

Note that table creation needs to be done outside this package to allow flexibility.

2. Define the fields of the document.

```js
const fields = {
id: { required: true },
name: { required: true },
type: { required: true },
};
```

3. Define primary and secondary keys

```js
const pKey = { pk: '{type}#{id}', sk: 'ANIMAL#{type}' };
const sKey = { pk2: 'ANIMAL', sk2: '{type}#{id}' };
```

4. Create schema

```js
const schema = new DDB.Schema(fields, pKey, sKey);
```

5. Create class

```js
const Animal = DDB.model('Animal', schema);
```

6. Create an instance document from data object

```js
const dog = new Animal({ id: 1, name: 'sparkle', type: 'dog' });
await dog.save();
```

7. Check the tests folder for more examples.

### Debugging

This package uses [debug](https://www.npmjs.com/package/debug).

To enable:

```bash
DEBUG=ddb:* node app.js
```

## Sonar Cloud Badges

[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=alert_status)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Coverage](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=coverage)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Code Smells](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=code_smells)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Bugs](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=bugs)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Lines of Code](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=ncloc)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Duplicated Lines (%)](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=duplicated_lines_density)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Maintainability Rating](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=sqale_rating)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Reliability Rating](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=reliability_rating)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Security Rating](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=security_rating)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Technical Debt](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=sqale_index)](https://sonarcloud.io/dashboard?id=kdcio_ddb) [![Vulnerabilities](https://sonarcloud.io/api/project_badges/measure?project=kdcio_ddb&metric=vulnerabilities)](https://sonarcloud.io/dashboard?id=kdcio_ddb)