Skip to content

flow-build/workflow-api

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Workflow API

Dependencies:

node -v
v18.12

npm -v
9.2.0

Environment variables

Add a .env file with the following variables:

  • NODE_ENV (suggested value = docker)
  • KOA_LOG_LEVEL (error, warn, info, http, verbose, debug, silly)
  • PORT (default=3000)

DATABASE CONNECTION

  • KNEX_ENV (text, docker, dockerLocal, prod)
  • POSTGRES_PORT
  • POSTGRES_HOST
  • POSTGRES_DATABASE
  • POSTGRES_USER
  • POSTGRES_PASSWORD
  • DB_MAX_POOL_CONNECTION (default=10)

TOKEN CONFIGURATION

The default configuration is set to use a own generated JWT token. If an external token is to be used, the JWT_ variables need to be passed.

  • JWT_KEY (default=1234)
  • JWT_ALG (default=HS256, if set to RS256, the application will convert the JWT_KEY to a public certificate.)
  • JWT_PASSTHROUGH (boolean, default=true)
  • JWTEXTRA_KEYS (_optional, defines extra properties from token payload that should be sent to process' actor_data)
  • JWT_PATH_ACTOR_ID (default=actor_id, specifies the path to the actor id in the token payload)
  • JWT_PATH_CLAIMS (default=claims. Claims value should always be an array)
  • JWTPATH_SESSION_ID (_optional, default=session_id)

MQTT CONFIGURATION

  • MQTT (bool)
  • MQTT_HOST
  • MQTT_PORT
  • MQTT_PATH
  • MQTT_PROTOCOL
  • MQTTUSERNAME (_optional, required for wss connections)
  • MQTTPASSWORD (_optional, required for wss connections)
  • MQTT_NAMESPACE (if present, this string will the prepended to any topic published)

AMQP CONFIGURATION

  • AMQP (bool)
  • BROKER_HOST
  • BROKER_QUEUE
  • BROKER_USERNAME
  • BROKER_PASSWORD

KAFKA CONFIGURATION

  • KAFKA (bool)
  • KAFKA_BOOTSTRAP_SERVER
  • KAFKA_SEC_PROTOCOL
  • KAFKA_SASL_MECHANISMS
  • KAFKA_CLUSTER_API_KEY
  • KAFKA_API_SECRET
  • KAFKA_SESSION_TIMEOUT

EVENT Nodes CONFIGURATION (also WEM CONFIGURATION)

  • WORKFLOW_EVENTS_BROKER (Values: KAFKA|MQTT|AMQP. If not defined, it won't send)
  • WORKFLOW_EVENTS_NAMESPACE

CHOOSING BROKERS TO USE (AMQP OR MQTT)

  • ACTIVITY_MANAGER_BROKER
  • PROCESS_STATE_BROKER
  • ENGINE_LOGS_BROKER

ACTIVITY_MANAGER CONFIGURATION

  • ACTIVITY_MANAGER_SEND_ONLY_ON_CREATION (bool)

ENGINE CONFIGURATION

  • ENGINE_LOG_LEVEL (default=error)
  • ENGINE_HEARTBEAT (true/false string, turns on-off engine heartbeat)
  • HEART_BEAT (integer, default=1000, interval between beats in ms)
  • PUBLISH_STATE_EVENTS (true/false string, enables states to be published to message broker)
  • PUBLISH_ENGINE_LOGS (true/false string, enables engine logs to be published to message broker)
  • PUBLISH_SERVER_LOGS (true/false string, enables api logs to be published to message broker)
  • MAX_STEP_NUMBER (integer, maximum number of steps for a process)
  • MAX_CONTENT_LENGTH (integer, max content length for response on http node calls)
  • MAX_BODY_LENGTH (integer, max body length for response on BasicAuth nodes)
  • HTTP_TIMEOUT (integer, timeout in ms for BasicAuth nodes)
  • TIMER_BATCH (integer, default=40)
  • ORPHAN_BATCH (integer, default=40)

TIMER CONFIGURATION

Timer management can be handled outside the heartbeat, by a external Timer Worker running timers using an Redis Queue using bullMQ. To enable this option, the engine must be configured to publish timers on the queue thru 3 variables that configures the bullMQ.

  • TIMER_QUEUE (string)
  • TIMER_HOST (URL)
  • TIMER_PORT

HEALTHCHECK

Healthcheck route (GET / or GET /healthcheck), by default, checks the router and db connection. The server can be configured to evaluate the number of ready timers (timers expired but not yet triggered) to access engine health. This setting should not be enabled if the timers area being handled by the timer worker.

  • MAXREADY_TIMERS (_optional, integer, defines the amount of ready timers before the server is declared unhealthy)

MONITORING

  • OTEL_ENABLED (bool, activates Open Telemetry config)
  • OTEL_SERVICE_NAME (string)
  • OTEL_COLLECTOR_URL

NEW RELIC CONFIGURATION

  • NEW_RELIC_ENABLED (bool, activates New Relic config for direct or OTEL Monitoring.)
  • NEW_RELIC_API_KEY (required if New Relic is enabled)
  • NEW_RELIC_NO_CONFIG_FILE (recommended=true)
  • NEW_RELIC_LOG (recommended=stdout)
  • NEW_RELIC_LOG_ENABLED (recommended=true)
  • NEW_RELIC_LOG_LEVEL (recommended=info)
  • NEW_RELIC_DISTRIBUTEC_TRACING_ENABLED (recommended=true)
  • NEW_RELIC_APPLICATION_LOGGING_ENABLED (recommended=true)
  • NEW_RELIC_APP_NAME

POSTMAN

For Newman test runs

  • POSTMAN_API_KEY
  • POSTMAN_TEST_COLLECTION
  • POSTMAN_ENVIRONMENT

Run the project on docker:

To run docker, just run

docker-compose up

Make sure ports 3000 and 5432 are free to use on your localhost.

To run the tests, you may use the command below:

docker-compose run -T app ./scripts/run_tests.sh

For Windows users, comment the script command from the docker-compose.yml and use the bash one.

Exploring and executing the API

To explore all possible routes, go to http://localhost:3000/swagger

If you change the base url, change it as well in the openapi3.yaml file.

If you wish to use a third-party program, such as Insomnia or Postman, just import the openapi3.yaml file and all the routes will be shown. If you use Postman, I would recommend changing the Folder organization to Tags after selecting the file to be imported.

Logging

There are 2 sources of logs: engine and the API itself. Both uses winston library to manage formats and transports.

The events emitted by the engine can by logged by the engine itself or managed by the API app.

You can set the log level from the engine using the ENGINE_LOG_LEVEL variable. At the time you cannot turn them completely off.

The log levels use the scale below:

silly -> debug -> verbose -> http -> info -> warn -> error

The API app uses the same log levels, but they are managed by the KOA_LOG_LEVEL variable and has a default value of info.

Notice that at default configuration, error events are logged twice.

Engine events will also be sent to a /logs topic to mqtt if the both MQTT and PUBLISH_ENGINE_LOGS are set to true.

MQTT

The default compose will set up a postgres database, an hive MQTT server and the app itself.

During app initialization, is the MQTT is true, the flowbuild will try to connect to the MQTT server.

Be sure to provide the following parameters as environment variables

  • MQTT_HOST (localhost if you a running on docker)
  • MQTT_PORT (8000)
  • MQTT_PATH (/mqtt)

The following topics will be used:

  • /logs for engine logs
  • /process/:processId/state for each process state created
  • /process/:processId/am/create for each activity_manager created
  • /actor/:actorId/am/create for each activity_manager created, if an actor_id property exists in activity_manager input
  • /session/:sessionId/am/create for each activity_manager created, if an session_id property exists in activity_manager input

Tests

You can run unit tests by running npm run tests.

If you would like to test the routes itself, you can use Newman to do that, by running the command.

newman run postman \newman\tests.postman_collection.json -e postman\newman\local_environment.json

Bibliography

how to prepare for windows

how to install docker on windows hot to install wsl2

how to prepare for linux

how to install docker on linux distros

About

No description or website provided.

Topics

Resources

License

Security policy

Stars

Watchers

Forks

Packages

No packages published

Languages