0.1.33 • Published 6 years ago

lishy v0.1.33

Weekly downloads
3
License
MIT
Repository
bitbucket
Last release
6 years ago

Lishy

An Express / Kafka / MongoDB framework for transactional processing of logic with full historisation of actions and data.

What is it?

Lish is a framework to organise your business logic into Typescript service classes. When an action is triggered, lish calls the code and records what has been changed.

Lish has adapters for HTTP / Express and for the Apache Kafke messaging system. Upon request, lish performs data validation and handles all exceptions that may occur during the

Features

  • Typescript class system for business logic and persistent data
  • Data Validation (via JSON schema and the class-validator framework)
  • Transactional handling of the MongoDB documents with rollback on errors
  • Historisation of all documents, enabling change tracking
  • Backdated excution of logic in a time-machine (as data looked like at a particular time in the past)
  • Fail-safe adapter to Express, making sure errors are correctly reported to the client
  • ... many more

Quick start

Create your input and output message classes

This is the supposed input data, required for a service:

export class MyInputData {
   @LishProperty(String, true)
   requiredId: string;
   
   @LishProperty(Number)
   optionalValue: number;
}

And here the MongoDB document that will be produced:

@LishEntity()
export class MyInputData extends LishEntity {
   @LishProperty(Number) @Max(1000)
   amount: number;
}
@LishService({ 
export class MyTrigger<MyInputData, Boolean> extends LishService {

   async run(lish: LishCtx<MyInputData>): Promise<Boolean> {
      // our data is provided as 'msg'; it is validated and type-safe 
      const value = lish.msg.optionalValue || 10;
      const id = lish.msg.requiredId;
      
      // get or create a document identified by our id and change it 
      const item = lish.DB(MyInputData).findOrCreateById(id);
      item.amount += value;
      
      // return - 'item' will automatically be updated in Mongo
      return true;
   }

}
0.1.33

6 years ago

0.1.32

6 years ago

0.1.31

6 years ago

0.1.30

7 years ago

0.1.29

7 years ago

0.1.28

7 years ago

0.1.27

7 years ago

0.1.26

7 years ago

0.1.25

7 years ago

0.1.24

7 years ago

0.1.23

7 years ago

0.1.22

7 years ago

0.1.21

7 years ago

0.1.20

7 years ago

0.1.19

7 years ago

0.1.18

7 years ago

0.1.17

8 years ago

0.1.16

8 years ago

0.1.15

8 years ago

0.1.14

8 years ago

0.1.13

8 years ago

0.1.12

8 years ago

0.1.11

8 years ago

0.1.10

8 years ago

0.1.9

8 years ago

0.1.8

8 years ago

0.1.7

8 years ago

0.1.6

8 years ago

0.1.5

8 years ago

0.1.4

8 years ago

0.1.3

8 years ago

0.1.2

8 years ago

0.1.1

8 years ago

0.1.0

8 years ago