Skip to content
/ cwl-ts Public
forked from rabix/cwl-ts

Typescript data model for Common Workflow Language

License

Notifications You must be signed in to change notification settings

amaris/cwl-ts

This branch is 252 commits behind rabix/cwl-ts:master.

Folders and files

NameName
Last commit message
Last commit date
Feb 8, 2018
Apr 5, 2018
Feb 8, 2018
Feb 8, 2018
Feb 8, 2018
May 19, 2016
Feb 24, 2017
Mar 22, 2018
Mar 22, 2018
Feb 8, 2018

Repository files navigation

cwl-ts

Build Status npm version

CWL-ts is a data model library for the Common Workflow Language made for use in TypeScript and JavaScript (primarily client-side) applications.

It supports JSON schemas and mappings for draft-3, draft-4, and v1.0. Draft-2 support is SevenBridges flavored.

Installation

npm install cwlts

Build

The npm package can be built locally by running the following command. It will generate .d.ts and compiled .js files into the /lib directory.

./scripts/package.sh

Mappings

lib/mappings contains TypeScript interfaces that can be used for type hinting when working with CWL documents in TS/JS.

Schemas

lib/schemas contains JSON Schema definitions for CommandLineTool, Workflow and ExpressionTool for each draft/version. They can be used with a JSON Schema validator to ensure schema validity of a CWL document.

Models [WIP]

lib/models contains TypeScript classes representing CWL entities. Models are still in early development, so many intended features are not implemented yet or don't function properly. The purpose of these models is to provide a set of methods that will facilitate working with CWL in a client-side application--one that graphically displays CWL documents or creates them. They should abstract differences between drafts and versions, provide a consistent API, and always generate correct and valid CWL documents.

CommandLineToolModel should:

  • generate command line when supplied test data
  • evaluate and validate expressions
  • enable operations on complex child objects (inputs, outputs, arguments, etc)

WorkflowModel should:

  • generate DAG of workflow
  • enable adding and connecting steps
  • enable operations on complex child objects (inputs, outputs, steps, etc)

About

Typescript data model for Common Workflow Language

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 91.6%
  • Common Workflow Language 5.7%
  • JavaScript 2.5%
  • Shell 0.2%