# Use via the CLI
npm install -g asl-puml
# Use in your code
npm install asl-puml
$ asl-puml --help
Usage: asl-puml [options]
Amazon States Language to PUML
Options:
Amazon States Language to PUML
Options:
-i --input <input> path to input file
-o --output <output> path to output dir
-c --config <config> path to config file
-h, --help display help for command
Return status:
0
if diagram was generated1
if there was an error
const aslPuml = require('asl-puml');
const definition = require('./path/to/my/state/machine/json/definition');
const { isValid, puml, message } = aslPuml(definition);
if (isValid) {
console.log(puml)
} else {
console.error(message);
}
Generates a plantuml state diagram from a valid Amazon States Language file.
The existing tools are good, but I'm looking for a simpler rendering that encodes a little more info than the AWS Toolkit.
I also do all of my development in an IDE and don't want to switch to the browser based AWS Workflow Studio.
See __tests__/Definitions/demo.asl.json
for the step function used for these examples.
The diagrams below show the same step function rendered by:
- asl-puml (this library)
- AWS Toolkit
- AWS Workflow Studio
Feature or Style Requirement |
asl-puml | AWS Toolkit | AWS Workflow Studio |
---|---|---|---|
renders the step function as a state diagram | |||
conveys the behavior for the state | ✅, via colors and some icons | ❌ | ✅, very familiar AWS icons and colors. |
matches the style for instance executions | ❌ | ✅ | ❌ |
renders within Webstorm/JetBrains products | ✅, via the existing plantuml plugin | ❌, not in AWS Toolkit for Webstorm | ❌ |
renders the step function within VS Code | ✅, via the existing plantuml plugin | ✅, available in AWS Toolkit for VS Code | ❌ |
label the path from a catch | ✅, with line weight and color | ❌ | ✅, path is labeled with a Catch |
label the path to a Fail state | ✅, with line weight and color | ❌ | ❌ |
identify the compensation path | ✅, albeit hard coded by state name regex | ❌ | ❌ |
avoid drawing duplicate paths to reduce clutter (catches) | ✅ | ✅ | ❌, all paths are drawn |
The term "compensate" is borrowed from business processes where it refers to the undoing of work as part of handling a fault.
When reviewing a process, it's useful to identify which parts of the process are in service of the happy path versus those in the compensation path.
Currently, the library uses a regex to match on the state's name to decide if it's in the compensation path. This will be made configurable as part of the theme. There isn't a good way to determine the compensation path without hints from the config.
A user supplied file that conforms to the config-schema.json type can be provided to control the diagram theme.
{
"theme": {
"skinparams": {
"ArrowColor": "#black"
},
"states": {
"Pass": {
"BackgroundColor": "#whitesmoke"
},
"Map": {
"BackgroundColor": "#whitesmoke"
},
"Choice": {
"BackgroundColor": "#whitesmoke"
},
"Parallel": {
"BackgroundColor": "#whitesmoke"
},
"Wait": {
"BackgroundColor": "#whitesmoke"
},
"Task": {
"BackgroundColor": "#lightblue"
},
"Fail": {
"BackgroundColor": "#red"
},
"Succeed": {
"BackgroundColor": "#green"
}
},
"lines": {
"fromCatch": {
"bold": true,
"color": "#orange"
},
"toFail": {
"color": "#pink"
}
},
"compensation": {
"pattern": "^.*(compensate).*$",
"color": "#orange"
}
}
}
See LICENSE.