serverless-cqrs.write-model

0.2.10-alpha.0 • Public • Published

write-model

The write-model exports two functions repositoryBuilder and commandServiceBuilder.

To initialize the model, you pass an adapter and reducer to the repositoryBuilder to generate a repository. Then you pass the repository and actions to the commandServiceBuilder to generate a list of commands

Example

const {
  repositoryBuilder,
  commandServiceBuilder,
} = require('serverless-cqrs.write-mode')

const adapter = require('./adapter')
const reducer = require('./reducer')
const actions = require('./actions')

const repository = repositoryBuilder.build({
  adapter,
  reducer,
})

module.exports = commandServiceBuilder.build({
  repository,
  actions,
})

repositoryBuilder

Takes a reducer and an adapter and returns a repository. A repository is the layer of our Onion Architecture (see Introduction) which handles data persistence.

The write-model repository has a single method called getById. When invoked, it uses the adapter to load all events for given ID and runs them through the reducer to calculate the current state. It returns an object that contains state and also a save method, which is used to append new events.

Methods

build

build({ adapter, reducer })

builds a repository

Parameters

attribute type description
adapter object Any object which implements the write-model Adapter Interface.
reducer function a function which, given a list of events, knows how to calculate the current state of an object.

Returns

{ getById } - an object with the getById function.

getById

getById(id)

Loads and returns the current state of an entity. Also returns a save function for appending new events to the data store.

Parameters

attribute type description
id string the id of the entity

Returns

{ state, save } - an object containing an arbitrary state object, and a save function.

save

save(events)

Appends new events to the datastore

Parameters

attribute type description
events array an array of arbitrary event objects

Returns

null

commandServiceBuilder

Takes a list of actions and a repository and returns an object where action names map to executable commands.

Each command accepts an id and a payload. When invoked, a command loads the current state of the entity from the repo and passes it, and the payload, to the action. The action will perform its validation and if successful, generate one or more events. The command forwards those events to the repository to be appended to the entity.

Methods

build

build({ actions, repository })

Turns actions into commands that can be executed on real objects.

Parameters

attribute type description
actions object Domain actions
repository object generated by the repositoryBuilder

Returns

commands - where keys are actions names and values are functions which accept an id and payload

Package Sidebar

Install

npm i serverless-cqrs.write-model

Weekly Downloads

0

Version

0.2.10-alpha.0

License

ISC

Unpacked Size

8.83 kB

Total Files

8

Last publish

Collaborators

  • yonahforst