Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/titarenko/flou
Simple construction of complex flows.
https://github.com/titarenko/flou
Last synced: about 2 months ago
JSON representation
Simple construction of complex flows.
- Host: GitHub
- URL: https://github.com/titarenko/flou
- Owner: titarenko
- Created: 2014-10-29T13:49:13.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2014-10-29T23:38:34.000Z (about 10 years ago)
- Last Synced: 2024-10-08T15:08:28.211Z (4 months ago)
- Language: JavaScript
- Homepage:
- Size: 117 KB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# flou
Simple construction of complex flows.
[![Build Status](https://secure.travis-ci.org/titarenko/flou.png?branch=master)](https://travis-ci.org/titarenko/flou) [![Coverage Status](https://coveralls.io/repos/titarenko/flou/badge.png?branch=master)](https://coveralls.io/r/titarenko/flou?branch=master)
[![NPM](https://nodei.co/npm/flou.png?downloads=true&stars=true)](https://nodei.co/npm/flou/)
## Installation
```bash
npm install flou --save
```## Example
```js
var Flow = require('flou');var saveOrderPromise = new Flow({ order: someOrder })
.having('order')
.run(findCountry, findRegionAndTimezone, findOperator, findOffer)
.having('country', 'regionAndTimezone')
.run(createClientRecord).having('clientRecord', 'offer')
.run(createOrderRecord).having('country')
.run(findShipmentMethod).having('country', 'shipmentMethod', 'orderRecord')
.run(createOrderShipmentRecord).having('operator', 'orderRecord')
.run(createOrderCallRecord).having('orderShipmentRecord', 'orderCallRecord')
.run(updateOrderRecord)
.returning('updatedOrderRecord').having('updatedOrderRecord')
.finish();saveOrderPromise.done(function (context) {
console.log('Hooray! I have passed all steps of the specified flow! Id of order is', context.order.id);
}, function (error) {
console.error('Oh no! Flow was interrupted due to', error && error.stack || error);
});
```## API
### Flow(initialValues)
Creates flow object initialized with named values passed as hash.
### having(name1, name2, name3, ...)
Starts flow step building by accepting names of flow variables which must be resolved (in terms of promises) before step can start.
### run(fn1, fn2, fn3, ...)
Schedules execution of given functions once preconditions are met (see `having`).
Each function should (but not must!) accept one argument which is hash of named flow variables and should (but not must!) return any value.
Each function result will be saved as flow variable named after function or using value provided via `returning` (see next section for details). "Named after function" here means equals to function name without leading verb (for example, result of `saveOrderRecord` will be named `orderRecord`).
### returning(name1, name2, name3, ...)
Explicitly specifies names for function execution results.
### finish()
Finalizes flow and returns final promise.
## License
BSD