All notable changes to this project will be documented in this file.
Added
for new features.Changed
for changes in existing functionality.Deprecated
for soon-to-be removed features.Removed
for now removed features.Fixed
for any bug fixes.Security
in case of vulnerabilities.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- Use standard styles for link, fix home button in breadcrumbs #2354
- Don't log 406 Not Acceptable errors to Sentry #2350
- Correctly handle floats in LogMessage #2348
- Make root layout configurable #2310
- Use snapshots when initiating Github Sync #1827
- Move runtime logic into module #2338
- Use
AccountHook Extension
to register new users invited in a project #2341 - Standardized top bars across the UI with a navigable breadcrumbs interface #2299
- Limit frame size of worker socket connections #2339
- Limit number of days to 31 in cron trigger dropdown #2331
- Expose more Kafka configuration at instance-level. #2329
- Table action css tweaks #2333
- A rudimentary optimisation for Kafka messages that do not have a key as the sequence of these messages can not be guaranteed. #2323
- Fix an intermittent bug when trying to intern Kafka offset reset policy. #2327
- CSS - standardized some more tailwind components PR#2324
- Enable End to End Integration tests #2187
- Make selected Kafka trigger parameters configurable via ENV vars. #2315
- Use the Oauth2
revocation_endpoint
to revoke token access (1) before attempting to reauthorize and (2) when users schedule a credential for deletion #2314 - Standardized tailwind alerts #2314
- Standardized
link
tailwind style (and providedlink-plain
,link-info
,link-error
, andlink-warning
) #2314
- Fix work order URL in failure alerts #2305
- Fix error when handling existing encrypted credentials #2316
- Fix job editor switches to the snapshot version when body is changed #2306
- Fix misaligned "Retry from here" button on inspector page #2308
- Add experimental support for triggers that consume message from a Kafka cluster #1801
- Workflows can now specify concurrency, allowing runs to be executed syncronously or to a maximum concurrency level. Note that this applies to the default FifoRunQueue only. #2022
- Invite Non-Registered Users to a Project #2288
- Make modal close events configurable #2298
- Prevent Oauth credentials from being created if they don't have a
refresh_token
#2289 and send more helpful error data back to the worker during token refresh failure #2135 - Fix CLI deploy not creating snapshots for workflows #2271
- UsageTracking crons are enabled again (if config is enabled) #2276
- UsageTracking metrics absorb the fact that a step's job_id may not currently exist when counting unique jobs #2279
- Adjusted layout and text displayed when preventing simultaneous edits to accommodate more screen sizes #2277
- Prevent two editors from making changes to the same workflow at the same time #1949
- Moved the Edge Condition Label field to the top of the form, so it's always visible #2236
- Update edge condition labels in the Workflow Diagram to always show the condition type icon and the label #2236
- Do Not Require Lock Version In URL Parameters #2267
- Trim erroneous spaces on user first and last names #2269
- When the entire log string is a valid JSON object, pretty print it with a
standard
JSON.stringify(str, null, 2)
but if it's something else then let the user do whatever they want (e.g., if you writeconsole.log('some', 'cool', state.data)
we won't mess with it.) #2260
- Fixed sticky toggle button for switching between latest version and a snapshot of a workflow #2264
- Bumped the ws-worker to v1.3
- Fix issue when selecting different steps in RunViewer and the parent liveview not being informed #2253
- Stopped inspector from crashing when looking for a step by a run/job combination #2201
- Workflow activation only considers new and changed workflows #2237
- Allow endpoint plugs to be injected at compile time. #2248
- All models to use the
public
schema. #2249 - In the workflow diagram, smartly update the view when adding new nodes #2174
- In the workflow diagram, remove the "autofit" toggle in the control bar
- Remove prompt parameter from the authorization URL parameters for the Generic Oauth Clients #2250
- Fixed react key error #2233
- Show common functions in the Docs panel #1733
- Update email copies #2213
- Fix jumpy cursor in the Job editor. #2229
- Rework syncing behaviour to prevent changes getting thrown out on a socket reconnect. #2007
- Use of snapshots for displaying runs and their associated steps in the History page. #1825
- Added view-only mode for rendering workflows and runs in the Workflow Canvas and the Inspector page using snapshots, with the option to switch between a specific snapshot version and the latest version. Edit mode is available when displaying the latest version. #1843
- Allow users to delete steps sssociated with runs in the Workflow Canvas #2027
- Link to adaptor
/src
from inspector. - Prototype AI Assistant for working with job code. #2193
- Reverted behaviour on "Rerun from here" to select the Log tab. #2202
- Don't allow connections between an orphaned node and a Trigger#2188
- Reduce the minimum zoom in the workflow diagram #2214
- Fix some adaptor docs not displaying #2019
- Fix broken
mix lightning.install_adaptor_icons
task due to addition of Finch http client change.
- Added a notice on application start about anonymous public impact reporting and its importance for the sustainability of Digital Public Goods and Digital Public Infrastructure.
- Increase default
WORKER_MAX_RUN_DURATION_SECONDS
to 300 to match the ws-worker default so if people don't set their timeout via ENV, at least the two match up.
- Fix vanishing Docs panel when Editor panel is collapsed and opened again #2195
- Maintain tab when RunViewer remounts/push state drops tab hash #2199
- Erlang to 26.2.5
- Update debian bookworm from 20240130 to 20240513.
- Return 403s when Provisioning API fails because of usage limits #2182
- Update email notification for changing retention period #2066
- Return 415s when Webhooks are sent Content-Types what are not supported. #2180
- Updated the default step text
- Rewrite TabSelector (now Tabbed) components fixing a number of navigation issues #2051
- Support multiple edges leading to the same step (a.k.a., "drag & drop") #2008
- Replace LiveView Log Viewer component with React Monaco #1863
- Bump default CLI to
@openfn/[email protected]
- Don't show deprecated adaptor versions in the adaptor version picklist (to be followed by some graceful deprecation handling/warning in later work) #2169
- Refactor count workorders to reuse search code #2121
- Updated provisioning error message to include workflow and job names #2140
- Don't let two deploy workflows run at the same time to prevent git collisions #2044
- Stopped sending emails when creating a starter project #2161
- Change Default Text For New Job Nodes #2014
- Persisted run options when runs are created, not when they are claimed. This has the benefit of "locking in" the behavior desired by the user at the time they demand a run, not whenever the worker picks it up. #2085
- Made
RUN_GRACE_PERIOD_SECONDS
a configurable ENV instead of 20% of theWORKER_MAX_RUN_DURATION
#2085
- Stopped Janitor from calling runs lost if they have special runtime options #2079
- Dataclip Viewer now responds to page resize and internal page layout #2120
- Stop users from creating deprecated Salesforce and GoogleSheets credentials. #2142
- Delegate menu customization and create menu components for reuse. #1988
- Disable Credential Save Button Until All Form Fields Are Validated #2099
- Fix Credential Modal Closure Error When Workflow Is Unsaved #2101
- Fix error when socket reconnects and user is viewing a run via the inspector #2148
- Preserve custom values (like
apiVersion
) during token refresh for OAuth2 credentials #2131
- Don't compile Phoenix Storybook in production and test environments #2119
- Improve performance and memory consumption on queries and logic for digest mailer #2121
- When a refresh token is updated, save it! #2124
- Fix duplicate credential type bug #2100
- Ensure Global OAuth Clients Accessibility for All Users #2114
- Fix credential not added automatically after being created from the canvas. #2105
- Replace the "not working?" prompt by "All good, but if your credential stops working, you may need to re-authorize here.". #2102
- Fix Generic Oauth credentials don't get included in the refresh flow #2106
- Replace LiveView Dataclip component with React Monaco bringing large performance improvements when viewing large dataclips. #1872
- Allow users to build Oauth clients and associated credentials via the user interface. #1919
- Refactored image and version info #2097
- Fixed issue where updating adaptor name and version of job node in the workflow canvas crashes the app when no credential is selected #99
- Removes stacked viewer after switching tabs and steps. #2064
- Fixed issue where updating an existing Salesforce credential to use a
sandbox
endpoint would not properly re-authenticate. #1842 - Navigate directly to settings from url hash and renders default panel when there is no hash. #1971
- Fix render settings default panel on first load #1971
- Upgraded Sentry to v10 for better error reporting.
- Fix the "reset demo" script by disabling the emailing that was introduced to
the
create_project
function. #2063
- Bumped @openfn/ws-worker to 1.1.8
- Correctly pass max allowed run time into the Run token, ensuring it's valid for the entirety of the Runs execution time #2072
- Add Github sync to usage limiter #2031
- Remove illogical cancel buttons on user/pass change screen #2067
- Stop users from configuring failure alerts when the limiter returns error #2076
- Fixed early worker token expiry bug #2070
- Allow for automatic resubmission of failed usage tracking report submissions. 1789
- Make signup feature configurable #2049
- Apply runtime limits to worker execution #2015
- Limit usage for failure alerts #2011
- Fix provioning API calls workflow limiter without the project ID #2057
- Benchmarking script that simulates data from a cold chain. #1993
- Changed Snapshot
get_or_create_latest_for
to accept multis allow controlling of which repo it uses. - Require exactly one owner for each project #1991
- Fixed issue preventing credential updates #1861
- Allow menu items customization #1988
- Workflow Snapshot support #1822
- Fix sample workflow from init_project_for_new_user #2016
- Bumped @openfn/ws-worker to 1.1.6
- Assure workflow is always passed to Run.enqueue #2032
- Fix regression on History page where snapshots were not preloaded correctly #2026
- Fix missing credential types when running Lightning using Docker #2010
- Fix provisioning API includes deleted workflows in project state #2001
- Fix github cli deploy action failing to auto-commit #1995
- Add custom metric to track the number of finalised runs. #1790
- Set better defaults for the GitHub connection creation screen #1994
- Update
submission_status
for any Usagetracking.Report that does not have it set. #1789
- Allow description below the page title #1975
- Enable users to connect projects to their Github repos and branches that they have access to #1895
- Enable users to connect multiple projects to a single Github repo #1811
- Change all System.get_env calls in runtime.exs to use dotenvy #1968
- Track usage tracking submission status in new field #1789
- Send richer version info as part of usage tracking submission. #1819
- Fix sync to branch only targetting main branch #1892
- Fix enqueue run without the workflow info #1981
- Run the usage tracking submission job more frequently to reduce the risk of Oban unavailability at a particular time. #1778
- Remove code supporting V1 usage tracking submissions. #1853
- Fix scrolling behaviour on inspector for small screens #1962
- Fix project picker for users with many projects #1952
- Support for additional paths on a webhook URL such as
/i/<uuid>/Patient
#1954 - Support for a GET endpoint to "check" webhook URL availability #1063
- Allow external apps to control the run enqueue db transaction #1958
- Changed dataclip search from string
LIKE
to tsvector on keys and values. While this will limit partial string matching to the beginning of words (not the middle or end) it will make searching way more performant #1939 - Translate job error messages using errors.po file #1935
- Improve the UI/UX of the run panel on the inspector for small screens #1909
- Regular database timeouts when searching across dataclip bodies #1794
- Enable users to connect to their Github accounts in preparation for streamlined GitHub project sync setup #1894
- Apply usage limit to bulk-reruns #1931
- Fix edge case that could result in duplicate usage tracking submissions. #1853
- Fix query timeout issue on history retention deletion #1937
- Allow admins to set project retention periods #1760
- Automatically wipe input/output data after their retention period #1762
- Automatically delete work order history after their retention period #1761
- When automatically creating a project for a newly registered user (via the
INIT_PROJECT_FOR_NEW_USER=true
environment variable) that user should be theowner
of the project. #1927 - Give priority to manual runs (over webhook requests and cron) so that active users on the inspector don't have to wait ages for thier work during high load periods #1918
- TSVector index to log_lines, and gin index to dataclips #1898
- Add API Version field to Salesforce OAuth credentials #1838
- Replace v1 usage tracking with v2 usage tracking. #1853
- Updated anonymous usage tracker submissions #1853
- Support for smaller screens on history and inspector. #1908
- Polling metric to track number of available runs. #1790
- Allows limiting creation of new runs and retries. #1754
- Add specific messages for log, input, and output tabs when a run is lost #1757
- Soft and hard limits for runs created by webhook trigger. #1859
- Publish an event when a new user is registered #1873
- Adds ability to add project collaborators from existing users #1836
- Added ability to remove project collaborators #1837
- Added new usage tracking submission code. #1853
- Upgrade Elixir to 1.16.2
- Remove all values from
.env.example
. #1904
- Verify only stale project credentials #1861
- Show flash error when editing stale project credentials #1795
- Fixed bug with Github sync installation on docker-based deployments #1845
- Automatically create Github workflows in a target repository/branch when users set up a Github repo::OpenFn project sync #1046
- Allows limiting creation of new runs and retries. #1754
- Change bucket size used by the run queue delay custom metric. #1790
- Require setting
IS_RESETTABLE_DEMO
to "yes" via ENV before allowing the destructiveDemo.reset_demo/0
function from being called. #1720 - Remove version display condition that was redundant due to shadowing #1819
- Fix series of sentry issues related to OAuth credentials #1799
- Fixed error in Credentials without
sanbox
field set; only displaysandbox
field for Salesforce oauth credentials. #1798
- Display and edit OAuth credentials scopes#1706
- Stop sending
operating_system_detail
to the usage tracker #1785
- Make handling of usage tracking errors more robust. #1787
- Fix inspector shows selected dataclip as wiped after retying workorder from a non-first step #1780
- Actual metrics will now be submitted by Lightning to the Usage Tracker. #1742
- Added a support link to the menu that goes to the instance admin contact #1783
-
Usage Tracking submissions are now opt-out, rather than opt-in. Hashed UUIDs to ensure anonymity are default. #1742
-
Usage Tracking submissions will now run daily rather than hourly. #1742
-
Bumped @openfn/ws-worker to
v1.0
(this is used in dev mode when starting the worker from your mix app:RTM=true iex -S mix phx.server
) -
Bumped @openfn/cli to
v1.0
(this is used for adaptor docs and magic)
- Non-responsive workflow canvas after web socket disconnection #1750
- Fixed a bug with the OAuth2 credential refresh flow that prevented GoogleSheets jobs from running after token expiration #1735
- Renamed ImpactTracking to UsageTracking #1729
- Block github installation if there's a pending installation in another project #1731
- Expand work order button balloons randomly #1737
- Editing credentials doesn't work from project scope #1743
At the time of writing there are no more big changes planned and testing has gone well. Thanks to everyone who's helped to kick the tyres during the "rc" phase. There are still a lot of new features coming, so please:
- watch our Public Roadmap to stay abreast of our core team's backlog,
- request a feature in the Community Forum,
- raise a new issue if you spot a bug,
- and head over to the Contributing section to lend a hand.
Head to docs.openfn.org for product documentation and help with v1 to v2 migration.
- Bump
@openfn/worker
tov0.8.1
- Only show GoogleSheets and Salesforce credential options if Oauth clients are registered with the instance via ENV #1734
- Use standard table type for webhook auth methods #1514
- Make disabled button for "Connect to GitHub" clear, add tooltip #1732
- Add RunQueue extension to allow claim customization. #1715
- Add support for Salesforce OAuth2 credentials #1633
- Use
PAYLOAD_SIZE_KB
in k6 load testing script, set thresholds on wait time, set default payload size to2kb
- Adds more detail to work order states on dashboard #1677
- Fix Output & Logs in inspector fails to show sometimes #1702
- Bumped Phoenix LiveView from
0.20.4
to0.20.5
to fix canvas selection issue #1724
- Implemented safeguards to prevent deletion of jobs with associated run history #1570
- Fixed inspector dataclip body not getting updated after dataclip is wiped #1718
- Fixed work orders getting retried despite having wiped dataclips #1721
- Persist impact tracking configuration and reports #1684
- Add zero-persistence project setting #1209
- Wipe dataclip after use when zero-persistence is enabled #1212
- Show appropriate message when a wiped dataclip is viewed #1211
- Disable selecting work orders having wiped dataclips in the history page #1210
- Hide rerun button in inspector when the selected step has a wiped dataclip #1639
- Add rate limiter to webhook endpoints and runtime limiter for runs. #639
- Prevented secret scrubber from over-eagerly adding *** between all characters if an empty string secret was provided as a credential field value (e.g., {"username": "come-on-in", "password": ""}) #1585
- Fixed permissions issue that allowed viewer/editor to modify webhook auth methods. These permissions only belong to project owners and admins #1692
- Fixed bug that was duplicating inbound http_requests, resulting in unnecessary data storage #1695
- Fixed permissions issue that allowed editors to set up new Github connections #1703
- Fixed permissions issue that allowed viewers to initiate syncs to github #1704
- Fixed inspector view stuck at processing when following a crashed run #1711
- Fixed inspector dataclip selector not getting updated after running manual run #1714
- Shim code to interact with the Impact Tracking service #1671
- Standardized naming of "attempts" to "runs". This had already been done in the
front-end, but this change cleans up the backend, the database, and the
interface with the worker. Make sure to run migrations and update your
ENV/secrets to use
WORKER_RUNS_PRIVATE_KEY
rather thanWORKER_ATTEMPTS_PRIVATE_KEY
#1657 - Required
@openfn/[email protected]
or above.
- Store webhook request headers in Dataclips for use in jobs. #1638
- Display
http_request
dataclips to the user as they will be provided to the worker as "input" state to avoid confusion while writing jobs. 1664 - Named-spaced all worker environment variables with
WORKER_
and added documentation for how to configure them. #1672 - Bumped to
@openfn/[email protected]
- Bumped to
@openfn/[email protected]
- Fix Run via Docker #1653
- Fix remaining warnings, enable "warnings as errors" #1642
- Fix workflow dashboard bug when viewed for newly created workflows with only unfinished run steps. #1674
- Made two significant backend changes that don't impact UI/UX but require migrations and should make Lightning developer lives easier by updating parts of the backend to match terms now used in the frontend:
- Scrub output dataclips in the UI to avoid unintentional secret exposure #1606
- Bump to
@openfn/[email protected]
- Do not persist the active tab setting on the job editor #1504
- Make condition label optional #1648
- Fix credential body getting leaked to sentry incase of errors #1600
- Fixed validation on Javascript edge conditions #1602
- Removed unused code from
run_live
directory #1625 - Edge condition expressions not correctly being handled during provisioning #openfn/kit#560
- Custom metric to track stalled attempts #1559
- Dashboard with project and workflow stats #755
- Add search by ID on the history page #1468
- Custom metric to support autoscaling #1607
- Bumped CLI version to
0.4.13
- Bumped worker version to
0.5.0
- Give project editors and viewers read only access to project settings instead #1477
- Throw an error when Lightning.MetadataService.get_adaptor_path/1 returns an adaptor path that is nil #1601
- Fix failure due to creating work order from a newly created job #1572
- Fixes on the dashboard and links #1610 and #1608
- Restored left-alignment for step list items on run detail and inspector a6e4ada
- Inspector: fixed attempt/run language for "skipped" tooltip fd7dd0c
- Inspector: fixed failure to save during "save & run" from inspector #1596
- Inspector: fixed key bindings for save & run (retry vs. new work order) getting overridden when user focuses on the Monaco editor #1596
Lightning is the 2nd version of the OpenFn platform. While much of the core
technology is the same, there are breaking changes between v1.105
(pre-2024)
and v2
("OpenFn Lightning").
For customers using OpenFn v1
, a migration guide will be provided at
docs.openfn.org
- Link to the job inspctor for a selected run from the history interface #1524
- Reprocess an existing work order from the job inspector by default (instead of always creating a new work order) #1524
- Bumped worker to support edge conditions between trigger and first job
"@openfn/ws-worker": "^0.4.0"
-
Updated naming to prepare for v2 release #1248; the major change is that each time a work order (the typical unit of business value for an organization, e.g. "execute workflow ABC for patient 123") is executed, it is called a "run". Previously, it was called an "attempt". The hierarchy is now:
Build-Time: Projects > Workflows > Steps Run-Time: Work Orders > Runs > Steps
Note the name changes here are reflected in the UI, but not all tables/models will be changed until 1571 is delivered.
- Bumped worker to address occasional git install issue
"@openfn/ws-worker": "^0.3.2"
- Fix RuntimeError: found duplicate ID "google-sheets-inner-form" for GoogleSheetsComponent #1578
- Extend export script to include new JS expression edge type #1540
- Fix regression for attempt viewer log line highlighting #1589
- Hide project security setting tab from non-authorized users #1477
- History page crashes if job is removed from workflow after it's been run #1568
- Add ellipsis for long job names on the canvas #1217
- Fix Credential Creation Page UI #1064
- Custom metric to track Attempt queue delay #1556
- Expand work order row when a
workorder_id
is specified in the filter #1515 - Allow Javascript expressions as conditions for edges #1498
- Derive dataclip in inspector from the attempt & step #1551
- Updated CLI to 0.4.10 (fixes logging)
- Changed UserBackupToken model to use UTC timestamps (6563cb77)
- Restore FK relationship between
work_orders
andattempts
pending a decision re: further partitioning. #1254
- New credential doesn't appear in inspector until refresh #1531
- Metadata not refreshing when credential is updated #791
- Adjusted z-index for Monaco Editor's sibling element to resolve layout conflict #1329
- Demo script sets up example Runs with their log lines in a consistant order. #1487
- Initial credential creation
changes
showafter
asnull
rather a value #1118 - AttemptViewer flashing/rerendering when Jobs are running #1550
- Not able to create a new Job when clicking the Check icon on the placeholder #1537
- Improve selection logic on WorkflowDiagram #1220
- Improved UI when manually creating Attempts via the Job Editor #1474
- Increased the maximum inbound webhook request size to 10MB and added protection against very large payloads with a 100MB "max_skip_body_length" #1247
- Use the internal port of the web container for the worker configuration in docker-compose setup. #1485
- Limit entries count on term work orders search #1461
- Scrub log lines using multiple credentials samples #1519
- Remove custom telemetry plumbing. 1259
- Enhance UX to prevent modal closure when Monaco/Dataclip editor is focused #1510
- Use checkbox on boolean credential fields rather than a text input field #1430
- Allow users to retry work orders that failed before their first run was created #1417
- Fix to ensure webhook auth modal is closed when cancel or close are selected. #1508
- Enable user to reauthorize and obtain a new refresh token. #1495
- Save credential body with types declared on schema #1518
- Only add history page filters when needed for simpler multi-select status interface and shorter page URLs #1331
- Use dynamic Endpoint config only on prod #1435
- Validate schema field with any of expected values #1502
- Fix for liveview crash when token expires or gets deleted after mount #1318
- Remove two obsolete methods related to Run:
Lightning.Invocation.delete_run
andLightning.Invocation.Run.new_from
. #1254 - Remove obsolete field
previous_id
fromruns
table. #1254 - Fix for missing data in 'created' audit trail events for webhook auth methods #1500
- Increased History search timeout to 30s #1461
- Tooltip text clears later than the background #1094
- Temporary fix to superuser UI for managing project users #1145
- Fix for adding ellipses on credential info on job editor heading #1428
- Dimmed/greyed out triggers and edges on the canvas when they are disabled #1464
- Async loading on the history page to improve UX on long DB queries #1279
- Audit trail events for webhook auth (deletion method) change #1165
- Sort project collaborators by first name #1326
- Work orders will now be set in a "pending" state when retries are enqueued. #1340
- Avoid printing 2FA codes by default #1322
- Create new workflow button sizing regression #1405
- Google credential creation and automatic closing of oAuth tab #1109
- Exporting project breaks the navigation of the page #1440
- Added
max_frame_size
to the Cowboy websockets protocol options in an attempt to address #1421
- Work Order ID was not displayed properly in history page #1423
This release will contain breaking changes as we've significantly improved both the workflow building and execution systems.
Before, workflows were represented as a list of jobs and triggers. For greater flexibility and control of complex workflows, we've moved towards a more robust "nodes and edges" approach. Where jobs in a workflow (a node) can be connected by edges.
Triggers still exist, but live "outside" the directed acyclic graph (DAG) and are used to automatically create work orders and attempts.
We've provided migrations that bring v0.9.3
workflows in line with the
v0.10.0
requirements.
Before, Lightning spawned child processes to execute attempts in sand-boxed NodeVMs on the same server. This created inefficiencies and security vulnerabilities. Now, the Lightning web server adds attempts to a queue and multiple worker applications can pull from that queue to process work.
In dev mode, this all happens automatically and on one machine, but in most high-availability production environments the workers will be on another server.
Attempts are now handled entirely by the workers, and they report back to
Lightning. Exit reasons, final attempt states, error types and error messages
are either entirely new or handled differently now, but we have provided
migration scripts that will work to bring most v0.9.3
runs, attempts, and
work orders up to v0.10.0
, though the granularity of v0.9.3
states and exits
will be less than v0.10.0
and the final states are not guaranteed to be
accurate for workflows with multiple branches and leaf nodes with varying exit
reasons.
The migration scripts can be run with a single function call in SetupUtils from
a connect iex
session:
Lightning.SetupUtils.approximate_state_for_attempts_and_workorders()
Note that (like lots of other functionality in SetupUtils
, calling this
function is a destructive action and you should only do it if you've backed up
your data and you know what you're doing.)
As always, we recommend backing up your data before migrating. (And thanks for bearing with us as we move towards our first stable Lightning release.)
- Fix flaky job name input behavior on error #1218
- Added a hover effect on copy and add button for adaptors examples #1297
- Migration helper code to move from
v0.9.3
tov0.10.0
added to SetupUtils #1363 - Option to start with
RTM=false iex -S mix phx.server
for opting out of the dev-mode automatic runtime manager. - Webhook Authentication Methods database and CRUD operations #1152
- Creation and Edit of webhook webhook authentication methods UI #1149
- Add webhook authentication methods overview methods in the canvas #1153
- Add icon on the canvas for triggers that have authentication enabled #1157
- Require password/2FA code before showing password and API Key for webhook auth methods #1200
- Restrict live dashboard access to only superusers, enable DB information and OS information #1170 OS information #1170
- Expose additional metrics to LiveDashboard #1171
- Add plumbing to dump Lightning metrics during load testing #1178
- Allow for heavier payloads during load testing #1179
- Add dynamic delay to help mitigate flickering test #1195
- Add a OpenTelemetry trace example #1189
- Add plumbing to support the use of PromEx #1199
- Add warning text to PromEx config #1222
- Track and filter on webhook controller state in :telemetry metrics #1192
- Secure PromEx metrics endpoint by default #1223
- Partition
log_lines
table based onattempt_id
#1254 - Remove foreign key from
attempts
in preparation for partitioningwork_orders
#1254 - Remove
Workflows.delete_workflow
. It is no longer in use and would require modification to not leave orphaned attempts given the removal of the foreign key fromattempts
. #1254 - Show tooltip for cloned runs in history page #1327
- Have user create workflow name before moving to the canvas #1103
- Allow PromEx authorization to be disabled #1483
- Updated vulnerable JS libraries,
postcss
andsemver
#1176 - Update "Delete" to "Delete Job" on Job panel and include javascript deletion confirmation #1105
- Move "Enabled" property from "Jobs" to "Edges" #895
- Incorrect wording on the "Delete" tooltip #1313
- Fixed janitor lost query calculation #1400
- Adaptor icons load gracefully #1140
- Selected dataclip gets lost when starting a manual work order from the inspector interface #1283
- Ensure that the whole edge when selected is highlighted #1160
- Fix "Reconfigure Github" button in Project Settings #1386
- Make janitor also clean up runs inside an attempt #1348
- Modify CompleteRun to return error changeset when run not found #1393
- Drop invocation reasons from DB #1412
- Fix inconsistency in ordering of child nodes in the workflow diagram #1406
- Add ellipsis when adaptor name is longer than the container allows #1095
- Webhook Authentication Methods database and CRUD operations #1152
- Prevent deletion of first job of a workflow #1097
- Fix long name on workflow cards #1102
- Fix highlighted Edge can get out of sync with selected Edge #1099
- Creating a new user without a password fails and there is no user feedback #731
- Crash when setting up version control #1112
- Add "esc" key binding to close job inspector modal #1069
- Save icons from the
adaptors
repo locally and load them in the job editor #943
- Modified audit trail to handle lots of different kind of audit events #271/#44
- Fix randomly unresponsive job panel after job deletion #1113
- Add favicons #1079
- Validate job name in placeholder job node #1021
- Bring credential delete in line with new GDPR interpretation #802
- Make job names unique per workflow #1053
- Enhanced the job editor/inspector interface #1025
- Finished run never appears in inspector when it fails #1084
- Cannot delete some credentials via web UI #1072
- Stopped the History table from jumping when re-running a job #1100
- Fixed the "+" button when adding a job to a workflow #1093
- Render error when workflow diagram node is invalid #956
- Output incorrectly shows "this run failed" when the run hasn't yet finished #1048
- Wrong label for workflow card timestamp #1022
- Lack of differentiation between top of job editor modal and top menu was disorienting. Added shadow.
- Moved Save and Run button to bottom of the Job edit modal #1026
- Allow a manual work order to save the workflow before creating the work order #959
- Introduces Github sync feature, users can now setup our github app on their instance and sync projects using our latest portability spec #970
- Support Backup Codes for Multi-Factor Authentication 937
- Log a warning in the console when the Editor/docs component is given latest #958
- Improve feedback when a Workflow name is invalid #961
- Show that the jobs' body is invalid #957
- Reimplement skipped CredentialLive tests #962
- Reimplement skipped WorkflowLive.IndexTest test #964
- Show GitHub installation ID and repo link to help setup/debugging for version control 1059
- Fixed issue where job names were being incorrectly hyphenated during project.yaml export #1050
- Allows the demo script to set a project id during creation to help with cli deploy/pull/Github integration testing.
- Fixed demo project_repo_connection failing after nightly demo resets 1058
- Fixed an issue where the monaco suggestion tooltip was offset from the main editor 1030
- Version control in project settings is now named Export your project #1015
- Tooltip for credential select in Job Edit form is cut off #972
- Dataclip type and state assembly notice for creating new dataclip dropped during refactor #975
- NodeJs security patch 1009
- Fixed flickery icons on new workflow job creation.
- Project owners can require MFA for their users 892
- Moved to Elixir 1.15 and Erlang 26.0.2 to sort our an annoying ElixirLS issue that was slowing down our engineers.
- Update Debian base to use bookworm (Debian 12) for our Docker images
- Change new credential modal to take up less space on the screen #931
- Placeholder nodes are now purely handled client-side
- Fix issue creating a new credential from the Job editor where the new credential was not being set on the job. #951
- Fix issue where checking a credential type radio button shows as unchecked on first click. #976
- Return the pre-filled workflow names #971
- Fix version reporting and external reset_demo() call via Application.spec()#1010
- Fixed issue where entering a placeholder name through the form would result an in unsaveable workflow #1001
- Ensure the DownloadController checks for authentication and authorisation.
- Unless otherwise specified, only show work orders with activity in last 14 days #968
- Don't add cast fragments if the search_term is nil #968
- Fixed an issue with newly created edges that prevented downstream jobs 977
Note that this is a pre-release with a couple of known bugs that are tracked in the Nodes and Edges epic.
- Added ability for a user to enable MFA on their account; using 2FA apps like Authy, Google Authenticator etc #890
- Write/run sql script to convert triggers #875
- Export projects as
.yaml
via UI #249
- In
v0.7.0
we change the underlying workflow building and execution infrastructure to align with a standard "nodes and edges" design for directed acyclic graphs (DAGs). Make sure to run the migrations! 793
- Propagate url pushState/changes to Workflow Diagram selection #944
- Fix issue when deleting nodes from the workflow editor #830
- Fix issue when clicking a trigger on a new/unsaved workflow #954
- Add feature to bulk rerun work orders from a specific step in their workflow; e.g., "rerun these 50 work orders, starting each at step 4." #906
- Oban exception: "value too long" when log lines are longer than 255 chars #929
- Add public API token to the demo site setup script
- Check and renew OAuth credentials when running a job #646
- Remove google sheets from adaptors list until supporting oauth flow #792
- Remove duplicate google sheets adaptor display on credential type picklist #663
- Fix demo setup script for calling from outside the app on Kubernetes deployments #917
- Ability to rerun work orders from start by selecting one of more of them from the History page and clicking the "Rerun" button. #659
- Example runs for demo incorrect #856
- Prevent saving null log lines to the database, fix issue with run display #866
-
Fixed viewer permissions for delete workflow
-
Fixed bug with workflow cards #859
-
Fixed bug with run logs #864
-
Correctly stagger demo runs to maintain order #856
-
Remove
Timex
use fromSetupUtils
in favor ofDateTime
to fix issue when calling it in escript.
- Create sample runs when generating sample workflow #821
- Added a provisioning api for creating and updating projects and their workflows See: PROVISIONING.md #641
- Add ability for a
superuser
to schedule deletion, cancel deletion, and delete projects #757 - Add ability for a
project owner
to schedule deletion, cancel deletion, and delete projects #746
- Ability to store run log lines as rows in a separate table #514
- Incorrect project digest queries #768]
- Fix issue when purging deleted users #747
- Generate a random name for Workflows when creating one via the UI. #828
- Handle error when deleting a job with runs. #814
- Add
workflow_edges
table in preparation for new workflow editor implementation #794 - Stamped
credential_id
on run directly for easier auditing of the history interface. Admins can now see which credential was used to run a run. #800 - Better errors when using magic functions: "no magic yet" and "check credential" #812
- The
delete-project
function now delete all associated activities #759
- Added ability to create and revoke personal API tokens #147
- Add
last-used at
to API tokens #722 - Improved "save" for job builder; users can now press
Ctrl + S
or⌘ + S
to save new or updated jobs job panel will not close. (Click elsewhere in the canvas or click the "Close" button to close.) #568 - Add filtered search params to the history page URL #660
- The secret scrubber now ignores booleans 690
- The secret scrubber now properly handles integer secrets from credentials 690
- Updated describe-package dependency, fixing sparkles in adaptor-docs 657
- Clicks on the workflow canvas were not lining up with the nodes users clicked on; they are now 733
- Job panel behaves better when collapsed 774
- Magic functions that fetch real metadata from connected systems via
credentials
and suggest completions in the job builder (e.g., pressingcontrol-space
when setting theorgUnit
attribute for a DHIS2 create operation will pull the actual list of orgUnits with human readable labels and fill in their orgUnit codes upon enter.)670 - A "metadata explorer" to browse actual system metadata for connected instances. 658
- Resizable job builder panel for the main canvas/workflow view. 681
- Display timezone for cron schedule—it is always UTC. #716
- Instance administrators can now configure the interval between when a project
owner or user requests deletion and when these records are purged from the
database. It defaults to 7, but by providing a
PURGE_DELETED_AFTER_DAYS
environment variable the grace period can be altered. Note that setting this variable to0
will make automatic purging never occur but will still make "deleted" projects and users unavailable. This has been requested by certain organizations that must retain audit logs in a Lightning instance. 758
- Locked CLI version to
@openfn/[email protected]
. #761
- Added a test harness for monitoring critical parts of the app using Telemetry #654
- Set log level to
info
for runs. Most of thedebug
logging is useful for the CLI, but not for Lightning. In the future the log level will be configurable at instance > project > job level by thesuperuser
and any projectadmin
. - Renamed license file so that automagic github icon is less confusing
- Broken links in failure alert email #732
- Registration Submission on app.openfn.org shows internal server error in browser #686
- Run the correct runtime install mix task in
Dockerfile-dev
#541 - Users not disabled when scheduled for deletion #719
- Implement roles and permissions across entire app #645
- Fix webhook URL
(
https://<<HOST_URL>>/i/cae544ab-03dc-4ccc-a09c-fb4edb255d7a
) for the OpenHIE demo workflow 448 - Phoenix Storybook for improved component development
- Load test for webhook endpoint performance #645
- Notify user via email when they're added to a project #306
- Added notify user via email when their account is created #307
- Improved errors when decoding encryption keys for use with Cloak. #684
- Allow users to run ANY job with a custom input. #629
- Ensure JSON schema form inputs are in the same order as they are written in the schema #685
- Tooltips on Job Builder panel #650
- Upgraded to Phoenix 1.7 (3945856)
- Issue with FailureAlerter configuration missing in
prod
mode.
- A user can change their own email #247
- Added a
SCHEMAS_PATH
environment variable to override the default folder location for credential schemas #604 - Added the ability to configure Google Sheets credentials #536
- Function to import a project #574
- Users cannot register if they have not selected the terms and conditions #531
- Jobs panel slow for first open after restart #567
- Added a Delete job button in Inspector
- Filter workflow runs by text/value in run logs or input body
- Drop "configuration" key from Run output dataclips after completion
- Ability to 'rerun' a run from the Run list
- Attempts and Runs update themselves in the Runs list
- Configure a project and workflow for a new registering user
- Run a job with a custom input
- Added plausible analytics
- Allow user to click on Webhook Trigger Node to copy webhook URL on workflow diagram
- Allow any user to delete a credential that they own
- Create any credential through a form except for OAuth
- Refit all diagram nodes on browser and container resize
- Enable distributed Erlang, allowing any number of redundant Lightning nodes to communicate with each other.
- Users can set up realtime alerts for a project
- Better code-assist and intelliense in the Job Editor
- Updated @openfn/workflow-diagram to 0.4.0
- Make plus button part of job nodes in Workflow Diagram
- Updated @openfn/adaptor-docs to 0.0.5
- Updated @openfn/describe-package to 0.0.10
- Create an follow a manual Run from the Job Inspector
- View all workflows in a project on the workflows index page
- Move @openfn/workflow-diagram into the application, the NPM module is now deprecated.
- Remove workflow name from first node
- Move the used parts of
@openfn/engine
into the application. - [BREAKING CHANGE] Ported
mix openfn.install.runtime
into application, usemix lightning.install_runtime
. - [BREAKING CHANGE] Introduced
@openfn/cli
as the new runtime for Jobs - Rename a workflow through the page heading
- Hide the dataclips tab for beta
- Make adaptor default to common@latest
- Remove jobs list page
- Better error handling in the docs panel
- Disable credential ownership transfer in dev and prod environments
- Add project settings page
- Change Work Order filters to apply to the aggregate state of the work order and not the run directly
- Enable jobs by default
- Set log level to info
- Add Beta checkbox to register page
- User roles and permissions
- Don't consider disabled jobs when calculating subsequent runs
- Fixed overflow on Job Editor Tooltips
- Fixed auto-scroll when adding a new snippet in the Job Editor
- Fixed common operation typings in Job Editor
- Fixed bug that tried to execute HTML scripts in dataclips
- Fixed bug that prevented work orders from displaying in the order of their last run, descending.
- Remove alerts after set timeout or close
- Add seed data for demo site
- Create adaptor credentials through a form
- Configure cron expressions through a form
- View runs grouped by work orders and attempts
- Run an existing Job with any dataclip uuid from the Job form
- Redirect users to projects list page when they click on Admin Settings menu
- Move job, project, input and output Dataclips to Run table
- Reverse the relationship between Jobs and Triggers. Triggers now can exist on their own; setting the stage for branching and merging workflows
- Updated Elixir and frontend dependencies
- [BREAKING CHANGE] Pipeline now uses Work Orders, previous data is not compatible.
- Runs, Dataclips and Attempts now all correctly use
usec
resolution timestamps. - Upgraded LiveView to 0.18.0
- Upgraded Elixir to 1.14.1 and OTP 25
- Workflow Job editor now behaves like a panel
- Split JobLive.InspectorFormComponent into different plug-able subcomponents
- Ensure new jobs with cron triggers receive a default frequency
- Webhooks are now referenced by the trigger id instead of job id.
- Filter runs by status
- Filter runs by workflow
- Filter runs by date
- View a job run from the runs history
- View latest matching inputs to run a job with
- [BREAKING CHANGE] Add
Workflow
model, Jobs now belong to a Workflow This is a breaking change to the schema. - Use Node.js 18, soon to be in LTS.
- Visualize success/fail triggers in workflow diagram.
- Move WorkflowDiagram related actions from DashboardLive into WorkflowLive
- Move WorkflowDiagram component into liveview, so that we can subscribe to channels (i.e. updating of the diagram when someone changes something).
- Integrate
@openfn/[email protected]
and use the new Store interface for updating it. - Remove
component_mounted
event from WorkflowDiagram hook, using a MutationObserver and a Base64 encoded JSON payload. - Fixed an issue where the compiler component would try and load a 'nothing adaptor', added a condition to check an adaptor is actually selected.
- Removed previous Workflow CTE queries, replaced by the introduction of the Workflow model, see (https://github.com/OpenFn/Lightning/blob/53da6883483e7d8d078783f348da327d1dd72d20/lib/lightning/workflows.ex#L111-L119).
- Allow administrators to configure OIDC providers for authentication (note that this is just for authenticating, not yet for creating new accounts via OIDC)
- Add Monaco editor to the step/job panel
- Allow users to delete their own accounts. Schedule their user and credentials data for deletion when they do.
- Allow superusers to delete a user account. Schedule the user's credentials and user data for deletion when they do.
- If a user is scheduled for deletion, disable their account and prevent them from logging in.
- The 'User profile' and 'Credentials' page now have a sidebar menu
- Project users now have one of the following roles: viewer, editor, admin, owner
- Users only have the following roles: user, superuser
- Transfer credential ownership to another user.
- Create credentials via a form interface*
- Show "projects with access" in credentials list view.
- Show job in runs list and run view.
- Added roles and permissions to workflows and history page #645
*The form is defined by a JSON schema provided by an adaptor, in most cases:
e.g., language-dhis2
provides a single schema which defines the required
attributes for state.configuration
, while language-common
provides multiple
credential schemas like "oauth" or "basic auth" which define attributes for
state.configuration
and which might be used by lots of different jobs.)
- User menu (top right) appears on top of all other components.
- User profile screen integrated with the rest of the liveview app.
- Fixed logging in Runner when
:debug
log level used; note that this caused crashes in Oban
- Credential auditing
- Build/version information display for easier debugging
- Fixed a bug that enqueued cron-triggered jobs even when they were disabled
- Navigate to user profile or credentials page and log out through the user icon dropdown
- Create and edit dataclips
- Add a production tag to credentials
- View a dropdown of operations and their description for the language-common
v2.0.0-rc2
adaptor (this pattern to be rolled out across adaptors)
- Navigate between projects through a project picker on the navbar
- Run Lightning with docker
- Sensitive credential values are scrubbed from run logs
- All credentials are encrypted at REST
- Run a job with a cron trigger
- Queue jobs via Oban/Postgres
- Edit jobs via the workflow canvas
-
Register, log in and log out of an account
-
Allow superusers and admin users to create projects
-
Allow admin users to create or disable a user’s account
-
Allow superusers for local deployments to create users and give them access to project spaces
-
Create and edit a job with a webhook, flow/fail or cron trigger
-
Create and edit credentials for a job
-
Copy a job's webhook URL
-
View all workflows in a project visually
-
Deploy lightning locally with Docker
-
Enable a job to automatically process incoming requests
-
Run a job with a webhook or flow/fail trigger
-
View job runs along with their logs, exit code, start and end time
-
View data clips that have initiated job runs (http requests for webhooks, run results)