jasquat 6f0e59409c
Feature/update extension docs (#1028)
* updated the docs around extensions and updated extensions interfaces in the frontend w/ burnettk

* allow specifying files in component args for extensions and added some support for CustomForm from extensions w/ burnettk

* added comments to the extension interfaces file to better describe how to create them

* finished adding comments to extension interfaces

* added comments at top and some minor tweaks

* some fixes for extensions w/ burnettk

* some fixes for extensions w/ burnettk

* ignore eslint issues for now w/ burnettk

* removed deprecated extension items w/ burnettk

---------

Co-authored-by: jasquat <jasquat@users.noreply.github.com>
2024-02-13 16:48:13 -05:00

3.8 KiB

Extensions

Extensions in SpiffArena provide a mechanism to augment the software with custom features and functionality. By leveraging extensions, users can implement functions or features not present in the standard offering. This powerful feature ensures adaptability to various business needs, from custom reports to specific user tools.

Here are some of key aspects of using Extensions:

  • Extensions are implemented within the process model repository.
  • Once an extension is created, it can be made accessible via various ui elements which can be specified in its extension-uischema.json file.
  • Access to an extension can be set up via permissions.
  • Configuration for an extensions can be found and modified in its extension-uischema.json file.

Extensions

Getting Started with Extensions

Environment Variable Activation

To utilize extensions, an environment variable must be set. This variable activates the extensions feature in the SpiffWorkflow backend. Here is the enviromental variable:

SPIFFWORKFLOW_BACKEND_EXTENSIONS_API_ENABLED=true

By default, SpiffArena will look for extensions in [SPIFFWORKFLOW_BACKEND_BPMN_SPEC_ABSOLUTE_DIR]/extensions but that can be configured using SPIFFWORKFLOW_BACKEND_EXTENSIONS_PROCESS_MODEL_PREFIX.

Creating an Extension

After enabling extensions from the backend, you can create extensions in the SpiffArena frontend. To create your own custom extension, follow these steps:

  • Navigate to the process group repository where extensions are to be implemented.

Extension Process Group

  • Create a process model in this group. You can give it whatever name you want. Then create a file inside the process model called extension-uischema.json. This will control how the extension will work.

Extension

As an example, we have created an extension that adds a link to the profile menu in the top right, and also adds a new "Support" page to the app so that users of the application know who to talk to if they have issues. You can find the full example in github.

Notice how the display_location "user_profile_item" tells it that the link belongs in the user profile menu (this is the top right menu where the logout link can be found). Notice also that the extension uischema defines a page ("/support"), and defines the list of components that should show up on this page. In this case, that is just a single MarkdownRenderer, which defines how to contact people.

An entirely new feature application feature with frontend and backend components can be implemented using an extension. This typescript interface file codifies the configuration of the extension uischema.

Use Cases

If your organization has specific needs not catered to by the standard SpiffArena features, you can use extensions to add those features.

Here are some of the use cases already implemented by our users:

  • Implementing a time tracking system.
  • Creating custom reports tailored to your business metrics.
  • Incorporating arbitrary content into custom pages using markdown.
  • Creating and accessing tailor-made APIs.
  • Rendering the output of these APIs using jinja templates and markdown.

Extensions in SpiffArena offer a robust mechanism to tailor the software to unique business requirements. When considering an extension, also consider whether the code would be more properly included in the core source code. In the cases where an extension is appropriate, by following the instructions in this guide, organizations can expand the system's functionality to meet their unique needs.