This update includes numerous bugfixes and a number of reintroduced features.
- Trigger nodes allow you to pause workflow execution until webhook for the trigger is hit with data
- Basic Condition nodes allow you to perform branching execution in a more flowchart-like manner
- Basic Transform nodes allow you to write code snippets to transform/remap/select action results on the fly (UI support pending)
- App version no longer required in app_name in api.tyaml
- CRUD endpoints now accept resource names as keys when applicable
- Globals can now be arbitrary JSON (UI support pending)
- Workflow import/export
- Workflow validation (still needs work); workflows can be saved in an incomplete state again
- Testing suite (still needs expansion)
- Uniqueness constraints on CRUD operations
- Dereferencing Global and Workflow variables in workflows
- Ability to override starting parameters in a workflow execution
This update includes a near-complete rewrite of the workflow execution logic, and a considerable refactor of the server in preparation for a future move to an asynchronous framework. The following changes are not exhaustive.
- "Umpire" added, which handles building and replication of Worker and App containers.
- Docker Compose is required. Python 3.7 is required if running components locally (primarily for development).
- Execution logic completely rewritten to support containerized architecture from the ground up.
- Apps now live in their own containers, separate from workers.
- Apps should now be (internally) stateless
- Kubernetes support has been removed in favor of using Docker Swarm API.
- Playbooks removed, Workflows can now be grouped by tags instead.
- unittest has been replaced with pytest
- Redis is now the primary communication channel between components (removing ZMQ and Kafka).
- SQLite database should no longer be used if running locally for development.
- Workflow Execution page has been overhauled aesthetically.
- Triggers have been temporarily removed, but are targeted for a near-future 1.1 release.
- Added ability to view WALKOFF Server API locally via /api/docs with the server running.
- Execution DB now gets properly closed when WALKOFF exits. Fixes issues with docker-compose stop/start.
- Triggers on unbound actions (apps without devices) fixed.
- Add Docker image and compose file based on development branch.
- Upgraded WALKOFF Server API from swagger2 to openapi3, which includes improved security, and better request validation.
- Upgraded Python marshmallow library version, which includes stricter validation.
- Please note: because some dependency library versions were changed in the requirements.txt file, users must run the command
pip install --upgrade -r requirements.txt
to make sure all dependencies are met. This is also good practice to do after every new release.
This is a minor release to fix missing front-end resources. A number of documentation changes have also been made, particularly regarding installing WALKOFF on Windows, as running WALKOFF directly on Windows has no longer supported since 0.9.0.
- References to running WALKOFF directly on Windows now emphasize lack of support.
- Front-end dependencies have been added to the repository.
This is a minor release primarily to ease installation of WALKOFF.
- README.md contains further documentation on running WALKOFF locally, in Docker, or in Kubernetes
- NodeJS and NPM are no longer required, as the front-end components are now prepackaged in the main repository.
- README.md now contains more detailed instructions on using WALKOFF with Docker, as well as a docker-compose file
- All databases will now be stamped with the most up-to-date alembic version, so WALKOFF will not run if you are using an out-of-date database (see Fixed section for more details)
- When using Redis as an external accumulator, results are now pickled to preserve typing. This fixes the issue where everything (list, int, etc.) was incorrectly being returned as strings
- Fixed walkoffctl update script to correctly update databases -- run
python -m walkoff local update
to update - ActionResult objects are now pretty-printed correctly in the console and log files
- Python Redis library is now pinned in requirements.txt due to breaking changes
- Fixed certificate generation for Kubernetes certificates
- Update.py script was removed and replaced with walkoffctl update (see Fixed section for more details)
Please Note: From version 0.9.0 forwards, WALKOFF requires a Redis cache to operate. You can run Redis natively on most Linux distributions (see the Redis quickstart guide: https://redis.io/topics/quickstart or search for a package in your OS's package manager). On Windows, you will need to use Docker to run Redis in a container or expose Redis from a VM.
- Support for running WALKOFF in a Kubernetes cluster using docker images and helm
- Command line interface (walkoffctl) for managing WALKOFF installations, both locally and on Kubernetes
- More comprehensive logging with Prometheus, fluentd, and flask
- Ability to run apps in separate containers for better scalability (still in-progress)
- Support for templating Docker files for apps and runtimes
- Began introducing PyTest as a more maintainable alternative to unittest
- Support for tracking which User executed which Workflow
- Now have the option of choosing ZMQ sockets or Kafka message queues to communicate with executing Workflows
- Moved logic of executing a Workflow into Workflow execution context objects, which allows for more flexiblity
- Upgraded to boostrap4 and Angular 6.1.7
- Removed support for DiskCache -- a Redis cache must be installed to run WALKOFF
- The Case database, as it was unnecessary on top of the comprehensive logging done by WALKOFF
- Fixed the foreign key constraints in both databases (they were not being enforced previously)
- Connexion library version updated in requirements.txt to fix access_token and 404 error
- Minor aesthetic improvements to front-end
- Fixed a bug caused by a new version of the connexion library which made the OpenAPI specification invalid
- Workflows now support environment variables. These are top-level arguments to a workflow. These are then exposed on the execution page allowing users to modify the most important variables in a workflow without modifying the workflow itself.
- Added a health check endpoint at the /heath endpoint
- The Metrics page now defaults to showing workflow metrics instead of app metrics
- Action results and workflow results stream now filter for the currently-executing workflow. This eliminates many issues experienced by multiple users executing workflows concurrently from the workflow editor
- Fixed an error which caused the Scheduler to not execute workflows
- Fixed another bug in the scheduler in which the scheduled workflows would not persist across server restarts
- A bug where messages couldn't be sent
- A bug where modifying more than one device at a time on the playbook editor would cause the workflow to be invalidated
- Some database configuration bugs when used with non-SQLite databases
- Fixed a bug which wouldn't allow a user to a abort a workflow if it was pending execution.
- CSV to Array action in the Utilities app
- The action results SSE stream truncates the result using the
MAX_STREAM_RESULTS_SIZE_KB
config option
- Bytes conversion bug in the RedisCacheAdapter
- Bug in playbook editor using users and roles as arguments
- Bug where some callbacks weren't getting registered
- Column width bug in playbook editor, execution, and metrics pages
- OpenAPI validation bug with newest version of the swagger validator
- Arguments can now reference branches. This will resolve to the number of times that branch has been executed.
- Log messages are more comprehensive and useful.
- More error checking on the worker processes to harden them.
- Bug where databases couldn't be used with a password.
- Bug where app instances would receive an Argument rather than the necessary integer ID.
- Compatibility issue with pip 10 and the
install_dependencies.py
script. - Bug in validation of execution elements where, once an error was found it wouldn't be removed.
- Fixed bug where exporting playbooks with Python 3 would cause an error.
- Bug where argument ids were not stripped on exporting of playbooks, causing errors when importing them onto a different instance of Walkoff.
- Bug where Workflows with unbounded Actions were unable to be executed
- Multiple tools have been added to help develop workflows
- Playbooks can be saved even if they are invalid. However, playbooks cannot be executed if they are invalid.
- The playbook editor displays the errors on a workflow which must be solved before the workflow can be executed
- You can now use Python's builtin
logging
module in an app, and the log messages will be displayed in the playbook editor
- The metrics page has been introduced in the UI which displays simple metrics related to the execution of workflows and actions.
- The devices used in the actions in workflows are now objects, enabling
dynamic selection of the device used for the action. To further support this,
an action in the Utilities app named
get devices by fields
allows you to query the devices database. - The ability to use a key-value storage has been created. This is now the mechanism used to push workflows and backs the SSE streams. Currently two options are available for key-value store, DiskCache, a SQLite-backed key-value storage, and Redis. By default Walkoff will use DiskCache, but it is recommended that users configure and use Redis.
- The SSEs now use dedicated SseStream objects which are backed by the cache.
These objects make constructing and using streams much easier.
walkoff.see.InterfaceSseStream
andwalkoff.sse.FilteredInterfaceSseStream
objects have been made available to use in custom interfaces. - A
CaseLogger
object which makes it much easier to log events to the case database has been created.
- The
interfaces.AppBlueprint
used to construct interfaces has been modified to extend fromwalkoff.sse.StreamableBlueprint
which in turn extends Flask's Blueprint. This makes the interface cleaner and more flexible. - Changes to the REST API
- In the configuration resource:
workflow_path
,logging_config_file
, andzmq_requests
have been removed from the API- The ability to edit the cache configuration has been added
- In the playbook resources:
- All execution elements have a read only list of human-readable errors
- A workflow has a read only Boolean field "is_valid" which indicates if any of its execution elements have errors
- In the configuration resource:
- All changes to the configuration will only be applied on server restart
- Refactorings have been done to minimize the amount of global state used throughout Walkoff. Work will continue on this effort.
- Metrics are now stored in the execution database
- Changes to styling on the playbook editor
walkoff.helpers.create_sse_event
has been deprecated and will be removed in version 0.10.0. Usewalkoff.sse.SseEvent
or the streams inwalkoff.sse
instead .
- Bug where branches where all branches weren't being evaluated in a workflow
- Bug where object arguments could not be converted from strings
- Testing the backend now requires the additional the dependencies in
requirements-test.txt
- The minimum accepted unit test coverage for the Python backend is now 88%
- Bug where some device fields were being deleted on update
- Bug where NO_CONTENT return codes were failing on Werkzeug WSGI 0.14
- All node modules are now bundled into webpack
- An unintentional backward-breaking change was made to the format of the dictionary used in the interface dispatcher which sometimes resulted in a dict with a "data" field inside a "data" field. This has been fixed.
- Improved deserialization in the user interface
- Empty arrays are omitted from returned execution element JSON structure in the REST API.
PATCH /api/devices
now doesn't validate that all the fields of the device are provided.- Fixed dependency bug on GoogleProtocolBuffer version
- An execution control page is now available on the user interface. This page
allows you to start, pause, resume, and abort workflows as well as displays
the status of all running and pending workflows.
- With this feature is a new resource named
workflowqueue
which is available through the/api/workflowqueue
endpoints.
- With this feature is a new resource named
- You now have the ability to use a full set of Boolean logic on conditions. This means that on branches and triggers you can specify a list of conditions which must all be true (AND operator), or a list of conditions of which any must be true (OR operator), or a list of conditions of which exactly one must be true (XOR operator). You can also negate conditions or have child conditions. This new conditional structure is called a ConditionalExpression and wraps the old Condition objects.
- Playbooks can be exported to and imported from a JSON text file using the new
GET /api/playbooks?mode=export
and thePOST /api/playbooks
using amultipart/form-data
body respectively.
- Significant changes to the REST API
- We have changed the HTTP verbs used for the REST API to reflect their more widely-accepted RESTful usage. Specifically, the POST and PUT verbs have been swapped for most of the endpoints.
- Workflows are now accessed through the new
/api/workflows
endpoints rather than the/api/playbooks
endpoints - The
/api/playbooks
and the/api/workflows
endpoints now use the UUID instead of the name. - The
/api/playbook/{id}/copy
and the/api/playbooks/{id}/workflows/{id}/copy
endpoints are now accessed throughPOST /api/playbooks?source={id_to_copy}
and thePOST /api/workflows?source={id_to_copy}
endpoints respectively. - Server-Sent Event streams are now located in the
/api/streams
endpoints - Errors are now returned using the RFC 7807 Problem Details standard
- Playbooks, workflows, and their associated execution elements are now stored in the database which formerly only held the devices. The both greatly increased scalability as well as simplified the interactions between the server and the worker processes as well as increased scalability.
- Paused workflows and workflows awaiting trigger data are now pickled (serialized to binary) and stored in a database table. Before, a conditional wait -was used to pause the execution of a workflow. By storing the state to the database, all threads on all worker processes are free to execute workflows.
- Information about the workflow which sent events are now available in both the Google Protocol Buffer messages as well as the arguments to callbacks using the interface event dispatcher.
- All times are stored in UTC time and represented in RFC 3339 format
- The marshmallow object serialization library is now used to serialize and deserialize execution elements instead of our old homemade solution
- The "sender_uids" argument in the interface dispatcher
on_xyz_event
decorators is now an alias for "sender_ids". This will be removed in version 0.9.0
- The
/api/playbooks/{name}/workflows/{name}/save
endpoint has been removed. - The
/api/playbooks/{name}/workflows/{name}/{execute/pause/resume}
endpoints have been removed. Use the/api/workflowqueue
resource instead - Removed
workflow_version
from the playbooks. This may be added later to provide backwards-compatible import functionality to the workflows. /api/devices/import
and/api/devices/export
endpoints have been removed. Use the newPOST /api/devices
withmultipart/form-data
andGET /api/devices?mode=export
endpoints respectively.
- The minimum accepted unit test coverage for the Python backend is now 86%
- Fixed bug in
create_sse_event
where data field of the SSE would not be populated if no data was not specified, causing the SSE event to be invalid
- Omitting
sender_uids
ornames
ondispatcher.on_xyz_event
decorators in interfaces now registers the decorated function for all senders. This is consistent with the previously inaccurate code examples in the tutorials.
- Webpack is now used to increase UI performance
- Default return codes for the Walkoff app
- Some UI tests are now run on Travis-CI
- The accept/decline method returns status codes indicating if the action was accepted or declined instead of true/false
- Fixed a bug where roles weren't being deleted from the database
- Fixed issue preventing permissions to be removed on editing roles
- Fixed issue with messages not properly being marked as responded
- Added a simple action in the Utilities app named "request user approval" which sends a message with some text to a user and has an accept/decline component.
- Refactoring of AppCache to use multiple objects. We had been storing it as a large dict which was becoming difficult to reason about. This is the first step of a larger planned refactoring of how apps are cached and validated
- Bug on UI when arguments using an array type without item types specified
- Fixed issue with workflow migration caused to erroneously deleting a script
Multithreaded workers for increased asynchronous workflow execution
- Multiple workflows can be executed on each worker process
- Decorator factory to simplify endpoint logic
- Endpoint to get system stats
- Bug where roles couldn't be assigned to a user on creation
- Added AppVeyor to test Walkoff on Windows
- Multiple workflows can be executed on each worker process
- Bumped dependency of
flask-jwt-extended
to version 3.4.0
- Default logging config issue
- Removed
walkoff/client/build
which was accidentally version controlled - CodeClimate misconfiguration
- Bug fixes to messaging caused by messaging callback not being registered in the server
Introducing roles, messages, and notifications
- Administrators can now create custom roles and assign users to those roles. Each resource of the server endpoint is protected by a permission, and roles can be created which combine resource permissions.
- Messages and notifications
- Actions can now send messages to users
- Messages can be used to convey information to users or to pause a workflow and wait for a user to approve its continued execution
- When a user receives a message, a notification will appear
- Easy updates
- An update script is provided to update to the most recent version if one is
available. This script includes custom workflow migration scripts and
database migration scripts generated by SqlAlchemy-Alembic. These are a work in progress.
- Note 1: Database migrations only work for default database locations and
using SQLite. This can be changed in the
alembic.ini
file - Note 2: Now that databases and workflows can be updated easily, minor version updates will not occur on backward-breaking changes to the database schema or the playbook schema.
- Note 1: Database migrations only work for default database locations and
using SQLite. This can be changed in the
- This script also includes utility functions for backing up the WALKOFF directory, cleaning pycache, setting up WALKOFF after an update, etc.
- An update script is provided to update to the most recent version if one is
available. This script includes custom workflow migration scripts and
database migration scripts generated by SqlAlchemy-Alembic. These are a work in progress.
- Explicit failure return codes for actions
- Return codes which indicate a failure of the action can be marked with
failure: true
. This will cause an ActionExecutionError event to be sent
- Return codes which indicate a failure of the action can be marked with
- Explicit success default return codes for actions
- The default return code for an action can be specified with
default_return: YourReturnHere
- The default return code for an action can be specified with
- Internal ZeroMQ addresses can be configured through the UI
- Added this change log
- Significant repository restructure
- This repository restructure combined the
core
andserver
packages into a singlewalkoff
package and moved modules such asappcache
anddevicedb
out of theapps
package - Top-level scripts with the exception of
walkoff.py
are now located in thescripts
directory - These changes make the Walkoff project follow a more canonical repository
structure, and are one step towards being able to install walkoff using
pip
, our eventual goal.
- This repository restructure combined the
- Classes have been moved out of the
server.context.Context
class. They were located there to remove circular dependencies, but they have been moved into their own submodule. - The
interface.__init__
module has been split into multiple modules - The Sphinx Python documentation has been relocated to the
docs
directory and can be generated usingmake html
. Additionally, they now use the ReadTheDocs theme. - Google Protocol Buffer message structure has been significantly altered.
- Tags used for action, condition, and transform decorators have been encapsulated in a WalkoffTag enum
setup_walkoff.py
no longer explicitly calls Gulp
- JWT structure changes
- JWTs' identity is now the user ID, not the username
- JWT claims are now the username and a list of role IDs this user possesses. These claims are populated on login, and require reauthentication to be updated.
- Fixed a bug where the config host and port were not initialized before the server started.
- A bug fix for case management due to a typo in the TS.
Introducing a more user-friendly playbook editor and custom event-driven interfaces
- New user-friendly playbook editor
- Host and port can now be specified on the command line
- App-specific conditions and transforms
- Conditions and transforms are now located in apps rather than in core, so they can be more easily created
- Branches now contain a "priority" field which can be used to determine the order in which the branches of a given action are evaluated
- Arguments to actions, conditions, and transforms which use references can select which component of the referenced action's output to use.
- Migration scripts to help ease a variety of backward-breaking changes --
migrate_workflows.py
andmigrate_api.py
- Scripts to create Sphinx documentation have been added to the repository
- Custom interfaces with event handling
- Interfaces are no longer attached to apps; they are now their own plugins
and are contained in the
interfaces
directory - Interfaces can use new decorator functions to listen and respond to all events in Walkoff as they occur
- Interfaces are no longer attached to apps; they are now their own plugins
and are contained in the
- Better triggers
- Triggers are no longer specified in the database. Instead, each individual action in a workflow can have its own set of conditions which can act as breakpoints in a workflow. You can send data to them through the server and have that data validated against a set of conditions before the action can resume.
- You can still start a workflow from the beginning through the server
- Renamed workflow components for clarity
- "steps" have been renamed "actions"
- "next steps" have been renamed "branches"
- "flags" have been renamed "conditions"
- "filters" have been renamed "transforms"
- Script used to start the server has been renamed
walkoff.py
- ZeroMQ keys are contained in the
.certificates
directory - Playbook file format changes
- Branches are now contained outside of actions, creating two top-level fields.
- Branches have a
source_uid
and adestination_uid
instead of just aname
field - The
start
step on a workflow is indicated with the start step's UID instead of its name - The
app
andaction
fields of actions, conditions, and transforms have been renamedapp_name
andaction_name
respectively. - Conditions and transforms contain an
app_name
field instead of just anaction
field - We have removed the
widgets
field and therisk
field from actions - Devices for actions are specified by id rather than by name
- Actions'
inputs
field, as well as conditions' and transforms'args
field has been renamedarguments
and is now a complete JSON object - Playbooks now contain a
walkoff_version
field which will be used to indicate which version of WALKOFF created them. This will be helpful in the future to migrate workflows to new formats
- Minor changes to api.yaml schema
dataIn
has been renameddata_in
termsOfService
has been renamedterms_of_service
externalDocs
has been renamedexternal_docs
and is always an array
- Performance of worker processes has been improved by removing gevent from child processes and reducing polling
- The blinker Signals used to trigger events have been wrapped in a WalkoffEvent enum
- Internal sockets used for ZeroMQ communication have been moved to
core.config.config
- Actions which are defined inside of a class must supply a device, or the workflow will fail on initialization
- The REST API to get the APIs of apps has been enhanced significantly and returns all of the API
- Unfortunately, event-driven actions have been broken for some time now. We have removed this functionality, but are working on an even better replacement for them in the meantime
- We have removed accumulated risk from workflows and risk from steps. This feature will be re-added at a future date
- We have removed widgets from the backend. This feature will be reimplemented later.
- Backend support for adding roles to users has been removed. All users are administrators as they have been in previous releases. There was never a UI component for this feature, and it was breaking some other components for editing users. Roles will be re-added in the next release.
- HTTPS is enabled by default if certificates are placed in the
.certificates
directory.
- Coverage.py is used to generate test coverage report. Travis-CI will fail if the code coverage is below 81% This percentage will rise over time
- Bug fixes to Playbook editor
- Bug in global action execution
- Bug fixes to playbook editor
Introducing custom devices and global app actions
- Custom devices
- Apps define their own fields needed in their devices
- Global app actions
- Actions no longer need to be defined in a class
- Performance improvements and bug fixes
- Bug Fixes
Introducing a new Angular-driven UI, schedulers, cases, and concurrency
- Brand new UI
- Better concurrent execution of CPU-bound workflows
- Multiple workflows can be executed on the same scheduler
- New Scheduler UI page
- New Case Management UI
- Improved REST API
- Workflows are now stored as JSON
- Bugs and performance improvements
- Enhanced security using JSON Web Tokens
- Workflows are stored as JSON
- Event-driven app actions
- Multiple return codes for actions and error handling
- Apps are now located in Walkoff-Apps repo
- Workflow results are stored in case database
- Bug fixes and performance improvements
Introducing app action validation and improved data flow
- New app specification using YAML metadata files
- Better input validation using JSON schema
- Arguments can be string, integer, number, arrays, or JSON objects
- Workflow animation during execution in the workflow editor
- Results from previously executed actions can be used later in workflows
- Better workflow monitoring during execution
- New apps
- NMap
- Splunk
- TP-Link 100 Smart Outlet
- UI styling and bug fixes
- Bug fixes and performance improvements
- New Lifx playbook
- Bug fixes to UI and apps
- OpenAPI Specification for server endpoints and connexion Flask app
- New Apps
- AR.Drone
- Ethereum Blockchain
- Facebook User Post
- Webcam
- Watson Visual Recognition
- Tesla
- Lifx
- Better error handling in server endpoints
- Bug fixes
- Swagger UI documentation
- UI improvements
Initial Release