Skip to content

Workspaces

Definitions

A workspace is a project that :

  • Enables various Automations inside your IT organization, between your APIs, ...
  • Is easily configurable through workspace config, Apps and automations graph
  • Produces events recording what's happening and optionally triggering Automations
  • Present computed data / events through Web Pages accessible to admins or event external end users
  • Has configurable roles providing distinct user groups with fine grained permissions

Config

For now, workspace config is only configurable from source code :

name: MyConfiguredWorkspace
slug: test
config:
  value:
    API_URL: https://api.mycompany.com
    LOGIN_URL: "{{config.API_URL}}/login"
    headers:
      apiKey: someAPIKey

The config.value field defined at the top of this workspace is exposed as a config variable inside your automations.
This config variable is also avaible in the workspace config itself, as well as in installed apps config.

Sensitive config values like credentials can be injected with secret variables : {{secret.yourExternalSecret}}.
See Secrets.

Finally, sensitive config values can also be passed from environment variables built using the target workspace slug, for example :

WORKSPACE_CONFIG_test_API_URL=https://api.mycompany.com
This will set the same config.API_URL variable as in above example. Workspace config takes precedence over environment variables.

More details on variables usage.

The config object accepts an additional field specific to apps : config.schema

Secrets

Workspaces can have a list of secrets provided either from UI or API. API usage will allow you to pull some externals secret manager in a CI pipeline to feed workspaces' secrets with /workspaces/:workspaceId/security/secrets API (See documentation).

By default (unless permitted through custom roles), only owner can access workspace secrets.

These secrets can be used with secret variable in these 2 places exclusively :

Workspace config :

config:
  value:
    headers:
      apiKey: '{{secret.apiKey}}'

Workspace repositories :

repositories:
  github:
    name: My Own Github
    type: git
    mode: read-write
    config:
      url: https://github.com/YourUser/your-repository.git
      branch: main
      auth:
        user: 'your git user'
        password: '{{secret.gitPassword}}'

Events

Each workspace has a continuous and real-time stream of events describing what's happening at any time.
Events can be native or custom :

  • Native events are automatically generated by the platform throughout the workspace's lifetime : Updates, input webhooks, errors, automation executions, ...
  • Custom events (or application events) are emitted either by your own automations or the apps you installed

Workspaces can emit custom events in order to simply record that something special happened or to trigger some other automations which will be executed in parallel.
Workspaces can listen to some native events and every custom events in order to execute any desired workflow inside theirs automations.

Events are stored up to 3 years after their creation and can ben viewed / searched at anytime from the Activity view of the workspace.
However, events from workspaces inactive for longer than 15 days and with less than 100 events are regularly deleted.
Events from deleted workspaces are kept for up to 6 months after the deletion.

Activity View - Watch Video

Every event includes a source field with many useful information including the following ones :

  • source.userId : Authenticated user id, only set for user emitted events and runtime.automations.executed events emitted while processing some user event
  • source.sessionId : Authenticated user session id, shared by all events emitted in relation with the user session
  • source.correlatonId : Unique id shared by every events emitted in relation with the same initial trigger
  • source.automationSlug : Automation slug from which this event has been emitted
  • source.appInstanceFullSlug : If any, source app instance full slug
  • source.http : Source http request details, if any

For security reason, events emitted from a nested app (i.e an app installed within an app installed in your workspace) will not be visible to the root workspace events feed.

Custom domains

You can attach a custom domain name to your workspace to be able to display your pages under your own host. You'll need to complete this steps:

  1. Add a CNAME entry to your domain name with value pages.prisme.ai.. If you want to use a root domain, you can use an ALIAS instead.
  2. Set the domain in your Workspace by adding it in customDomains value. Ex:
    customDomains:
      - www.acme.fr
    
  3. Contact us for Entreprise version