Karify API (v2)

Download OpenAPI specification:

Karify support: support@karify.com

Karify offers two methods for integrations.

  1. Data can be sent and received via the Karify API.
  2. An application can integrate on Karify's Single Sign-On (SSO) to make using Karify more easy for users.

The Karify API is an interface allowing developers to build applications that access the Karify dataset.

Access

Generally speaking, a Karify API application only has access to a user's data after the user has authorized the application to use it.

Registering your application and thereby receiving credentials can be requested only by contacting Karify. These credentials allows you to negotiate tokens on behalf of Karify users. All calls to the Karify API require a token defining the user and application making the call.

See the Authentication section for more information about generating access tokens and the OAuth authorization flow.

Treat tokens with care. Never share tokens with other users or applications. Do not publish tokens in public code repositories.

Requests and responses

Request

HTTP headers All API operations use JSON as the data format. To make a request with a JSON body, use the following header in the request:

Content-Type: application/json

If an operation returns JSON data, also add the Accept header to your request. Also, since the only available version is v2, the version should be added to this header:

Accept: application/json; version=v2

Response codes

API calls indicate the result (success or error) using the corresponding HTTP status codes. See RFC7231 section 6.1 for a list of HTTP status codes.

The response body may have additional error information in the JSON object, for example:

(404 NOT FOUND):

{
  "error_code":"ACCOUNT_NOT_FOUND"
}

Or, when adding information to Karify, the data in the body of the POST or PUT/PATCH request can be unprocessable. Then the following exception will be returned (422 UNPROCESSABLE ENTITY):

{
  "error_code":"VALIDATION_ERROR",
  "details":
  [
    {
      "property_path":
      "emailAddress",
      "message": "This value is not a valid email address.",
      "error_code": "INVALID_EMAIL_FORMAT"
    }
  ]
}

To keep Karify API backwards compatible, some endpoints also return the fields code and message in the exception response. These fields will be deprecated so applications should not create a dependency on it.

In addition to the common error codes, the Karify API can also return the following error codes:

HTTP status code error_code Description
403 MULTI_FACTOR_AUTHENTICATION_NOT_SET_UP Multi-factor authentication is mandatory for the user of the access_token but not set up

Response data

Note that responses may contain user-generated data, which is not escaped or sanitized unless otherwise noted. It could therefore also contain HTML and/or Javascript. You should make sure that this data is sanitized or escaped before rendering, to avoid executing potentially malicious code.

Paginating results

By default, GET operations, which return a list of requested items, return only the first 10 items. To get a different set of items, you can use the offset and limit parameters in the query string of the GET request.

For example, the .../spaces (GET) operation returns:

URL Description
.../spaces Returns the first 10 spaces (the default limit is 10).
.../spaces?limit=5 Returns the first 5 spaces.
.../spaces?offset=3&limit=5 Returns spaces 4..9.
.../spaces?offset=3 Returns spaces 3..13 (the default number of the returned spaces is 10).

To page through all the available items, first, use the collection metadata section of the JSON response to get the total number of items.

{
  "collection":
    [
      ...
    ],
  "offset": 0,
  "limit": 10,
  "total_count": 39
}

Tip: You can request .../spaces?limit=0 to get just metadata, without defect data.

Then send subsequent requests with increasing offsets and a fixed limit until you get all the data.

.../spaces?offset=10&limit=10
.../spaces?offset=20&limit=10
.../spaces?offset=30&limit=10

Change strategy

Karify will take effort to making all changes to the Karify API backwards compatible. However, when a breaking change has to be made within a version of the Karify API, we will take care of phasing out the old variant. This means:

  • We will mark a functionality as deprecated in the documentation,
  • Communicate this deprecation to our clients with clear deprecation plan.
  • As communicated in the deprecation plan, we will remove deprecated functions only after the mentioned time window. When possible, we will monitor the usage of deprecated functions to make sure no breaking changes occur client side.

Beta

Some API endpoints are currently marked as beta. This means backwards incompatible changes might be made without any deprecation plan or notification upfront.

Karify API best practices

  • Properties can be added to the JSON responses within the same API version, so make sure your application can handle these additional properties.
  • Do not use more data than necessary so server load and your application's response time is as low as possible. Also, by using only what is needed, backward compatibility issues will less likely to happen.
  • E.g., be cautious with the use of a high limit parameter when paginating responses.
  • Do not create unnecessary dependencies on fields that your application does not need.
  • Make sure you always set the accept header.
  • Make sure you do not parse the response body of responses with a 204 HTTP status code since those responses never contain a body.
  • Make sure your application can handle error responses and validation responses well. Logging error responses will help you in finding the actual problem. Also make sure that a client side error (4XX status code) won't block other processes of your application without reason.
  • Received access tokens can be invalidated by users in their Karify account settings. Make sure your application handles an invalidated access and refresh token well. Any API endpoint will respond with a 401 Unauthorized response code when an access_token has been invalidated by the user, while refreshing the access_token will result in a 400 Bad Request response code in this situation.

Authorization

The grant type which will be used to authenticate as a Karify user and therefore being able to view or change data on behalf of that user is the authorization_code grant type. Also see RFC6749.

Authorization consists of two (or three if token is expired) steps before the step of getting, putting or posting content via the API is possible:

  • Requesting an (authorization) code
  • Exchange (authorization) code for an access_token
  • Refresh expired access_token using an refresh_token
  • GET, PUT or POST content (Protected Resource) using access_token

Once having a valid access_token it can be used to do requests to Karify API endpoints. Note that access tokens have a lifetime of one hour. Once expired, a 401 Unauthorized will be returned. The response message can be The access token provided has expired. or The access token provided is invalid. since Karify cleans up expired refresh tokens on a regular basis.

See the described steps in the schema below:

Single Sign-On via OAuth

Karify has the possibility to start up a Karify session for a user using an OAuth access_token. This makes it possible to set up a Single Sign-On functionality after a user explicitly granted this for your application.

Karify's Single Sign On (SSO) makes easy access for the end-user from an external application to Karify possible (e.g. EPD, HIS or KIS). When an end-user is logged in at a trusted external application, the end-user can be directly redirected to Karify without having to log in again.

Single Sign-On via SAML

Karify makes use of Security Assertion Markup Language 2.0 (SAML) to make SSO possible. SAML is a common standard within healthcare. It is an XML-based, open-standard data format for exchanging authentication and authorization data between applications. Specifically, between an identity provider (IdP) and a service provider (SP). Karify acts as the service provider (SP). Identifying a user with Karify is done based on the email address provided in the SAML response message.

This functionality provides sufficient opportunity for an application to achieve a basic integration with Karify. A more comprehensive integration is possible by using a RelayState, which redirects the end user to a specific page in Karify. For example, to a client's record (see also the section Redirecting to a client's page below.

SAML usage scenarios

Karify supports two types of usage scenarios of the SAML protocol:

  • IdP-initiated Single Sign-On POST Binding
  • SP-initiated Single Sign-On POST/Artifact Bindings

IDP-initiated Single Sign-On

In this scenario the user is able to be redirected directly from an application (IdP) to Karify (SP). A typical example is providing a 'Go to Karify' button in the application, or when utilizing RelayState, a 'Go to client X's dossier in Karify' button.

The following is a typical scenario:

  1. The user browses to the external application known as the IdP. The application prompts the user for credentials.
  2. The user logs in to the external application.
  3. The user clicks on the 'Go to Karify' button. This causes the IdP's Single Sign-On Service to be called.
  4. The Single Sign-On Service builds a SAML assertion representing the user's logon security context. The assertion is digitally signed before it is placed within a SAML Response message.
  5. The browser issues an HTTP POST request to send the form to the Karify's Assertion Consumer Service (https://saml.karify.com/acs, found in Karify's metadata file).
  6. Karify validates the message and checks whether the user exists and has the correct authorization to access the resource.

If the access check passes, the resource is then returned to the browser. In other words: the user is logged in.

SP-initiated Single Sign-On

In this scenario an SP-initiated SSO exchange is described. In such an exchange, the external application sends the user to a specific page on Karify (e.g. https://saml.karify.com/identity-provider-x). Again, a typical example is a 'Go to Karify' button. Since the user does not have a current logon session for Karify, the user is sent to the IdP to log on and the IdP provides a SAML web SSO assertion for the user's federated identity back to Karify, the SP.

For additional information, see the official documentation on this scenario at http://saml.xml.org/wiki/sp-initiated-single-sign-on-postartifact-bindings.

The following is a typical scenario:

  1. The user browses to the external application, known as the IdP. The application prompts the user for credentials.
  2. The user logs in to the external application.
  3. The user clicks on the 'Go to Karify' button. The external application sends the user to a specific page on Karify (e.g. https://saml.karify.com/identity-provider-x).
  4. Karify will start up a SAML request by redirecting the user with sending an AuthRequest to the IdP using HTTP-POST binding.
  5. The Single Sign-On Service of the IdP builds a SAML assertion representing the user's logon security context. The assertion is digitally signed before it is placed within a SAML Response message.
  6. The browser issues an HTTP POST request to send the form to Karify's Assertion Consumer Service (https://saml.karify.com/acs, found in Karify's metadata file).
  7. Karify validates the message and checks whether the user exists and has the correct authorization to access the resource. If the access check passes, the resource is then returned to the browser. In other words: the user is logged in.

Redirecting to a Client's Page

Karify provides an option to redirect users to a specific client's page using the client's identification number, when the current user has a connection with that client. The required URL format is:

https://my.karify.com/client-by-identification-number/{identification-number}

For example, if the client's identification number is 1234abc, the URL would be:

https://my.karify.com/client-by-identification-number/1234abc

When the current account has a connection in one Healthspace, they are immediately redirected to the client's page in that Healthspace. Otherwise a screen is shown with the different Healthspaces (in case of a connection in multiple Healthspaces) or a "not found" message.

Using RelayState with SP-Initiated Single Sign-On

When combining this redirection with SP-initiated Single Sign-On, the RelayState parameter should contain the URL-encoded client page URL. The URL that the user is redirected to in step 3 of the above flow would look like this (mind the identity-provider-x part that should be replaced by the relevant identity provider for your organization):

https://saml.karify.com/authn/identity-provider-x?RelayState=https%3A%2F%2Fmy.karify.com%2Fclient-by-identification-number%2F1234abc

This ensures that after authentication, the user is redirected directly to the client's page in Karify.

account

Each Karify user has an account, even if a user does not have any membership (profile) for a Healthspace, he or she can still have an account.

Each account endpoint needs its own scope and role permissions. An application can use the scope MANAGE_ORGANIZATION_ACCOUNTS to use all (..._READ) scopes in one scope.

Returns the currently authenticated account

Get information of the account of the authenticated user.

Scope The access_token should have the scope ACCOUNT_READ for this endpoint.

Role
No specific role is needed for the authenticated user using this endpoint.

Authorizations:
oauth2

Responses

Response samples

Content type
application/json
Example
{
  • "id": "e5d54898fe3d",
  • "first_name": "Henk",
  • "surname_prefix": "van der",
  • "surname": "Molen",
  • "email": "henk@example.com",
  • "email_address_confirmed": true,
  • "terms_of_use_accepted": true,
  • "birthday": "2002-01-21",
  • "image": {},
  • "user_type": "staff",
  • "organization": {
    },
  • "profiles": [],
  • "permissions": [ ],
  • "created_at": "2013-02-09T07:00:00+01:00",
  • "updated_at": "2021-01-13T09:04:43+01:00"
}

Update Account Details

beta

Authorizations:
oauth2
Request Body schema: application/json
required

The request body should contain an Account Object

non-empty
first_name
string <= 255 characters
surname_prefix
string <= 255 characters
surname
string <= 255 characters
terms_of_use_accepted
boolean
birthday
string <date>
phone_number
string or null
Value: null

By setting Phone Number to null, the phone number can be removed from the database. Updates to the phone number value must be done via the 'challenge' endpoint

preferred_locale
string
Enum: "en" "nl"

Responses

Request samples

Content type
application/json
Example
{
  • "terms_of_use_accepted": true
}

Response samples

Content type
application/json
Example
{
  • "id": "e5d54898fe3d",
  • "first_name": "Henk",
  • "surname_prefix": "van der",
  • "surname": "Molen",
  • "email": "henk@example.com",
  • "email_address_confirmed": true,
  • "terms_of_use_accepted": true,
  • "birthday": "2002-01-21",
  • "image": {},
  • "user_type": "staff",
  • "organization": {
    },
  • "profiles": [],
  • "permissions": [ ],
  • "created_at": "2013-02-09T07:00:00+01:00",
  • "updated_at": "2021-01-13T09:04:43+01:00"
}

Get a collection of all Accounts from all Healthspaces where Space Administrator

beta

Authorizations:
oauth2
query Parameters
spaces[]
Array of strings[ items = 12 characters ]

Space ID(s)

active
boolean

Is Active Account

surname
string [ 1 .. 255 ] characters

User Surname

user_type
string
Enum: "staff" "client"

User Type

string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of Accounts to return (defaults to 10)

string or integer
Examples:
  • offset=10 - Example of an offset value as a string
  • offset=25 - Example of an offset value as an integer

Index of first Account to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [ ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 0
}

Resend Account confirmation email

beta

Authorizations:
oauth2

Responses

Response samples

Content type
application/json
{
  • "error_code": "ACCOUNT_ALREADY_CONFIRMED"
}

Activate an Account

beta

Authorizations:
oauth2
Request Body schema: application/json
required

Request body containing an Activation Code

activation_code
required
string = 32 characters

Responses

Request samples

Content type
application/json
{
  • "activation_code": "a938b948214bb60b1a46ceab2ea8c236"
}

Response samples

Content type
application/json
{
  • "error_code": "INVALID_ACCOUNT_ACTIVATION_CODE"
}

Get accounts of organization

Get all accounts or filter within accounts of the authenticated user's organization based on some optional parameters.

Scope The scope ORGANIZATION_ACCOUNT_READ is needed for this endpoint.

Role The authenticated user should have the role ROLE_ACCOUNT_SPACE_OWNER.

Authorizations:
oauth2
query Parameters
identificationNumber
string
Example: identificationNumber=6b6d3ea100af

Filters the result by identificationNumber

birthday
string
Example: birthday=1970-03-27

Filters the result by birthday (YYYY-MM-DD)

Responses

Response samples

Content type
application/json
{
  • "collection": [
    ],
  • "limit": 10,
  • "offset": 0,
  • "total_count": 1
}

banners

Banners

Dismiss a banner temporarily or permanently (which may or may not be shown again at a later date)

beta

Authorizations:
oauth2
Request Body schema: application/json
required

The request body should contain a dismissed banner ID and an optional dismiss duration (in seconds)

id
required
string [ 1 .. 255 ] characters
dismiss_duration
integer >= 0

Responses

Request samples

Content type
application/json
Example
{
  • "id": "multi-factor-authentication-persuade-banner",
  • "dismiss_duration": 604800
}

Response samples

Content type
application/json
Example
{
  • "id": "multi-factor-authentication-persuade-banner",
  • "dismissed_until": "2021-04-07T14:07:27+01:00"
}

Get dismissed banner resource

beta

Authorizations:
oauth2
path Parameters
id
required
string [ 1 .. 255 ] characters
Examples:
  • multi-factor-authentication-persuade-banner - An example of 'id' value

Banner ID

Responses

Response samples

Content type
application/json
Example
{
  • "id": "multi-factor-authentication-persuade-banner",
  • "dismissed_until": "2021-04-07T14:07:27+01:00"
}

connections

Karify access authorisation works based on connections. Connections between a clinician and a patient allows record access, communications and managing treatments. Connections are made based from profile to profile so are on the level of a Healthspace. Each user in Karify can requests it's own connections, so both users with an account type staff as an account type client.

Get all connections of the current account

This endpoint enables you to obtain the complete set of active connections for the account of the given access_token (the current user). The collection result can be filtered on some optional parameters. Note that some details are only visible when the current user is a staff member.

Scope

The scope CONNECTION_READ is needed for this endpoint.

Role

No specific role is needed for the authenticated user using this endpoint.

Authorizations:
oauth2
query Parameters
search
string
Examples:
  • search=Penny - Example of a search by name
  • search=5678hj63 - Search by identification number

Filter by some combination of first name, surname, and (in the case of a staff member searching for clients) identification number.

account
string = 12 characters
Example: account=2503faf1a145

Filter by account ID

string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of Connections to return (defaults to 10)

string or integer

Index of first Connection to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [
    ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 1
}

Get connections for a given profile

This endpoint enables you to obtain the set of connections for one of your profiles. The collection result can be filtered on some optional parameters. Note that some details are only visible when the current user is a staff member.

Scope

The scope CONNECTION_READ is needed for this endpoint.

Role

No specific role is needed for the authenticated user using this endpoint.

Authorizations:
oauth2
path Parameters
profile
required
string = 12 characters
Example: a8bcb96e629c

The ID of the profile you want to look up connections for

query Parameters
search
string
Examples:
  • search=Penny - Search on account name
  • search=13049837892 - Search on identification number

Filter by some combination of first name and surname or on identification number

string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of Connections to return (defaults to 10)

string or integer

Index of first Connection to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [
    ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 1
}

counters

Counters

Get a counter of all tasks in a given space for the current account

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

Responses

Response samples

Content type
application/json
Example
{
  • "all_task_count": 0
}

current-user-profiles

Each user in Karify can requests their own profiles, so both users with an account type staff as an account type client.

Get profiles

This endpoint enables you to obtain the complete set of profiles for the account of the given access_token (the current user).

Scope

The scope PROFILE_READ is needed for this endpoint.

Role

No specific role is needed for the authenticated user using this endpoint.

Authorizations:
oauth2cookie
query Parameters
string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of Profiles to return (defaults to 10)

string or integer

Index of first Profile to be returned (defaults to 0)

Responses

Response samples

Content type
application/json

A collection with two profiles for a staff member

{
  • "collection": [
    ],
  • "limit": 10,
  • "offset": 0,
  • "total_count": 2
}

Get specific profile

This endpoint enables you to obtain a specific profile of the account of the given access_token (the current user) based on the profile_id you received earlier.

Scope

The scope PROFILE_READ is needed for this endpoint.

Role

No specific role is needed for the authenticated user using this endpoint.

Authorizations:
oauth2cookie
path Parameters
profile
required
string = 12 characters
Example: a8bcb96e629c

The ID of the desired profile

Responses

Response samples

Content type
application/json

Get a single profile for the given id

{
  • "account": {
    },
  • "administrative_data": { },
  • "created_at": "2020-12-08T21:37:06+01:00",
  • "id": "9681f2a7bf0c",
  • "space": {
    },
  • "status": "subscribed",
  • "updated_at": "2020-12-08T21:37:06+01:00",
  • "user_type": "staff"
}

data-exports

Organization owners can generate data exports. A data export consists of several CSV files and a text description of these CSV files, all combined in a zip file. These data exports are generated in an asynchronous process, as the creation can take quite a long time (due to various factors). The workflow is therefore to first create a new data export using the POST /api/v2/data-exports endpoint, then poll the status through the GET /api/v2/data-exports endpoint. Once the status has progressed from queued to processing to finished, the data export will have the download url available, which indicates where the zip file can be downloaded. Finally, a data export can be deleted using the DELETE /api/v2/data-exports/{id} endpoint. Data exports are automatically deleted after 14 days, so deleting manually is not necessary but can keep the overview more organized.

Get all data exports

Get all the current account has requested. Note that the fields of a data export differ per type of export. Note that if a data export has finished processing, it will get the file property which indicates the URL of the zip file.

Authorizations:
oauth2
query Parameters
string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of Connections to return (defaults to 10)

string or integer

Index of first Connection to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [
    ],
  • "limit": 10,
  • "offset": 0,
  • "total_count": 5
}

Create a new data export

Create a new data export. Note that you can only create a data export for spaces you have the Space Administrator role for.

Authorizations:
oauth2
Request Body schema: application/json

The request body should describe the data export that is requested. Different fields are required for different types of data export.

type
required
string
Enum: "client_record_export" "dossier_audit_log_export" "member_connections_export" "member_data_export" "space_activity_export"

The type of data export that is requested. Note that not all types of exports might be enabled for a healthspace.

Array of objects (profile-reference)

An array of Healthspaces which should be included in the data export. This field is required for member_data_export, space_activity_export, member_connections_export, and dossier_audit_log_export

start_date
string <date>

The start date of the time period to get data for. Optional for the space_activity_export and dossier_audit_log_export data export types. If this field is omitted, all data from the very beginning is included.

end_date
string <date>

The end date of the time period to get data for. Optional for the space_activity_export and dossier_audit_log_export data export types. If this field is omitted, all data up to the current day is included.

object

The account for which data should be exported. Required only for data exports of type client_record_export.

Responses

Request samples

Content type
application/json
Example
{
  • "type": "client_record_export",
  • "client_account": {
    }
}

Response samples

Content type
application/json
Example
{
  • "id": "95cc5025d2d3",
  • "type": "client_record_export",
  • "status": "queued",
  • "created_at": "2024-11-18T13:05:23+01:00",
  • "created_by": {
    },
  • "spaces": [
    ],
  • "expires_at": "2024-12-02T13:05:23+01:00",
  • "client_account": {
    }
}

Delete a data export

Authorizations:
oauth2
path Parameters
id
required
string = 12 characters
Examples:
  • 897128edfa05 - An example of an id

Data export ID

Responses

Response samples

Content type
application/json
Example
{
  • "error": "invalid_grant",
  • "error_description": "The access token provided is invalid."
}

Download a data export

Download the data export as a zip file, as linked from the file property in the GET endpoint

Authorizations:
oauth2
path Parameters
id
required
string = 12 characters
Examples:
  • 897128edfa05 - An example of an id

Data export ID

filename
required
string
Examples:
  • 673c99376feed00de904b7d3.zip - An example filename

The data export filename

Responses

Response samples

Content type
application/json
Example
{
  • "error": "invalid_grant",
  • "error_description": "The access token provided is invalid."
}

external-record-items

External record items can be added to the personal health record of a client on behalf of an organisation in Karify. Each external record item endpoint needs its own scope and role permissions. An application can use the scope MANAGE_ORGANIZATION_EXTERNAL_RECORD_ITEMS to use all (..._READ, ..._CREATE and ..._UPDATE) scopes in one scope. We distinguish two types of external record items, based on their contents: HTML external record items, and external record items with a file. These are very similar when retrieved through GET requests. However, the POST and PUT requests differ to such a degree that they are specified for both types separately in this documentation.

Get external record items of account

This endpoint enables you to obtain the complete set of external record items for the specified account.

Scope The scope ORGANIZATION_EXTERNAL_RECORD_ITEM_READ is needed for this endpoint.

Role The authenticated user should have the role ROLE_ACCOUNT_SPACE_OWNER.

Authorizations:
oauth2
path Parameters
account
required
string = 12 characters
Example: a2b75d614ef1

Account ID

query Parameters
string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of external record items to return (defaults to 10)

string or integer
Examples:
  • offset=10 - Example of an offset value as a string
  • offset=25 - Example of an offset value as an integer

Index of first external record item to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
{
  • "collection": [
    ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 3
}

Create an external record item for the specified account

This endpoint enables you to create an external record item with html or file content for the specified account.

Content-Type Different from most other requests, a request to post an external record item with a file requires the Content-Type to be multipart/related. This multipart request should contain two parts: one part containing the data in JSON format, and one part containing the file.

Scope The scope ORGANIZATION_EXTERNAL_RECORD_ITEM_CREATE is needed for this endpoint.

Role The authenticated user should have the role ROLE_ACCOUNT_SPACE_OWNER.

Authorizations:
oauth2
path Parameters
account
required
string = 12 characters
Example: a2b75d614ef1

Account ID

Request Body schema:

The request body should contain the new external record item to create. Note that the content-type depends on whether the external record item should contain HTML content or a file.

external_id
string [ 1 .. 255 ] characters

A self-chosen identifier for the external item, which must be unique per external item. Required when creating a new external record item through POST, not when updating through PUT.

name
required
string [ 1 .. 255 ] characters

Name of item to display to client

type
required
string
Value: "html"

The type of the external record item, in this case 'html'. Note that, when updating an external record item, the types should match.

content
required
string non-empty

Any textual content in html format. Allowed html tags are: a[href|target], abbr, acronym, address, b, blockquote, br, del, em, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, q, s, span[style], strike, strong, sub, sup, table, td, tbody, tfoot, th, thead, tr, ul.

status
required
string
Enum: "is-available-externally" "is-removed-externally"
send_notification
boolean
Default: true

Optional: whether to send a notification when the new external record item is created.

Responses

Request samples

Content type
Example
{
  • "external_id": "372975231",
  • "name": "The name of an item",
  • "type": "html",
  • "content": "<p>This is an example of an external record item with HTML content that is newly created.<p>",
  • "status": "is-available-externally"
}

Response samples

Content type
application/json
Example
{
  • "external_id": "372975231",
  • "name": "The name of an item",
  • "type": "html",
  • "content": "<p>This is an example of an external record item with HTML content that is newly created.<p>",
  • "status": "is-available-externally",
  • "account": {
    },
  • "created_by_account": {
    },
  • "created_at": "2017-03-27T14:29:08+00:00",
  • "updated_at": "2017-03-27T14:29:08+00:00"
}

Get specific external record item of account

This endpoint enables you to obtain one specific external record items for the specified account based on an external_record_item_id.

Scope The scope ORGANIZATION_EXTERNAL_RECORD_ITEM_READ is needed for this endpoint.

Role The authenticated user should have the role ROLE_ACCOUNT_SPACE_OWNER.

Authorizations:
oauth2
path Parameters
account
required
string = 12 characters
Example: a2b75d614ef1

Account ID

externalId
required
string [ 1 .. 255 ] characters
Examples:
  • a2b75d614ef1 - a short ID using hexadecimal characters
  • 218689506768030517684506458537912482794 - A long ID consisting of only numbers

The external ID of the external record item

Responses

Response samples

Content type
application/json
{
  • "external_id": "372975231",
  • "name": "The name of an item",
  • "type": "html",
  • "content": "<p>This is an example of an external record item<p>",
  • "status": "is-available-externally",
  • "account": {
    },
  • "created_by_account": {
    },
  • "created_at": "2017-03-27T14:29:08+00:00",
  • "updated_at": "2017-03-27T14:29:08+00:00"
}

Update an external record item for the specified account. The client will get a new version of the item in their personal health record and can still browse through previous versions.

This endpoint enables you to update a specified external record item for the specified account. The client will get a new version of the item in their personal health record and can still browse through previous versions.

Note that you can only update external record items with external records of the same type, so an external record item with file content can only be updated with external record items with file content.

Content-Type Different from most other requests, a request to update a file requires the Content-Type to be multipart/related. This multipart request should contain two parts: one part containing the data in JSON format, and one part containing the file.

Scope The scope ORGANIZATION_EXTERNAL_RECORD_ITEM_UPDATE is needed for this endpoint.

Role The authenticated user should have the role ROLE_ACCOUNT_SPACE_OWNER.

Authorizations:
oauth2
path Parameters
account
required
string = 12 characters
Example: a2b75d614ef1

Account ID

externalId
required
string [ 1 .. 255 ] characters
Examples:
  • a2b75d614ef1 - a short ID using hexadecimal characters
  • 218689506768030517684506458537912482794 - A long ID consisting of only numbers

The external ID of the external record item

Request Body schema:

The request body should contain the updated contents of the external record item

external_id
string [ 1 .. 255 ] characters

A self-chosen identifier for the external item, which must be unique per external item. Required when creating a new external record item through POST, not when updating through PUT.

name
required
string [ 1 .. 255 ] characters

Name of item to display to client

type
required
string
Value: "html"

The type of the external record item, in this case 'html'. Note that, when updating an external record item, the types should match.

content
required
string non-empty

Any textual content in html format. Allowed html tags are: a[href|target], abbr, acronym, address, b, blockquote, br, del, em, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, q, s, span[style], strike, strong, sub, sup, table, td, tbody, tfoot, th, thead, tr, ul.

status
required
string
Enum: "is-available-externally" "is-removed-externally"
send_notification
boolean
Default: true

Optional: whether to send a notification when the new external record item is created.

Responses

Request samples

Content type
{
  • "external_id": "372975759",
  • "name": "The name of an item to be updated",
  • "type": "html",
  • "content": "<p>The 'created at' and 'updated at' dates should be different now.</p>",
  • "status": "is-available-externally"
}

Response samples

Content type
application/json
Example
{
  • "external_id": "372975759",
  • "name": "The name of an item to be updated",
  • "type": "html",
  • "content": "<p>The 'created at' and 'updated at' dates should be different now.</p>",
  • "status": "is-available-externally",
  • "account": {
    },
  • "created_by_account": {
    },
  • "created_at": "2019-07-01T10:17:21+00:00",
  • "updated_at": "2019-08-01T09:02:52+00:00"
}

Get the file contents of the external record item

beta

Authorizations:
oauth2
path Parameters
account
required
string = 12 characters
Example: a2b75d614ef1

Account ID

externalId
required
string [ 1 .. 255 ] characters
Examples:
  • a2b75d614ef1 - a short ID using hexadecimal characters

The external ID of the external record item

Responses

Response samples

Content type
application/json
Example
{
  • "error": "invalid_grant",
  • "error_description": "The access token provided is invalid."
}

files

My Files

Get files for current account's given organization

Authorizations:
oauth2
path Parameters
organization
required
string = 12 characters
Example: a2b75d614ef1

Organization ID

query Parameters
string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of files to return (defaults to 10)

string or integer
Examples:
  • offset=10 - Example of an offset value as a string
  • offset=25 - Example of an offset value as an integer

Index of first file to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [ ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 0
}

healthspace-connections

Specific users can also manage all connections in a Healthspace (when they have the role ROLE_SPACE_CONNECTION_MANAGER for the given Healthspace).

Each connection endpoint needs its own scope and role permissions. An application can use the scope MANAGE_SPACE_CONNECTIONS to use all (..._READ, ..._CREATE and ..._DELETE) scopes in one scope.

Get connections

This endpoint enables you to obtain the complete set of active connections within the given Healthspace.

Scope

The scope SPACE_CONNECTION_READ is needed for this endpoint.

Role

The authenticated user should have the role ROLE_SPACE_CONNECTION_MANAGER for the given space. This role is part of the group assistants.

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Example: eb860ec90005

The ID of the healthspace of the connection

query Parameters
profile
string = 12 characters
Example: profile=1811aea3de49

Optional: filter the connections by profile

Responses

Response samples

Content type
application/json
{
  • "collection": [
    ],
  • "limit": 10,
  • "offset": 0,
  • "total_count": 2
}

Add connection

This endpoint enables you to create connections between clients and clinicians, based on their respective profile_ids.

When a connection between two profiles is created, users may be notified via e-mail notification.

Scope

The scope SPACE_CONNECTION_CREATE is needed for this endpoint.

Role

The authenticated user should have the role ROLE_SPACE_CONNECTION_MANAGER for the given space. This role is part of the group assistants.

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Example: eb860ec90005

The ID of the healthspace of the connection

Request Body schema: application/json
object

The profile of the clinician

object

The profile of the client

type
string
Value: "PROCLI"

Responses

Request samples

Content type
application/json
{
  • "profile1": {
    },
  • "profile2": {
    },
  • "type": "PROCLI"
}

Response samples

Content type
application/json

Returns the connection that was created

{
  • "id": "6478da305e40",
  • "profile1": {
    },
  • "profile2": {
    },
  • "type": "PROCLI"
}

Get a single connection in a healthspace you administer

This endpoint enables you to obtain a specific connection based on a connection_id

Scope

The scope SPACE_CONNECTION_READ is needed for this endpoint.

Role

The authenticated user should have the role ROLE_SPACE_CONNECTION_MANAGER for the given space. This role is part of the group assistants.

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Example: 210e4b93c511

The ID of the healthspace of the connection

connection
required
string = 12 characters
Example: 751c4c973c9e

The ID of the connection

Responses

Response samples

Content type
application/json
{
  • "id": "751c4c973c9e",
  • "profile1": {
    },
  • "profile2": {
    },
  • "type": "PROCLI"
}

Remove connection

This endpoint enables you to delete a connection based on a connection_id, received when creating or requesting details on a connection.

Scope

The scope SPACE_CONNECTION_DELETE is needed for this endpoint.

Role

The authenticated user should have the role ROLE_SPACE_CONNECTION_MANAGER for the given space. This role is part of the group assistants.

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Example: 210e4b93c511

The ID of the healthspace of the connection

connection
required
string = 12 characters
Example: 751c4c973c9e

The ID of the connection to delete

Responses

Response samples

Content type
application/json
Example
{
  • "error": "invalid_grant",
  • "error_description": "The access token provided is invalid."
}

healthspace-profiles

Specific users can also manage all profiles in a Healthspace (when they have the role ROLE_SPACE_MEMBER_MANAGER for the given Healthspace).

Each profile endpoint needs its own scope and role permissions. An application can use the scope MANAGE_SPACE_PROFILES to use all (..._READ, ..._CREATE and ..._DELETE) scopes in one scope.

Get a specific profile from a healthspace you administer

Returns a single profile in the specified healthspace by the id.

Scope

The scope SPACE_PROFILE_READ is needed for this endpoint.

Role

The authenticated user should have the role ROLE_SPACE_MEMBER_MANAGER which is part of the group assistants, or be any staff member with a Professional-to-Client Connection with the specified profile.

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters

Space ID

profile
required
string = 12 characters

Profile ID

Responses

Response samples

Content type
application/json
{
  • "account": {
    },
  • "administrative_data": {
    },
  • "created_at": "2017-03-27T08:12:09+00:00",
  • "id": "68043e7c1cf2",
  • "groups": [ ],
  • "space": {
    },
  • "status": "subscribed",
  • "updated_at": "2017-03-27T08:12:09+00:00",
  • "user_type": "client"
}

Patch administrative data for a profile in a healthspace you administer

Update a specific profile based on profile_id. It is possible to change the values of status and/or administrative_data using this method.

You can patch a profile and set the status parameter to unsubscribed to unsubscribe the profile, or set the value to subscribed to reactivate it. Changing the subscription status may result in a notification by email to the owner of the profile.

Scope

The scope SPACE_PROFILE_UPDATE is needed for this endpoint.

Role

The authenticated user should have the role ROLE_SPACE_MEMBER_MANAGER which is part of the group assistants.

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters

Space ID

profile
required
string = 12 characters

Profile ID

Request Body schema: application/json
administrative_data
object
status
string
Enum: "subscribed" "unsubscribed"
groups
Array of strings
Items Enum: "administrators" "api_users" "assistants" "clinicians" "clinicians_with_permission_to_manage_connections_with_self" "clinicians_with_permission_to_manage_invitations" "library_managers"

Responses

Request samples

Content type
application/json
{
  • "administrative_data": {
    },
  • "status": "unsubscribed",
  • "groups": [
    ]
}

Response samples

Content type
application/json
{
  • "account": {
    },
  • "administrative_data": {
    },
  • "created_at": "2017-03-27T08:12:09+00:00",
  • "id": "68043e7c1cf2",
  • "space": {
    },
  • "status": "unsubscribed",
  • "updated_at": "2017-03-27T11:28:51+00:00",
  • "user_type": "client",
  • "groups": [
    ]
}

healthspaces

Healthspaces represent groups of profiles on Karify. Users can be invited to a healthspace and thereby become a member.

invitation

Users can be invited to your Healthspace. This can be done using the following endpoints. A user will receive an invitation by email and can chose to create a new Karify account or log in using their existing Karify account. Either way, a profile will be created to confirm the membership with the inviting Healthspace.

Each invitation endpoint needs its own scope and role permissions. An application can use the scope MANAGE_SPACE_INVITATIONS to use all (..._READ, ..._CREATE, ..._RESEND and ..._WITHDRAW) scopes in one scope.

Status Each invitation has an status, the following statusses are possible.

Status Description
invited The user has been invited (via email) to become a member of this Healthspace
requested A user has requested a membership for this Healthspace
accepted The user has accepted the invitation and thus has become a member of this Healthspace
withdrawn The invitation has been withdrawn

Note: the returned invitation object contains both an id and a secret field. The secret field will be deprecated so should not be used for new implementations, please use the id field instead.

Accept an invitation for a Healthspace with an authenticated account.

beta

Authorizations:
oauth2
Request Body schema: application/json
required

The request body should contain an invitation secret

secret
required
string <= 64 characters

Responses

Request samples

Content type
application/json
{
  • "secret": "529832847252d239b31d0d56cfb1d8669aadf3ac568ebd839f5db78c94ace4dc"
}

Response samples

Content type
application/json
Example
{}

Get invitations for space

To get the status of all invites for a specific Healthspace use the following request.

Scope

The scope SPACE_INVITATION_READ is needed for this endpoint.

Role

The authenticated user should have the role ROLE_SPACE_INVITATION_MANAGER for the given space. This role is part of the group assistants.

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

query Parameters
last_modified_since
integer
Example: last_modified_since=631152000

The last_modified_since parameter matches to a UNIX timestamp.

Responses

Response samples

Content type
application/json
{
  • "collection": [
    ],
  • "limit": 10,
  • "offset": 0,
  • "total_count": 6
}

Send invitation

To invite a patient for Karify and for a Healthspace use the following request.

Scope

The scope SPACE_INVITATION_CREATE is needed for this endpoint.

Role

The authenticated user should have the role ROLE_SPACE_INVITATION_MANAGER for the given space. This role is part of the group assistants.

If successful, a 201 code will be returned along with some response variables like invitation_id, which identifies this specific invitation for future reference.

Use this identifier to reference to a patient based on your own administration (for example, the patient identification number).

When a successful invitation is posted, Karify will now go through the process of inviting a patient. An e-mail will be sent to the user with a link to the invitation URL. Here, the user will be guided through the steps of becoming a member of the healthspace. If the user does not have an account, it will also be created during this process.

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

Request Body schema: application/json
object

Object which can include any named variable like identificationNumber for further reference.

email_address
required
string

Email address of invitee to sent the invitation explanation and link to

first_name
required
string

First name of invitee to personalize invitation mail and pre-fill the invitation form for creating a Karify account

invite_user_type
required
string
Enum: "client" "staff"
Array of objects

Connections can be proposed when sending an invitation. Connections will be created with the provided array of accounts once the invited user accepts the invitation.

surname
required
string

Surname of invitee to personalize invitation mail and pre-fill the invitation form for creating a Karify account.

surname_prefix
string

Surname prefix of invitee to personalize invitation mail and pre-fill the invitation form for creating a Karify account

groups
Array of strings

Responses

Request samples

Content type
application/json
{
  • "administrative_data": {
    },
  • "email_address": "penny@example.com",
  • "first_name": "Penny",
  • "invite_user_type": "client",
  • "pending_connections": [
    ],
  • "surname": "Breil",
  • "surname_prefix": ""
}

Response samples

Content type
application/json
{
  • "administrative_data": {
    },
  • "email_address": "piet@example.com",
  • "first_name": "Piet",
  • "groups": [
    ],
  • "id": "89880a5b1d14",
  • "invite_user_type": "staff",
  • "invited_at": "2017-03-27T13:46:30+00:00",
  • "invited_by_account": {
    },
  • "pending_connections": [
    ],
  • "secret": "89880a5b1d14",
  • "space": {
    },
  • "status": "invited",
  • "surname": "Janssen",
  • "surname_prefix": ""
}

Get invitation

To get the status of an invite for Karify use the following request.

Scope

The scope SPACE_INVITATION_READ is needed for this endpoint.

Role

The authenticated user should have the role ROLE_SPACE_INVITATION_MANAGER for the given space. This role is part of the group assistants.

If successful, a 200 code will be returned along with status information of the invitation.

Authorizations:
oauth2
path Parameters
space
required
string

Determines the destination healthspace

invitation
required
string

Unique invitation identifier, returned when creating an invitation (id)

Responses

Response samples

Content type
application/json
{
  • "administrative_data": {
    },
  • "email_address": "piet@example.com",
  • "first_name": "Piet",
  • "groups": [
    ],
  • "id": "89880a5b1d14",
  • "invite_user_type": "staff",
  • "invited_at": "2017-03-27T13:46:30+00:00",
  • "invited_by_account": {
    },
  • "pending_connections": [
    ],
  • "secret": "89880a5b1d14",
  • "space": {
    },
  • "status": "invited",
  • "surname": "Janssen",
  • "surname_prefix": ""
}

Resend invitation

It is possible to resend the invitation in case the targetted user cannot access the invitation.

Scope The scope SPACE_INVITATION_RESEND is needed for this endpoint.

Role The authenticated user should have the role ROLE_SPACE_INVITATION_MANAGER for the given space. This role is part of the group assistants.

If successful, a 202 status (Accepted) is returned containing the updated invitation.

Authorizations:
oauth2
path Parameters
space
required
string

Determines the destination healthspace

invitation
required
string

Unique invitation identifier, returned when creating an invitation (id)

Responses

Response samples

Content type
application/json
{
  • "administrative_data": {
    },
  • "email_address": "piet@example.com",
  • "first_name": "Piet",
  • "groups": [
    ],
  • "id": "89880a5b1d14",
  • "invite_user_type": "staff",
  • "invited_at": "2017-03-27T13:46:30+00:00",
  • "invited_by_account": {
    },
  • "pending_connections": [
    ],
  • "secret": "89880a5b1d14",
  • "space": {
    },
  • "status": "invited",
  • "surname": "Janssen",
  • "surname_prefix": ""
}

Withdraw invitation

Withdrawing the invitation invalidates the outstanding invitation as well as the secret that enables opening the invitation.

Scope

The scope SPACE_INVITATION_WITHDRAW is needed for this endpoint.

Role

The authenticated user should have the role ROLE_SPACE_INVITATION_MANAGER for the given space. This role is part of the group assistants.

If successful, a 202 status (Accepted) is returned containing the updated invitation, with status withdrawn.

Authorizations:
oauth2
path Parameters
space
required
string

Determines the destination healthspace

invitation
required
string

Unique invitation identifier, returned when creating an invitation (id)

Responses

Response samples

Content type
application/json
{
  • "administrative_data": {
    },
  • "email_address": "penny@example.com",
  • "first_name": "Penny",
  • "groups": [ ],
  • "id": "89880a5b1d13",
  • "invitation_resent_at": "2017-03-27T14:04:03+00:00",
  • "invite_user_type": "client",
  • "invited_at": "2017-03-27T13:46:30+00:00",
  • "invited_by_account": {
    },
  • "pending_connections": [ ],
  • "secret": "89880a5b1d13",
  • "space": {
    },
  • "status": "withdrawn",
  • "surname": "Breil",
  • "surname_prefix": ""
}

life-events

Life Events

Get a collection with all Life Events of the user that is logged in

beta

Authorizations:
oauth2
query Parameters
search
string
Examples:
  • search=something - Search for Life Events where the name contains 'something'

Refine the returned results to those Life Events which contain the given search term in their name

string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of Life Events to return (defaults to 10)

string or integer
Examples:
  • offset=10 - Example of an offset value as a string
  • offset=25 - Example of an offset value as an integer

Index of first Life Event to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [ ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 0
}

login

Login

Log in to Karify with a username and password

beta

Authorizations:
oauth2
Request Body schema: application/json
required

The request body should contain a username and password

username
required
string <email>
password
required
string <password> [ 8 .. 60 ] characters

Responses

Request samples

Content type
application/json
{
  • "username": "account-email@example.com",
  • "password": "some-random-password"
}

Response samples

Content type
application/json
Example
{
  • "error_code": "BAD_REQUEST"
}

mail

Sending and receiving messages.

Get all threads

beta

Authorizations:
oauth2
query Parameters
string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of Profiles to return (defaults to 10)

string or integer

Index of first Profile to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
Example

No threads found

{
  • "collection": [ ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 0
}

Create a new thread

beta

Authorizations:
oauth2
Request Body schema:

The content of the new thread

required
Array of objects (account-reference) non-empty

The list of participant accounts. Note that if the currently logged-in account is not included, it is automatically added to the list of participants in the thread. This should include at least one account that is not the currently logged-in account.

subject
required
string non-empty
required
Array of objects non-empty
required
object (space-id)

Responses

Request samples

Content type
Example
{
  • "participant_accounts": [
    ],
  • "subject": "Simple new thread",
  • "messages": [
    ],
  • "space": {
    }
}

Response samples

Content type
application/json
{
  • "id": "99a03c787c8c",
  • "created_by_account": {
    },
  • "participant_accounts": [
    ],
  • "subject": "Simple new thread",
  • "has_attachments": false,
  • "message_count": 1,
  • "last_message": {
    },
  • "space": {
    },
  • "archived": false,
  • "starred": false,
  • "read": true,
  • "reply_enabled": true
}

Get a specific thread

beta

Authorizations:
oauth2
path Parameters
thread
string = 12 characters
Example: c5f085b880ac

The ID of the thread

Responses

Response samples

Content type
application/json
Example
{
  • "id": "c5f085b880ac",
  • "created_by_account": {
    },
  • "participant_accounts": [
    ],
  • "subject": "Example message thread",
  • "has_attachments": false,
  • "message_count": 1,
  • "last_message": {
    },
  • "space": {
    },
  • "archived": false,
  • "starred": false,
  • "read": true,
  • "reply_enabled": true
}

Update the flags on the thread

beta

Authorizations:
oauth2
path Parameters
thread
string = 12 characters
Example: c5f085b880ac

The ID of the thread

Request Body schema: application/json

The properties of the thread to update

archived
boolean
starred
boolean
read
boolean

Responses

Request samples

Content type
application/json

Mark the thread as 'starred'

{
  • "starred": true
}

Response samples

Content type
application/json
{
  • "id": "c5f085b880ac",
  • "created_by_account": {
    },
  • "participant_accounts": [
    ],
  • "subject": "Example message thread",
  • "has_attachments": false,
  • "message_count": 1,
  • "last_message": {
    },
  • "space": {
    },
  • "archived": false,
  • "starred": true,
  • "read": true,
  • "reply_enabled": true
}

Get all messages in a thread

beta

Authorizations:
oauth2
path Parameters
thread
required
string = 12 characters
Example: 23f5e6fe250b

The ID of the thread

query Parameters
string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of Profiles to return (defaults to 10)

string or integer

Index of first Profile to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
{
  • "collection": [
    ],
  • "limit": 0,
  • "offset": 0,
  • "total_count": 0
}

Post a new message to the thread

Authorizations:
oauth2
path Parameters
thread
required
string = 12 characters
Example: 23f5e6fe250b

The ID of the thread that contains the message

Request Body schema:

The message to post, either without attachments as application/json or with attachments as multipart/related. Note that multiple attachment can be added, in which case each attachment is added in a separate part.

body
required
string non-empty
file_attachments
Array of arrays <= 0 items

File attachments only make sense in a multipart/related request, when there are files attached, but it's not wrong to send an empty array.

Responses

Request samples

Content type

A simple reply to the thread

{
  • "body": "This is a new message in reply to the thread"
}

Response samples

Content type
application/json

A new reply

{
  • "id": "4b7092ca4e12",
  • "sender_account": {
    },
  • "body": "This is an example message.",
  • "file_attachments": [ ],
  • "library_attachments": [ ],
  • "read": true,
  • "created_at": "2021-06-04T08:59:44+02:00"
}

Get a specific message

beta

Authorizations:
oauth2
path Parameters
thread
required
string = 12 characters
Example: 23f5e6fe250b

The ID of the thread that contains the message

message
required
string = 12 characters
Example: 4b7092ca4e12

The ID of the requested message

Responses

Response samples

Content type
application/json
Example

A simple message without attachments

{
  • "id": "4b7092ca4e12",
  • "sender_account": {},
  • "body": "This is an example message.",
  • "file_attachments": [ ],
  • "library_attachments": [ ],
  • "read": true,
  • "created_at": "2021-04-21T09:32:27+02:00"
}

Mark a specific message as read or unread

beta

Authorizations:
oauth2
path Parameters
thread
required
string = 12 characters
Example: 23f5e6fe250b

The ID of the thread that contains the message

message
required
string = 12 characters
Example: 4b7092ca4e12

The ID of the requested message

Request Body schema: application/json

The updated contents of the message

read
required
boolean

Responses

Request samples

Content type
application/json
Example

Mark the message as read

{
  • "read": true
}

Response samples

Content type
application/json
Example

A read message.

{
  • "id": "4b7092ca4e12",
  • "sender_account": {
    },
  • "body": "This is an example message.",
  • "file_attachments": [ ],
  • "library_attachments": [ ],
  • "read": true,
  • "created_at": "2021-04-22T12:41:06+02:00"
}

metadata

Metadata is used in the SAML protocol to expose the configuration of a SAML entity, like a SP or IdP. Metadata defines information such as what service are available, addresses and certificates. Metadata is defined in XML. A SP uses the Metadata to know how to communicate with the IdP and vice versa.

Metadata is exchanged between the SP and the IdP. There is no protocol for how the exchange is done but there is no secret information in the metadata so the XML can be freely distributed by mail or published in plain text on the internet.

The SAML metadata for Karify can be found here: https://saml.karify.com/metadata.xml

multi-factor-authentication

Multi factor authentication

Endpoint to associate an authentication method with the currently logged in user

beta

Authorizations:
oauth2cookie
Request Body schema: application/json
required
method
required
string
Enum: "SMS" "TOTP"

Responses

Request samples

Content type
application/json
{
  • "method": "SMS"
}

Response samples

Content type
application/json
Example
{ }

Endpoint to disable multi factor authentication for the currently logged in user.

beta

Authorizations:
oauth2cookie

Responses

Response samples

Content type
application/json
{
  • "error_code": "SESSION_EXPIRED"
}

Endpoint to resend the multi factor authentication code.

beta

Authorizations:
oauth2cookie

Responses

Response samples

Content type
application/json
Example
{
  • "phone_number": "*********78"
}

Endpoint to complete the multifactor authentication challenge.

beta

Authorizations:
oauth2cookie
Request Body schema: application/json
required
mfa_code
required
string
trusted_device
boolean

Responses

Request samples

Content type
application/json
{
  • "mfa_code": "string",
  • "trusted_device": true
}

Response samples

Content type
application/json
{
  • "backup_codes_left": 1
}

Endpoint to request the user's currently set up multi factor authentication method.

beta

Authorizations:
oauth2cookie

Responses

Response samples

Content type
application/json
Example
{
  • "method": "TOTP"
}

Endpoint to generate new backup codes.

beta

Authorizations:
oauth2cookie

Responses

Response samples

Content type
application/json
[
  • "4460377125",
  • "6048618494",
  • "0570784111"
]

Endpoint to invalidate all trusted device cookies for the current user.

beta

Authorizations:
oauth2cookie

Responses

Response samples

Content type
application/json
{
  • "error_code": "SESSION_EXPIRED"
}

Endpoint to request all multi factor authentication methods that are currently supported.

beta

Authorizations:
oauth2cookie

Responses

Response samples

Content type
application/json
[
  • "SMS",
  • "TOTP"
]

Endpoint to generate a QR code.

beta

Authorizations:
oauth2cookie
query Parameters
size
integer

The size of the QR code, defaults to 300 if not given

margin
integer

The margin of the QR code, defaults to 10 if not given

Responses

Response samples

Content type
image/svg+xml

A QR code of default dimensions

<?xml version="1.0"?><svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="320px" height="320px" viewBox="0 0 320 320"><defs><rect id="block" width="8" height="8" fill="#000000" fill-opacity="1"/></defs><rect x="0" y="0" width="320" height="320" fill="#ffffff" fill-opacity="1"/><use x="12" y="12" xlink:href="#block"/><use x="20" y="12" xlink:href="#block"/><use x="28" y="12" xlink:href="#block"/><use x="36" y="12" xlink:href="#block"/><use x="44" y="12" xlink:href="#block"/><use x="52" y="12" xlink:href="#block"/><use x="60" y="12" xlink:href="#block"/><use x="84" y="12" xlink:href="#block"/><use x="132" y="12" xlink:href="#block"/><use x="140" y="12" xlink:href="#block"/><use x="180" y="12" xlink:href="#block"/><use x="188" y="12" xlink:href="#block"/><use x="220" y="12" xlink:href="#block"/><use x="228" y="12" xlink:href="#block"/><use x="252" y="12" xlink:href="#block"/><use x="260" y="12" xlink:href="#block"/><use x="268" y="12" xlink:href="#block"/><use x="276" y="12" xlink:href="#block"/><use x="284" y="12" xlink:href="#block"/><use x="292" y="12" xlink:href="#block"/><use x="300" y="12" xlink:href="#block"/><use x="12" y="20" xlink:href="#block"/><use x="60" y="20" xlink:href="#block"/><use x="76" y="20" xlink:href="#block"/><use x="84" y="20" xlink:href="#block"/><use x="100" y="20" xlink:href="#block"/><use x="108" y="20" xlink:href="#block"/><use x="148" y="20" xlink:href="#block"/><use x="164" y="20" xlink:href="#block"/><use x="188" y="20" xlink:href="#block"/><use x="196" y="20" xlink:href="#block"/><use x="212" y="20" xlink:href="#block"/><use x="220" y="20" xlink:href="#block"/><use x="252" y="20" xlink:href="#block"/><use x="300" y="20" xlink:href="#block"/><use x="12" y="28" xlink:href="#block"/><use x="28" y="28" xlink:href="#block"/><use x="36" y="28" xlink:href="#block"/><use x="44" y="28" xlink:href="#block"/><use x="60" y="28" xlink:href="#block"/><use x="84" y="28" xlink:href="#block"/><use x="92" y="28" xlink:href="#block"/><use x="100" y="28" xlink:href="#block"/><use x="124" y="28" xlink:href="#block"/><use x="140" y="28" xlink:href="#block"/><use x="164" y="28" xlink:href="#block"/><use x="172" y="28" xlink:href="#block"/><use x="180" y="28" xlink:href="#block"/><use x="188" y="28" xlink:href="#block"/><use x="196" y="28" xlink:href="#block"/><use x="204" y="28" xlink:href="#block"/><use x="212" y="28" xlink:href="#block"/><use x="220" y="28" xlink:href="#block"/><use x="236" y="28" xlink:href="#block"/><use x="252" y="28" xlink:href="#block"/><use x="268" y="28" xlink:href="#block"/><use x="276" y="28" xlink:href="#block"/><use x="284" y="28" xlink:href="#block"/><use x="300" y="28" xlink:href="#block"/><use x="12" y="36" xlink:href="#block"/><use x="28" y="36" xlink:href="#block"/><use x="36" y="36" xlink:href="#block"/><use x="44" y="36" xlink:href="#block"/><use x="60" y="36" xlink:href="#block"/><use x="76" y="36" xlink:href="#block"/><use x="84" y="36" xlink:href="#block"/><use x="100" y="36" xlink:href="#block"/><use x="140" y="36" xlink:href="#block"/><use x="148" y="36" xlink:href="#block"/><use x="156" y="36" xlink:href="#block"/><use x="204" y="36" xlink:href="#block"/><use x="228" y="36" xlink:href="#block"/><use x="252" y="36" xlink:href="#block"/><use x="268" y="36" xlink:href="#block"/><use x="276" y="36" xlink:href="#block"/><use x="284" y="36" xlink:href="#block"/><use x="300" y="36" xlink:href="#block"/><use x="12" y="44" xlink:href="#block"/><use x="28" y="44" xlink:href="#block"/><use x="36" y="44" xlink:href="#block"/><use x="44" y="44" xlink:href="#block"/><use x="60" y="44" xlink:href="#block"/><use x="92" y="44" xlink:href="#block"/><use x="108" y="44" xlink:href="#block"/><use x="116" y="44" xlink:href="#block"/><use x="124" y="44" xlink:href="#block"/><use x="132" y="44" xlink:href="#block"/><use x="164" y="44" xlink:href="#block"/><use x="172" y="44" xlink:href="#block"/><use x="180" y="44" xlink:href="#block"/><use x="188" y="44" xlink:href="#block"/><use x="236" y="44" xlink:href="#block"/><use x="252" y="44" xlink:href="#block"/><use x="268" y="44" xlink:href="#block"/><use x="276" y="44" xlink:href="#block"/><use x="284" y="44" xlink:href="#block"/><use x="300" y="44" xlink:href="#block"/><use x="12" y="52" xlink:href="#block"/><use x="60" y="52" xlink:href="#block"/><use x="76" y="52" xlink:href="#block"/><use x="92" y="52" xlink:href="#block"/><use x="116" y="52" xlink:href="#block"/><use x="124" y="52" xlink:href="#block"/><use x="132" y="52" xlink:href="#block"/><use x="140" y="52" xlink:href="#block"/><use x="148" y="52" xlink:href="#block"/><use x="188" y="52" xlink:href="#block"/><use x="212" y="52" xlink:href="#block"/><use x="220" y="52" xlink:href="#block"/><use x="228" y="52" xlink:href="#block"/><use x="252" y="52" xlink:href="#block"/><use x="300" y="52" xlink:href="#block"/><use x="12" y="60" xlink:href="#block"/><use x="20" y="60" xlink:href="#block"/><use x="28" y="60" xlink:href="#block"/><use x="36" y="60" xlink:href="#block"/><use x="44" y="60" xlink:href="#block"/><use x="52" y="60" xlink:href="#block"/><use x="60" y="60" xlink:href="#block"/><use x="76" y="60" xlink:href="#block"/><use x="92" y="60" xlink:href="#block"/><use x="108" y="60" xlink:href="#block"/><use x="124" y="60" xlink:href="#block"/><use x="140" y="60" xlink:href="#block"/><use x="156" y="60" xlink:href="#block"/><use x="172" y="60" xlink:href="#block"/><use x="188" y="60" xlink:href="#block"/><use x="204" y="60" xlink:href="#block"/><use x="220" y="60" xlink:href="#block"/><use x="236" y="60" xlink:href="#block"/><use x="252" y="60" xlink:href="#block"/><use x="260" y="60" xlink:href="#block"/><use x="268" y="60" xlink:href="#block"/><use x="276" y="60" xlink:href="#block"/><use x="284" y="60" xlink:href="#block"/><use x="292" y="60" xlink:href="#block"/><use x="300" y="60" xlink:href="#block"/><use x="108" y="68" xlink:href="#block"/><use x="116" y="68" xlink:href="#block"/><use x="132" y="68" xlink:href="#block"/><use x="164" y="68" xlink:href="#block"/><use x="196" y="68" xlink:href="#block"/><use x="220" y="68" xlink:href="#block"/><use x="236" y="68" xlink:href="#block"/><use x="12" y="76" xlink:href="#block"/><use x="20" y="76" xlink:href="#block"/><use x="28" y="76" xlink:href="#block"/><use x="36" y="76" xlink:href="#block"/><use x="44" y="76" xlink:href="#block"/><use x="60" y="76" xlink:href="#block"/><use x="68" y="76" xlink:href="#block"/><use x="76" y="76" xlink:href="#block"/><use x="84" y="76" xlink:href="#block"/><use x="92" y="76" xlink:href="#block"/><use x="108" y="76" xlink:href="#block"/><use x="124" y="76" xlink:href="#block"/><use x="132" y="76" xlink:href="#block"/><use x="148" y="76" xlink:href="#block"/><use x="156" y="76" xlink:href="#block"/><use x="188" y="76" xlink:href="#block"/><use x="220" y="76" xlink:href="#block"/><use x="228" y="76" xlink:href="#block"/><use x="244" y="76" xlink:href="#block"/><use x="260" y="76" xlink:href="#block"/><use x="276" y="76" xlink:href="#block"/><use x="292" y="76" xlink:href="#block"/><use x="52" y="84" xlink:href="#block"/><use x="76" y="84" xlink:href="#block"/><use x="132" y="84" xlink:href="#block"/><use x="140" y="84" xlink:href="#block"/><use x="172" y="84" xlink:href="#block"/><use x="180" y="84" xlink:href="#block"/><use x="188" y="84" xlink:href="#block"/><use x="228" y="84" xlink:href="#block"/><use x="244" y="84" xlink:href="#block"/><use x="252" y="84" xlink:href="#block"/><use x="292" y="84" xlink:href="#block"/><use x="300" y="84" xlink:href="#block"/><use x="36" y="92" xlink:href="#block"/><use x="60" y="92" xlink:href="#block"/><use x="92" y="92" xlink:href="#block"/><use x="100" y="92" xlink:href="#block"/><use x="108" y="92" xlink:href="#block"/><use x="148" y="92" xlink:href="#block"/><use x="172" y="92" xlink:href="#block"/><use x="188" y="92" xlink:href="#block"/><use x="204" y="92" xlink:href="#block"/><use x="212" y="92" xlink:href="#block"/><use x="220" y="92" xlink:href="#block"/><use x="228" y="92" xlink:href="#block"/><use x="236" y="92" xlink:href="#block"/><use x="244" y="92" xlink:href="#block"/><use x="252" y="92" xlink:href="#block"/><use x="268" y="92" xlink:href="#block"/><use x="284" y="92" xlink:href="#block"/><use x="300" y="92" xlink:href="#block"/><use x="12" y="100" xlink:href="#block"/><use x="36" y="100" xlink:href="#block"/><use x="44" y="100" xlink:href="#block"/><use x="52" y="100" xlink:href="#block"/><use x="100" y="100" xlink:href="#block"/><use x="124" y="100" xlink:href="#block"/><use x="140" y="100" xlink:href="#block"/><use x="164" y="100" xlink:href="#block"/><use x="172" y="100" xlink:href="#block"/><use x="196" y="100" xlink:href="#block"/><use x="220" y="100" xlink:href="#block"/><use x="244" y="100" xlink:href="#block"/><use x="260" y="100" xlink:href="#block"/><use x="20" y="108" xlink:href="#block"/><use x="28" y="108" xlink:href="#block"/><use x="52" y="108" xlink:href="#block"/><use x="60" y="108" xlink:href="#block"/><use x="92" y="108" xlink:href="#block"/><use x="100" y="108" xlink:href="#block"/><use x="140" y="108" xlink:href="#block"/><use x="172" y="108" xlink:href="#block"/><use x="180" y="108" xlink:href="#block"/><use x="188" y="108" xlink:href="#block"/><use x="204" y="108" xlink:href="#block"/><use x="220" y="108" xlink:href="#block"/><use x="228" y="108" xlink:href="#block"/><use x="252" y="108" xlink:href="#block"/><use x="260" y="108" xlink:href="#block"/><use x="268" y="108" xlink:href="#block"/><use x="292" y="108" xlink:href="#block"/><use x="300" y="108" xlink:href="#block"/><use x="12" y="116" xlink:href="#block"/><use x="36" y="116" xlink:href="#block"/><use x="44" y="116" xlink:href="#block"/><use x="52" y="116" xlink:href="#block"/><use x="68" y="116" xlink:href="#block"/><use x="76" y="116" xlink:href="#block"/><use x="108" y="116" xlink:href="#block"/><use x="116" y="116" xlink:href="#block"/><use x="124" y="116" xlink:href="#block"/><use x="132" y="116" xlink:href="#block"/><use x="172" y="116" xlink:href="#block"/><use x="180" y="116" xlink:href="#block"/><use x="188" y="116" xlink:href="#block"/><use x="196" y="116" xlink:href="#block"/><use x="204" y="116" xlink:href="#block"/><use x="220" y="116" xlink:href="#block"/><use x="228" y="116" xlink:href="#block"/><use x="236" y="116" xlink:href="#block"/><use x="268" y="116" xlink:href="#block"/><use x="300" y="116" xlink:href="#block"/><use x="28" y="124" xlink:href="#block"/><use x="36" y="124" xlink:href="#block"/><use x="44" y="124" xlink:href="#block"/><use x="52" y="124" xlink:href="#block"/><use x="60" y="124" xlink:href="#block"/><use x="68" y="124" xlink:href="#block"/><use x="92" y="124" xlink:href="#block"/><use x="116" y="124" xlink:href="#block"/><use x="124" y="124" xlink:href="#block"/><use x="132" y="124" xlink:href="#block"/><use x="140" y="124" xlink:href="#block"/><use x="148" y="124" xlink:href="#block"/><use x="188" y="124" xlink:href="#block"/><use x="212" y="124" xlink:href="#block"/><use x="220" y="124" xlink:href="#block"/><use x="228" y="124" xlink:href="#block"/><use x="236" y="124" xlink:href="#block"/><use x="244" y="124" xlink:href="#block"/><use x="252" y="124" xlink:href="#block"/><use x="284" y="124" xlink:href="#block"/><use x="300" y="124" xlink:href="#block"/><use x="20" y="132" xlink:href="#block"/><use x="28" y="132" xlink:href="#block"/><use x="36" y="132" xlink:href="#block"/><use x="44" y="132" xlink:href="#block"/><use x="52" y="132" xlink:href="#block"/><use x="68" y="132" xlink:href="#block"/><use x="76" y="132" xlink:href="#block"/><use x="92" y="132" xlink:href="#block"/><use x="108" y="132" xlink:href="#block"/><use x="116" y="132" xlink:href="#block"/><use x="132" y="132" xlink:href="#block"/><use x="156" y="132" xlink:href="#block"/><use x="164" y="132" xlink:href="#block"/><use x="172" y="132" xlink:href="#block"/><use x="180" y="132" xlink:href="#block"/><use x="196" y="132" xlink:href="#block"/><use x="220" y="132" xlink:href="#block"/><use x="260" y="132" xlink:href="#block"/><use x="292" y="132" xlink:href="#block"/><use x="28" y="140" xlink:href="#block"/><use x="52" y="140" xlink:href="#block"/><use x="60" y="140" xlink:href="#block"/><use x="76" y="140" xlink:href="#block"/><use x="108" y="140" xlink:href="#block"/><use x="124" y="140" xlink:href="#block"/><use x="132" y="140" xlink:href="#block"/><use x="180" y="140" xlink:href="#block"/><use x="188" y="140" xlink:href="#block"/><use x="212" y="140" xlink:href="#block"/><use x="228" y="140" xlink:href="#block"/><use x="236" y="140" xlink:href="#block"/><use x="260" y="140" xlink:href="#block"/><use x="268" y="140" xlink:href="#block"/><use x="276" y="140" xlink:href="#block"/><use x="292" y="140" xlink:href="#block"/><use x="300" y="140" xlink:href="#block"/><use x="12" y="148" xlink:href="#block"/><use x="36" y="148" xlink:href="#block"/><use x="84" y="148" xlink:href="#block"/><use x="92" y="148" xlink:href="#block"/><use x="132" y="148" xlink:href="#block"/><use x="140" y="148" xlink:href="#block"/><use x="164" y="148" xlink:href="#block"/><use x="180" y="148" xlink:href="#block"/><use x="188" y="148" xlink:href="#block"/><use x="196" y="148" xlink:href="#block"/><use x="204" y="148" xlink:href="#block"/><use x="228" y="148" xlink:href="#block"/><use x="236" y="148" xlink:href="#block"/><use x="244" y="148" xlink:href="#block"/><use x="252" y="148" xlink:href="#block"/><use x="260" y="148" xlink:href="#block"/><use x="268" y="148" xlink:href="#block"/><use x="300" y="148" xlink:href="#block"/><use x="12" y="156" xlink:href="#block"/><use x="60" y="156" xlink:href="#block"/><use x="92" y="156" xlink:href="#block"/><use x="100" y="156" xlink:href="#block"/><use x="108" y="156" xlink:href="#block"/><use x="148" y="156" xlink:href="#block"/><use x="172" y="156" xlink:href="#block"/><use x="180" y="156" xlink:href="#block"/><use x="188" y="156" xlink:href="#block"/><use x="204" y="156" xlink:href="#block"/><use x="212" y="156" xlink:href="#block"/><use x="220" y="156" xlink:href="#block"/><use x="228" y="156" xlink:href="#block"/><use x="244" y="156" xlink:href="#block"/><use x="252" y="156" xlink:href="#block"/><use x="268" y="156" xlink:href="#block"/><use x="276" y="156" xlink:href="#block"/><use x="284" y="156" xlink:href="#block"/><use x="292" y="156" xlink:href="#block"/><use x="300" y="156" xlink:href="#block"/><use x="12" y="164" xlink:href="#block"/><use x="44" y="164" xlink:href="#block"/><use x="68" y="164" xlink:href="#block"/><use x="92" y="164" xlink:href="#block"/><use x="100" y="164" xlink:href="#block"/><use x="124" y="164" xlink:href="#block"/><use x="140" y="164" xlink:href="#block"/><use x="164" y="164" xlink:href="#block"/><use x="172" y="164" xlink:href="#block"/><use x="180" y="164" xlink:href="#block"/><use x="188" y="164" xlink:href="#block"/><use x="196" y="164" xlink:href="#block"/><use x="276" y="164" xlink:href="#block"/><use x="284" y="164" xlink:href="#block"/><use x="292" y="164" xlink:href="#block"/><use x="12" y="172" xlink:href="#block"/><use x="28" y="172" xlink:href="#block"/><use x="52" y="172" xlink:href="#block"/><use x="60" y="172" xlink:href="#block"/><use x="76" y="172" xlink:href="#block"/><use x="100" y="172" xlink:href="#block"/><use x="148" y="172" xlink:href="#block"/><use x="156" y="172" xlink:href="#block"/><use x="172" y="172" xlink:href="#block"/><use x="220" y="172" xlink:href="#block"/><use x="228" y="172" xlink:href="#block"/><use x="236" y="172" xlink:href="#block"/><use x="244" y="172" xlink:href="#block"/><use x="252" y="172" xlink:href="#block"/><use x="276" y="172" xlink:href="#block"/><use x="292" y="172" xlink:href="#block"/><use x="300" y="172" xlink:href="#block"/><use x="12" y="180" xlink:href="#block"/><use x="20" y="180" xlink:href="#block"/><use x="28" y="180" xlink:href="#block"/><use x="36" y="180" xlink:href="#block"/><use x="44" y="180" xlink:href="#block"/><use x="52" y="180" xlink:href="#block"/><use x="68" y="180" xlink:href="#block"/><use x="84" y="180" xlink:href="#block"/><use x="108" y="180" xlink:href="#block"/><use x="116" y="180" xlink:href="#block"/><use x="124" y="180" xlink:href="#block"/><use x="132" y="180" xlink:href="#block"/><use x="156" y="180" xlink:href="#block"/><use x="164" y="180" xlink:href="#block"/><use x="180" y="180" xlink:href="#block"/><use x="220" y="180" xlink:href="#block"/><use x="228" y="180" xlink:href="#block"/><use x="236" y="180" xlink:href="#block"/><use x="276" y="180" xlink:href="#block"/><use x="292" y="180" xlink:href="#block"/><use x="20" y="188" xlink:href="#block"/><use x="36" y="188" xlink:href="#block"/><use x="60" y="188" xlink:href="#block"/><use x="76" y="188" xlink:href="#block"/><use x="116" y="188" xlink:href="#block"/><use x="124" y="188" xlink:href="#block"/><use x="132" y="188" xlink:href="#block"/><use x="148" y="188" xlink:href="#block"/><use x="156" y="188" xlink:href="#block"/><use x="188" y="188" xlink:href="#block"/><use x="204" y="188" xlink:href="#block"/><use x="212" y="188" xlink:href="#block"/><use x="228" y="188" xlink:href="#block"/><use x="244" y="188" xlink:href="#block"/><use x="252" y="188" xlink:href="#block"/><use x="260" y="188" xlink:href="#block"/><use x="268" y="188" xlink:href="#block"/><use x="284" y="188" xlink:href="#block"/><use x="292" y="188" xlink:href="#block"/><use x="12" y="196" xlink:href="#block"/><use x="20" y="196" xlink:href="#block"/><use x="36" y="196" xlink:href="#block"/><use x="44" y="196" xlink:href="#block"/><use x="68" y="196" xlink:href="#block"/><use x="76" y="196" xlink:href="#block"/><use x="108" y="196" xlink:href="#block"/><use x="116" y="196" xlink:href="#block"/><use x="132" y="196" xlink:href="#block"/><use x="148" y="196" xlink:href="#block"/><use x="164" y="196" xlink:href="#block"/><use x="172" y="196" xlink:href="#block"/><use x="180" y="196" xlink:href="#block"/><use x="196" y="196" xlink:href="#block"/><use x="212" y="196" xlink:href="#block"/><use x="236" y="196" xlink:href="#block"/><use x="244" y="196" xlink:href="#block"/><use x="260" y="196" xlink:href="#block"/><use x="276" y="196" xlink:href="#block"/><use x="284" y="196" xlink:href="#block"/><use x="20" y="204" xlink:href="#block"/><use x="44" y="204" xlink:href="#block"/><use x="52" y="204" xlink:href="#block"/><use x="60" y="204" xlink:href="#block"/><use x="108" y="204" xlink:href="#block"/><use x="124" y="204" xlink:href="#block"/><use x="132" y="204" xlink:href="#block"/><use x="140" y="204" xlink:href="#block"/><use x="172" y="204" xlink:href="#block"/><use x="180" y="204" xlink:href="#block"/><use x="212" y="204" xlink:href="#block"/><use x="220" y="204" xlink:href="#block"/><use x="228" y="204" xlink:href="#block"/><use x="236" y="204" xlink:href="#block"/><use x="276" y="204" xlink:href="#block"/><use x="284" y="204" xlink:href="#block"/><use x="292" y="204" xlink:href="#block"/><use x="300" y="204" xlink:href="#block"/><use x="12" y="212" xlink:href="#block"/><use x="20" y="212" xlink:href="#block"/><use x="36" y="212" xlink:href="#block"/><use x="44" y="212" xlink:href="#block"/><use x="52" y="212" xlink:href="#block"/><use x="68" y="212" xlink:href="#block"/><use x="76" y="212" xlink:href="#block"/><use x="132" y="212" xlink:href="#block"/><use x="172" y="212" xlink:href="#block"/><use x="180" y="212" xlink:href="#block"/><use x="188" y="212" xlink:href="#block"/><use x="196" y="212" xlink:href="#block"/><use x="204" y="212" xlink:href="#block"/><use x="228" y="212" xlink:href="#block"/><use x="236" y="212" xlink:href="#block"/><use x="244" y="212" xlink:href="#block"/><use x="252" y="212" xlink:href="#block"/><use x="260" y="212" xlink:href="#block"/><use x="276" y="212" xlink:href="#block"/><use x="292" y="212" xlink:href="#block"/><use x="12" y="220" xlink:href="#block"/><use x="28" y="220" xlink:href="#block"/><use x="36" y="220" xlink:href="#block"/><use x="60" y="220" xlink:href="#block"/><use x="76" y="220" xlink:href="#block"/><use x="84" y="220" xlink:href="#block"/><use x="100" y="220" xlink:href="#block"/><use x="108" y="220" xlink:href="#block"/><use x="140" y="220" xlink:href="#block"/><use x="188" y="220" xlink:href="#block"/><use x="212" y="220" xlink:href="#block"/><use x="220" y="220" xlink:href="#block"/><use x="252" y="220" xlink:href="#block"/><use x="260" y="220" xlink:href="#block"/><use x="268" y="220" xlink:href="#block"/><use x="276" y="220" xlink:href="#block"/><use x="284" y="220" xlink:href="#block"/><use x="292" y="220" xlink:href="#block"/><use x="12" y="228" xlink:href="#block"/><use x="28" y="228" xlink:href="#block"/><use x="44" y="228" xlink:href="#block"/><use x="52" y="228" xlink:href="#block"/><use x="68" y="228" xlink:href="#block"/><use x="100" y="228" xlink:href="#block"/><use x="124" y="228" xlink:href="#block"/><use x="140" y="228" xlink:href="#block"/><use x="148" y="228" xlink:href="#block"/><use x="156" y="228" xlink:href="#block"/><use x="164" y="228" xlink:href="#block"/><use x="172" y="228" xlink:href="#block"/><use x="196" y="228" xlink:href="#block"/><use x="220" y="228" xlink:href="#block"/><use x="236" y="228" xlink:href="#block"/><use x="244" y="228" xlink:href="#block"/><use x="260" y="228" xlink:href="#block"/><use x="284" y="228" xlink:href="#block"/><use x="300" y="228" xlink:href="#block"/><use x="12" y="236" xlink:href="#block"/><use x="36" y="236" xlink:href="#block"/><use x="52" y="236" xlink:href="#block"/><use x="60" y="236" xlink:href="#block"/><use x="76" y="236" xlink:href="#block"/><use x="84" y="236" xlink:href="#block"/><use x="100" y="236" xlink:href="#block"/><use x="132" y="236" xlink:href="#block"/><use x="148" y="236" xlink:href="#block"/><use x="156" y="236" xlink:href="#block"/><use x="172" y="236" xlink:href="#block"/><use x="188" y="236" xlink:href="#block"/><use x="220" y="236" xlink:href="#block"/><use x="228" y="236" xlink:href="#block"/><use x="236" y="236" xlink:href="#block"/><use x="244" y="236" xlink:href="#block"/><use x="252" y="236" xlink:href="#block"/><use x="260" y="236" xlink:href="#block"/><use x="268" y="236" xlink:href="#block"/><use x="284" y="236" xlink:href="#block"/><use x="292" y="236" xlink:href="#block"/><use x="300" y="236" xlink:href="#block"/><use x="76" y="244" xlink:href="#block"/><use x="84" y="244" xlink:href="#block"/><use x="108" y="244" xlink:href="#block"/><use x="116" y="244" xlink:href="#block"/><use x="124" y="244" xlink:href="#block"/><use x="140" y="244" xlink:href="#block"/><use x="164" y="244" xlink:href="#block"/><use x="180" y="244" xlink:href="#block"/><use x="196" y="244" xlink:href="#block"/><use x="236" y="244" xlink:href="#block"/><use x="268" y="244" xlink:href="#block"/><use x="276" y="244" xlink:href="#block"/><use x="300" y="244" xlink:href="#block"/><use x="12" y="252" xlink:href="#block"/><use x="20" y="252" xlink:href="#block"/><use x="28" y="252" xlink:href="#block"/><use x="36" y="252" xlink:href="#block"/><use x="44" y="252" xlink:href="#block"/><use x="52" y="252" xlink:href="#block"/><use x="60" y="252" xlink:href="#block"/><use x="76" y="252" xlink:href="#block"/><use x="116" y="252" xlink:href="#block"/><use x="124" y="252" xlink:href="#block"/><use x="132" y="252" xlink:href="#block"/><use x="148" y="252" xlink:href="#block"/><use x="172" y="252" xlink:href="#block"/><use x="188" y="252" xlink:href="#block"/><use x="196" y="252" xlink:href="#block"/><use x="212" y="252" xlink:href="#block"/><use x="220" y="252" xlink:href="#block"/><use x="236" y="252" xlink:href="#block"/><use x="252" y="252" xlink:href="#block"/><use x="268" y="252" xlink:href="#block"/><use x="276" y="252" xlink:href="#block"/><use x="284" y="252" xlink:href="#block"/><use x="292" y="252" xlink:href="#block"/><use x="300" y="252" xlink:href="#block"/><use x="12" y="260" xlink:href="#block"/><use x="60" y="260" xlink:href="#block"/><use x="108" y="260" xlink:href="#block"/><use x="116" y="260" xlink:href="#block"/><use x="140" y="260" xlink:href="#block"/><use x="156" y="260" xlink:href="#block"/><use x="172" y="260" xlink:href="#block"/><use x="180" y="260" xlink:href="#block"/><use x="196" y="260" xlink:href="#block"/><use x="204" y="260" xlink:href="#block"/><use x="236" y="260" xlink:href="#block"/><use x="268" y="260" xlink:href="#block"/><use x="284" y="260" xlink:href="#block"/><use x="12" y="268" xlink:href="#block"/><use x="28" y="268" xlink:href="#block"/><use x="36" y="268" xlink:href="#block"/><use x="44" y="268" xlink:href="#block"/><use x="60" y="268" xlink:href="#block"/><use x="76" y="268" xlink:href="#block"/><use x="84" y="268" xlink:href="#block"/><use x="92" y="268" xlink:href="#block"/><use x="108" y="268" xlink:href="#block"/><use x="124" y="268" xlink:href="#block"/><use x="132" y="268" xlink:href="#block"/><use x="140" y="268" xlink:href="#block"/><use x="156" y="268" xlink:href="#block"/><use x="172" y="268" xlink:href="#block"/><use x="180" y="268" xlink:href="#block"/><use x="188" y="268" xlink:href="#block"/><use x="204" y="268" xlink:href="#block"/><use x="220" y="268" xlink:href="#block"/><use x="236" y="268" xlink:href="#block"/><use x="244" y="268" xlink:href="#block"/><use x="252" y="268" xlink:href="#block"/><use x="260" y="268" xlink:href="#block"/><use x="268" y="268" xlink:href="#block"/><use x="284" y="268" xlink:href="#block"/><use x="12" y="276" xlink:href="#block"/><use x="28" y="276" xlink:href="#block"/><use x="36" y="276" xlink:href="#block"/><use x="44" y="276" xlink:href="#block"/><use x="60" y="276" xlink:href="#block"/><use x="76" y="276" xlink:href="#block"/><use x="84" y="276" xlink:href="#block"/><use x="132" y="276" xlink:href="#block"/><use x="172" y="276" xlink:href="#block"/><use x="180" y="276" xlink:href="#block"/><use x="220" y="276" xlink:href="#block"/><use x="228" y="276" xlink:href="#block"/><use x="236" y="276" xlink:href="#block"/><use x="260" y="276" xlink:href="#block"/><use x="268" y="276" xlink:href="#block"/><use x="292" y="276" xlink:href="#block"/><use x="300" y="276" xlink:href="#block"/><use x="12" y="284" xlink:href="#block"/><use x="28" y="284" xlink:href="#block"/><use x="36" y="284" xlink:href="#block"/><use x="44" y="284" xlink:href="#block"/><use x="60" y="284" xlink:href="#block"/><use x="76" y="284" xlink:href="#block"/><use x="100" y="284" xlink:href="#block"/><use x="108" y="284" xlink:href="#block"/><use x="148" y="284" xlink:href="#block"/><use x="164" y="284" xlink:href="#block"/><use x="188" y="284" xlink:href="#block"/><use x="212" y="284" xlink:href="#block"/><use x="220" y="284" xlink:href="#block"/><use x="260" y="284" xlink:href="#block"/><use x="268" y="284" xlink:href="#block"/><use x="284" y="284" xlink:href="#block"/><use x="300" y="284" xlink:href="#block"/><use x="12" y="292" xlink:href="#block"/><use x="60" y="292" xlink:href="#block"/><use x="76" y="292" xlink:href="#block"/><use x="92" y="292" xlink:href="#block"/><use x="100" y="292" xlink:href="#block"/><use x="124" y="292" xlink:href="#block"/><use x="140" y="292" xlink:href="#block"/><use x="164" y="292" xlink:href="#block"/><use x="172" y="292" xlink:href="#block"/><use x="196" y="292" xlink:href="#block"/><use x="220" y="292" xlink:href="#block"/><use x="236" y="292" xlink:href="#block"/><use x="244" y="292" xlink:href="#block"/><use x="252" y="292" xlink:href="#block"/><use x="268" y="292" xlink:href="#block"/><use x="292" y="292" xlink:href="#block"/><use x="12" y="300" xlink:href="#block"/><use x="20" y="300" xlink:href="#block"/><use x="28" y="300" xlink:href="#block"/><use x="36" y="300" xlink:href="#block"/><use x="44" y="300" xlink:href="#block"/><use x="52" y="300" xlink:href="#block"/><use x="60" y="300" xlink:href="#block"/><use x="76" y="300" xlink:href="#block"/><use x="84" y="300" xlink:href="#block"/><use x="100" y="300" xlink:href="#block"/><use x="132" y="300" xlink:href="#block"/><use x="148" y="300" xlink:href="#block"/><use x="156" y="300" xlink:href="#block"/><use x="172" y="300" xlink:href="#block"/><use x="188" y="300" xlink:href="#block"/><use x="212" y="300" xlink:href="#block"/><use x="228" y="300" xlink:href="#block"/><use x="244" y="300" xlink:href="#block"/><use x="260" y="300" xlink:href="#block"/><use x="276" y="300" xlink:href="#block"/><use x="292" y="300" xlink:href="#block"/><use x="300" y="300" xlink:href="#block"/></svg>

oauth-authorization

The OAuth authorization flow for obtaining and refreshing access tokens

Authorization code grant

To request access on behalf of a user, redirect the user to Karify's authorization page, https://my.karify.com/oauth/v2/auth with some mandatory parameters. The page will prompt the user to authorize the app while providing basic information about what is being asked.

By default, applications can only view a user's public data. The scope parameter can be used to request more access. It is recommended to only requested the minimum amount of access necessary.

When a visitor is directed to this page, they are required to log in using their username and password when they aren't logged in yet. After login, they will be prompted with a question to give the requested access (based on the scope) to the app (this is based on the API client details).

When the visitor grants access within karify, they will be redirected to the URL that was provided in redirect_url, with the addition of the state and code parameters in the query string. For example:

YOUR_REDIRECT_URI/?state=YOUR_OPTIONAL_STATE&code=Yjk2MWU5YjVhODBiN2I0ZDRkYmQ1OGM0NGY4MmUyOGM2NDQ2MmY2ZDg2YjUxYjRiMzAwZTY2MDQxZmUzODg2YQ

This code can then be used to fetch an access token and a refresh token using the /oauth/v2/token endpoint, uniquely identifying the client that made the request and the account it was created for.

Note: for security reasons, the code expires rather quickly.

Authorizations:
oauth2cookie
query Parameters
client_id
required
string
Example: client_id=01_abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ12345657890

The CLIENT_ID for your API client.

response_type
required
string
Value: "code"

The type of response, only code is supported.

redirect_uri
required
string
Example: redirect_uri=https://example.com/my-application

URI to redirect the user to after logging in. The authorization code will be added to the query string of this URI when redirecting, for example https://example.com/my-application?code=abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ12345657890

Note: for security reasons, the redirect_uri should be identical to the one provided on client creation. If not, an error is returned instead.

scope
required
string
Example: scope=LOGIN MANAGE_ACCOUNT MANAGE_MAIL MANAGE_MAIL_LABEL MANAGE_CONTACTS MANAGE_PROFILES MANAGE_VIDEO_CONVERSATIONS MANAGE_CONNECTIONS

Space separated list of requested scopes. See the documentation for the endpoint you want to use for the scope it needs. See RFC6749 for more information about scopes.

state
string

An unguessable random string. It is used to protect against cross-site request forgery attacks.

Responses

Obtain or refresh the access_token

This endpoint is used to obtain an access_token for OAuth authorization. Depending on the configuration of the API client, this can be done using an authorization code, a refresh token, or using client credentials.

When using the grant type authorization_code, you have to provide a code and a redirect_uri next to the three required fields grant_type, client_id, and client_secret. The code can be received using the authorization, flow by redirecting the user to /oauth/v2/auth. The redirect_uri has to be the same as the redirect_uri that was provided in that flow. Note that the obtained code expires quickly.

When you successfully get an access token using this grant type, you also get a refresh token. The access token is valid for one hour, after which you can use the refresh_token to obtain a new pair of access and refresh tokens. The refresh token is valid for half a year.

When using the grant type refresh_token, you have to provide the refresh_token as well as the three required fields to obtain a new access token. This also returns a new refresh token, invalidating the previous one. In other words: refresh tokens can only be used once.

Finally, when using the grant type client_credentials you only have to provide the grant_type, client_id and client_secret. This can only be used when your credentials have been configured to support it, and your login will then be tied to the organization that they are configured for. You will only receive an access_token, and will need to use the client_credentials grant type to obtain a new access token after it has expired.

In each of these flows you can also limit the scope of the access token by providing a scope, otherwise you will get the default scope for that flow. When based on an account (authorization_code or refresh_code), this is limited to the scopes that were initially requested from that user. When based on client credentials, this defaults to all scopes. Note that these scopes do not grant access if the underlying account or organization does not have access, it can only limit.

Authorizations:
oauth2cookie
Request Body schema: multipart/form-data
client_id
required
string
client_secret
required
string
grant_type
required
string
Enum: "refresh_token" "authorization_code" "client_credentials"
refresh_token
string
code
string
redirect_uri
string <url>
scope
string

A list of one or more scopes, separated by a space

Responses

Request samples

Content type
multipart/form-data
Example

Example of requesting a new token pair using an authorization code

{
  "client_id": "1_abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMOPQRSTUVWXYZ1234567890",
  "client_secret": "YourClientSecret",
  "grant_type": "authorization_code",
  "code": "YTdmM2U5MDlhYTcxZjJkYTdkZGQ2N2Q3YzMwZjY2MDk0NTMzZWJjMDBlZTU5YWRiN2JhZjUzYjEzNTI4OGY5Yw",
  "redirect_uri": "https://example.com/my-application"
}

Response samples

Content type
application/json
Example
{
  • "access_token": "OTM3ZmYwN2QwNmQ0NWIxMTliMjk3NWQyNzg5ZWFkMzM5ZGRhZDBmOGJjMGQ5ZTc3YWNjNTAzYzNjZmY4NmYyMw",
  • "expires_in": 3600,
  • "refresh_token": "YTdmM2U5MDlhYTcxZjJkYTdkZGQ2N2Q3YzMwZjY2MDk0NTMzZWJjMDBlZTU5YWRiN2JhZjUzYjEzNTI4OGY5Yw",
  • "scope": null,
  • "token_type": "bearer"
}

oauth-sso

Single Sign-On via OAuth

Generate an SSO URL

Generate a temporary SSO url for the user. This url can only be used once and will expire rather quickly (1 minute), so be sure to pass it to the user directly after requesting.

A optional redirect_uri can be used to redirect the user to a given page within Karify.

The (successful) response will have a 303 See Other HTTP status code and will redirect to a Karify URL. When a backend system requests this page, make sure the redirect is not followed but passed to the end-user instead.

Scope

The scope LOGIN is needed for this endpoint.

Role

No specific role is needed for the authenticated user using this endpoint.

Authorizations:
oauth2
query Parameters
redirect_uri
string
Example: redirect_uri=https://my.karify.com/dossier

The URL within Karify to redirect to after login

Responses

Response samples

Content type
application/json

Invalid redirect URI (e.g. a redirect outside of Karify)

{
  • "error_code": "INVALID_REDIRECT_URI"
}

Use SSO url

Once the SSO url of the previous step was generated, it can be used to start a Karify session for the user.

This URL should be followed by the user's browser instead of a external application's backend system.

As explained, the token in this URL expires rather quickly and can only be used once.

Note: if the token has expired or is invalid, a redirect to the index page will be returned without being logged in.

Authorizations:
oauth2cookie
query Parameters
token
string
Example: token=1234567890abcdefg

The token to validate the SSO request

Responses

organizations

Organizations represent groups of healthspaces of the same owner on Karify. Therefore a organization can have one or more healthspaces.

Get user's organization

Get information about the authenticated user's organization. Scope The scope ORGANIZATION_READ is needed for this endpoint.

Role The authenticated user should have the role ROLE_ACCOUNT_SPACE_OWNER.

Authorizations:
oauth2

Responses

Response samples

Content type
application/json
{
  • "account": {
    },
  • "address": {
    },
  • "billing_address": {
    },
  • "fiscal_number": "123456789",
  • "id": "74c506bc7589",
  • "name": "Karify demo organization"
}

Get occurrences of user's organization

beta

Authorizations:
oauth2
query Parameters
spaces[]
Array of strings[ items = 12 characters ]
Example: spaces[]=f33a6884f5b5&spaces[]=fd12e06fcf4c

filter occurrences by one or more Healthspaces

event_names[]
Array of strings
Items Value: "karify_dossier.external_record_item_details_viewed_in_space"

filter occurrences by one or more specific events

before
integer
Example: before=1745798400

Filter occurrences before a given timestamp

after
integer
Example: after=1745712000

Filter occurrences no earlier than a given timestamp

string or integer
Examples:
  • limit=50 - Example of a limit value as a string
  • limit=200 - Example of a limit value as an integer

Maximum number of occurrences to return (defaults to 100)

string or integer

Index of first occurrence to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
Example

An empty collection

{
  • "collection": [ ],
  • "limit": 100,
  • "offset": 0,
  • "total_count": 0
}

plan-recipe

Plan Recipe

Get a collection of all available Plan Recipes from a given Healthspaces where the role is Staff

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

query Parameters
string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of Plan Recipes to return (defaults to 10)

string or integer
Examples:
  • offset=10 - Example of an offset value as a string
  • offset=25 - Example of an offset value as an integer

Index of first Plan Recipe to be returned (defaults to 0)

search-term
string

Refine the returned results to those Plan Recipes which contain the given search term in their name or code

plannable_item_type[]
Array of strings
Items Enum: "package" "assignment_form" "widget" "externally_provided_plannable_item"
Examples:
  • plannable_item_type[]=package - Filter by plannable item type, where the plannable item type is 'package'
  • plannable_item_type[]=assignment_form - Filter by plannable item type, where the plannable item type is 'assignment_form'
  • plannable_item_type[]=widget - Filter by plannable item type, where the plannable item type is 'widget'
  • plannable_item_type[]=externally_provided_plannable_item - Filter by plannable item type, where the plannable item type is 'externally_provided_plannable_item'
  • plannable_item_type[]=package&plannable_item_type[]=widget - Filter by plannable item type, where the plannable item type is either 'package' or 'widget'

Filter the collection of plan recipes based on the given plannable item types

object
Examples:
  • order_by[name]=desc - Order by name in descending order
  • order_by[name]=asc - Order by name in ascending order
  • order_by[code]=desc - Order by code in descending order
  • order_by[code]=asc - Order by code in ascending order
  • order_by[created_at]=desc - Order by created_at in descending order
  • order_by[created_at]=asc - Order by created_at in ascending order
  • order_by[name]=desc&order_by[code]=asc - Order by name in descending order and code in ascending order
  • order_by[name]=desc&order_by[code]=asc - Order by code in descending order and name in ascending order

Sort the results of Plan Recipes based on name and/or code and/or created_at. The order in which the parameters are given, will also determine the order in which the filters will be applied.

plannable_item_reference_status[]
Array of strings
Items Enum: "published" "archived" "concept"
Examples:
  • plannable_item_reference_status[]=published - Filter by plannable item reference status, where the plannable item reference status is 'published'
  • plannable_item_reference_status[]=archived - Filter by plannable item reference status, where the plannable item reference status is 'archived'
  • plannable_item_reference_status[]=concept - Filter by plannable item reference status, where the plannable item reference status is 'concept'
  • plannable_item_reference_status[]=published&plannable_item_reference_status[]=concept - Filter by plannable item reference status, where the plannable item reference status is either 'published' or 'concept'

Filter the collection of plan recipes based on the given plannable item reference status or statuses

starred
boolean
Examples:
  • starred=true - Filter by plan recipes that are marked as starred.
  • starred=false - Filter by plan recipes that are not marked as starred.

Filter the collection of plan recipes based on the 'starred' status of the plan recipes. The 'starred' status indicates, when true, that a plan recipe has been marked as a 'favorite' by the user making the request.

recipe_type[]
Array of strings
Items Enum: "continuous_repeat_plan_recipe" "fixed_repeat_plan_recipe" "single_plan_recipe"
Examples:
  • recipe_type[]=continuous_repeat_plan_recipe - Filter by recipe type, where the type is 'continuous_repeat_plan_recipe'
  • recipe_type[]=fixed_repeat_plan_recipe - Filter by recipe type, where type type is 'fixed_repeat_plan_recipe'
  • recipe_type[]=single_plan_recipe - Filter by recipe type, where the type is 'single_plan_recipe'
  • recipe_type[]=single_plan_recipe&recipe_type[]=fixed_repeat_plan_recipe - Filter by recipe type, where the type is either 'single_plan_recipe' or 'fixed_repeat_plan_recipe'

Filter the collection of plan recipes based on the given recipe type or types

areas_of_care[]
Array of strings[ items [ 3 .. 63 ] characters ]
Examples:
  • areas_of_care[]=area-of-care-1 - Filter by area of care, where the area is 'area-of-care-1'
  • areas_of_care[]=area-of-care-1&areas_of_care[]=area-of-care-2 - Filter by multiple areas of care, where the areas are 'area-of-care-1' and 'area-of-care-2'

Filter the collection based on the given areas of care

forms_of_care[]
Array of strings[ items [ 3 .. 63 ] characters ]
Examples:
  • forms_of_care[]=form-of-care-1 - Filter by form of care, where the form is 'form-of-care-1'
  • forms_of_care[]=form-of-care-1&forms_of_care[]=form-of-care-2 - Filter by multiple forms of care, where the forms are 'form-of-care-1' and 'form-of-care-2'

Filter the collection based on the given forms of care

forms_of_therapy[]
Array of strings[ items [ 3 .. 63 ] characters ]
Examples:
  • forms_of_therapy[]=form-of-therapy-1 - Filter by form of therapy, where the form is 'form-of-therapy-1'
  • forms_of_therapy[]=form-of-therapy-1&forms_of_therapy[]=form-of-therapy-2 - Filter by multiple forms of therapy, where the forms are 'form-of-therapy-1' and 'form-of-therapy-2'

Filter the collection based on the given forms of therapy

languages[]
Array of strings[ items [ 3 .. 63 ] characters ]
Examples:
  • languages[]=language-1 - Filter by language, where the language is 'language-1'
  • languages[]=language-1&languages[]=language-2 - Filter by multiple languages, where the languages are 'language-1' and 'language-2'

Filter the collection based on the given language

intervention_types[]
Array of strings[ items [ 3 .. 63 ] characters ]
Examples:
  • intervention_types[]=intervention-type-1 - Filter by intervention type, where the type is 'intervention-type-1'
  • intervention_types[]=intervention-type-1&intervention_types[]=intervention-type-2 - Filter by multiple intervention types, where the types are 'intervention-type-1' and 'intervention-type-2'

Filter the collection of plan recipes based on the given intervention type or types

target_audiences[]
Array of strings[ items [ 3 .. 63 ] characters ]
Examples:
  • target_audiences[]=audience-1 - Filter by target audience, where the audience is 'audience-1'
  • target_audiences[]=audience-1&target_audiences[]=audience-2 - Filter by multiple target audiences, where the audiences are 'audience-1' and 'audience-2'

Filter the collection based on the given target audiences

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [ ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 0
}

Returns the plan recipe with the provided id

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

planRecipe
required
string = 12 characters
Examples:
  • 8727a54b25c0 - Example of a plan recipe ID

Plan Recipe ID

header Parameters
Accept-Language
string
Examples:
  • en - Example of setting the language to English
  • nl - Example of setting the language to Dutch

Accept-Language header to change the expected language that is returned for some metadata categories. Note that this only works when the logged in user has not specified a preferred locale in the account settings.

Responses

Response samples

Content type
application/json
Example
{
  • "id": "someRandomId",
  • "created_at": "2013-02-09T07:00:00+01:00",
  • "name": "Non-repeating Assignment Form",
  • "plannable_item_type": "assignment_form",
  • "recipe_type": "single_plan_recipe",
  • "starred": false,
  • "planned_item_count": 1,
  • "user_guide": {},
  • "intervention_type": {
    },
  • "image": {},
  • "user_guide_description": "# **User guide description **\n\n*Lorem ipsum *\n\ndolor sit amet, consectetur adipiscing elit. Nulla a commodo nisl. Vivamus ac orci sed urna faucibus gravida et vel nulla. Duis venenatis commodo pellentesque. Curabitur finibus est in ipsum rhoncus tristique. Donec et urna et quam vulputate dapibus. Proin lobortis ante id diam sollicitudin, varius malesuada purus pharetra. Nunc augue neque, tristique vitae turpis et, pretium pellentesque sem. Nam sed arcu quis sem sollicitudin vestibulum.\n\n* Phasellus accumsan luctus iaculis.\n* Vestibulum aliquam nisi\n* egestas scelerisque venenatis.\n1. Curabitur fringilla iaculis erat. Aenean sed dolor tellus.\n2. Cras fermentum enim\n3. sed molestie laoreet. Sed vel volutpat metus, in faucibus lorem. Etiam vel arcu posuere, cursus diam eu, egestas quam. Nullam lobortis enim nec felis imperdiet auctor.\n",
  • "language_code": "eng",
  • "published_at": "2016-02-18T07:00:00+01:00",
  • "background_color": "e4f3f8",
  • "price_per_use": 3.98,
  • "collaboration": "# **Collaboration **\n\n*Lorem ipsum *\n\ndolor sit amet, consectetur adipiscing elit. Nulla a commo\n\n* Phasellus accumsan luctus iaculis.\n* Vestibulum aliquam nisi\n* egestas scelerisque venenatis.\n1. Curabitur fringilla iaculis erat. Aenean sed dolor tellus.\n2. Cras fermentum enim\n3. sed molestie laoreet. Sed vel volutpat metus, in fauci\n",
  • "description": "# **Description **\n\n*Lorem ipsum *\n\ndolor sit amet, consectetur adipiscing elit. Nulla a commodo nisl. Vivamus ac orci sed urna faucibus gravida et vel nulla. Duis venenatis commodo pellentesque. Curabitur finibus est in ipsum rhoncus tristique. Donec et urna et quam vulputate dapibus. Proin lobortis ante id diam sollicitudin, varius malesuada purus pharetra. Nunc augue neque, tristique vitae turpis et, pretium pellentesque sem. Nam sed arcu quis sem sollicitudin vestibulum.\n\n* Phasellus accumsan luctus iaculis.\n* Vestibulum aliquam nisi\n* egestas scelerisque venenatis.\n1. Curabitur fringilla iaculis erat. Aenean sed dolor tellus.\n2. Cras fermentum enim\n3. sed molestie laoreet. Sed vel volutpat metus, in faucibus lorem. Etiam vel arcu posuere, cursus diam eu, egestas quam. Nullam lobortis enim nec felis imperdiet auctor.\n",
  • "recent_changes": "# **Recent changes **\n\n*Lorem ipsum *\n\ndolor sit amet, consectetur adipiscing elit. Nulla a commodo nisl. Vivamus ac orci sed urna faucibus gravida et vel nulla. Duis venenatis commodo pellentesque. Curabitur finibus est in ipsum rhoncus tristique. Donec et urna et quam vulputate dapibus. Proin lobortis ante id diam sollicitudin, varius malesuada purus pharetra. Nunc augue neque, tristique vitae turpis et, pretium pellentesque sem. Nam sed arcu quis sem sollicitudin vestibulum.\n\n* Phasellus accumsan luctus iaculis.\n* Vestibulum aliquam nisi\n* egestas scelerisque venenatis.\n1. Curabitur fringilla iaculis erat. Aenean sed dolor tellus.\n2. Cras fermentum enim\n3. sed molestie laoreet. Sed vel volutpat metus, in faucibus lorem. Etiam vel arcu posuere, cursus diam eu, egestas quam. Nullam lobortis enim nec felis imperdiet auctor.\n",
  • "source_references": "# **Source references **\n\n*Lorem ipsum *\n\ndolor sit amet, consectetur adipiscing elit. Nulla a commodo nisl. Vivamus ac orci sed urna faucibus gravida et vel nulla. Duis venenatis commodo pellentesque. Curabitur finibus est in ipsum rhoncus tristique. Donec et urna et quam vulputate dapibus. Proin lobortis ante id diam sollicitudin, varius malesuada purus pharetra. Nunc augue neque, tristique vitae turpis et, pretium pellentesque sem. Nam sed arcu quis sem sollicitudin vestibulum.\n\n* Phasellus accumsan luctus iaculis.\n* Vestibulum aliquam nisi\n* egestas scelerisque venenatis.\n1. Curabitur fringilla iaculis erat. Aenean sed dolor tellus.\n2. Cras fermentum enim\n3. sed molestie laoreet. Sed vel volutpat metus, in faucibus lorem. Etiam vel arcu posuere, cursus diam eu, egestas quam. Nullam lobortis enim nec felis imperdiet auctor.\n",
  • "time_indication_minimum": 3,
  • "time_indication_maximum": 4,
  • "version_major": 2,
  • "version_minor": 1,
  • "areas_of_care": [
    ],
  • "highlights": [
    ],
  • "keywords": [
    ],
  • "authors": [
    ],
  • "publishers": [
    ],
  • "focus_areas": [
    ],
  • "target_audiences": [
    ],
  • "forms_of_care": [
    ],
  • "forms_of_therapy": [
    ],
  • "suggested_start_date": "2025-04-18T08:15:21+02:00",
  • "children": [
    ]
}

Plan a plan recipe for a number of given profiles

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters

Space ID

planRecipe
required
string = 12 characters

Plan recipe ID

Request Body schema: application/json

The request should contain the profiles that the plan recipe is to be planned for. Optionally it may include a custom start date.

required
Array of objects (profile-reference)
custom_start_date
string <date-time>

Responses

Request samples

Content type
application/json
Example
{
  • "profiles": [
    ],
  • "custom_start_date": "2017-03-27T08:12:09+00:00"
}

Response samples

Content type
application/json
Example
{
  • "error": "invalid_grant",
  • "error_description": "The access token provided is invalid."
}

Set 'starred' on a plan recipe, indicating that it is marked as a favorite

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters

Space ID

planRecipe
required
string = 12 characters

Plan recipe ID

Request Body schema: application/json

The request should not contain a body

Schema not provided

Responses

Response samples

Content type
application/json
Example
{
  • "error": "invalid_grant",
  • "error_description": "The access token provided is invalid."
}

Endpoint to remove 'starred' from a plan recipe, indicating that it is not marked as a favorite.

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters

Space ID

planRecipe
required
string = 12 characters

Plan recipe ID

Responses

Response samples

Content type
application/json
Example
{
  • "error": "invalid_grant",
  • "error_description": "The access token provided is invalid."
}

Stage a plan recipe for a profile, so that it can be planned in.

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters

Space ID

profile
required
string = 12 characters

Profile ID

Request Body schema: application/json
required

The request should contain a plan recipe ID

required
object

The plan recipe to be staged for the profile

Responses

Request samples

Content type
application/json
{
  • "plan_recipe": {
    }
}

Response samples

Content type
application/json
Example
{
  • "id": "someRandomMongoDBId12345",
  • "created_at": "2013-02-09T07:00:00+01:00",
  • "plan_recipe": {
    },
  • "custom_start_date": "2013-02-09T07:00:00+01:00"
}

plan-recipe-image

Plan Recipe Image

Returns the plan recipe image with the provided id

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

planRecipe
required
string = 12 characters
Examples:
  • 8727a54b25c0 - Example of a plan recipe ID

Plan Recipe ID

upload
required
string = 24 characters
Examples:
  • 65390948afa91779d4185665 - Example of an upload ID

Upload ID

Responses

Response samples

Content type
image/svg+xml


plan-recipe-user-guide

Plan Recipe User Guide

Returns the plan recipe user guide with the provided id

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

planRecipe
required
string = 12 characters
Examples:
  • 8727a54b25c0 - Example of a plan recipe ID

Plan Recipe ID

upload
required
string = 24 characters
Examples:
  • 779d41850948afa916656539 - Example of an upload ID

Upload ID

Responses

Response samples

Content type
application/pdf
data:application/pdf;base64,JVBERi0xLjEKJcKlwrHDqwoKMSAwIG9iagogIDw8IC9UeXBlIC9DYXRhbG9nCiAgICAgL1BhZ2VzIDIgMCBSCiAgPj4KZW5kb2JqCgoyIDAgb2JqCiAgPDwgL1R5cGUgL1BhZ2VzCiAgICAgL0tpZHMgWzMgMCBSXQogICAgIC9Db3VudCAxCiAgICAgL01lZGlhQm94IFswIDAgMzAwIDE0NF0KICA+PgplbmRvYmoKCjMgMCBvYmoKICA8PCAgL1R5cGUgL1BhZ2UKICAgICAgL1BhcmVudCAyIDAgUgogICAgICAvUmVzb3VyY2VzCiAgICAgICA8PCAvRm9udAogICAgICAgICAgIDw8IC9GMQogICAgICAgICAgICAgICA8PCAvVHlwZSAvRm9udAogICAgICAgICAgICAgICAgICAvU3VidHlwZSAvVHlwZTEKICAgICAgICAgICAgICAgICAgL0Jhc2VGb250IC9UaW1lcy1Sb21hbgogICAgICAgICAgICAgICA+PgogICAgICAgICAgID4+CiAgICAgICA+PgogICAgICAvQ29udGVudHMgNCAwIFIKICA+PgplbmRvYmoKCjQgMCBvYmoKICA8PCAvTGVuZ3RoIDU1ID4+CnN0cmVhbQogIEJUCiAgICAvRjEgMTggVGYKICAgIDAgMCBUZAogICAgKEhlbGxvIFdvcmxkKSBUagogIEVUCmVuZHN0cmVhbQplbmRvYmoKCnhyZWYKMCA1CjAwMDAwMDAwMDAgNjU1MzUgZiAKMDAwMDAwMDAxOCAwMDAwMCBuIAowMDAwMDAwMDc3IDAwMDAwIG4gCjAwMDAwMDAxNzggMDAwMDAgbiAKMDAwMDAwMDQ1NyAwMDAwMCBuIAp0cmFpbGVyCiAgPDwgIC9Sb290IDEgMCBSCiAgICAgIC9TaXplIDUKICA+PgpzdGFydHhyZWYKNTY1CiUlRU9GCg==

planned-items

Planned Items

Archive a planned item

beta

Authorizations:
oauth2
path Parameters
plannedItem
required
string = 12 characters
Examples:
  • 0636e3e66b2f - Example of a planned item ID

Planned item ID

Responses

Response samples

Content type
application/json
Example
{
  • "error": "invalid_grant",
  • "error_description": "The access token provided is invalid."
}

Unarchive a planned item

beta

Authorizations:
oauth2
path Parameters
plannedItem
required
string = 12 characters
Examples:
  • 0636e3e66b2f - Example of a planned item ID

Planned item ID

Responses

Response samples

Content type
application/json
Example
{
  • "error": "invalid_grant",
  • "error_description": "The access token provided is invalid."
}

plugin

Plugin

Returns metadata for the minddistrict plugin in the given space.

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters

Space ID

Responses

Response samples

Content type
application/json
Example
{
  • "title": "eHealth via Minddistrict",
  • "description": "You can use Minddistrict to perform eHealth assignments.",
  • "menu_title": "eHealth",
  • "button_label": "Go to eHealth"
}

Returns the SSO URL to login in minddistrict for the current user for the given space.

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters

Space ID

Responses

Returns the RoQua ROM questionnaires for the current user in the RoQua environment associated with the given space.

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters

Space ID

query Parameters
status
string
Enum: "open" "completed" "scheduled" "aborted"

Filter questionnaires by status

string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of questionnaires to return (defaults to 10)

string or integer
Examples:
  • offset=10 - Example of an offset value as a string
  • offset=25 - Example of an offset value as an integer

Index of first questionnaire to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
Example
{
  • "offset": 0,
  • "limit": 10,
  • "total_count": 0,
  • "collection": [ ]
}

profiles

A profile connects an Karify account to a Healthspace. Profiles therefore can be seen as a Healthspace's membership. Each profile endpoint needs its own scope and role permissions. An application can use the scope MANAGE_SPACE_PROFILES and MANAGE_ORGANIZATION_PROFILES to use all (..._READ, ..._UPDATEand ..._UNSUBSCRIBE) scopes in one scope.

Get profiles of user's organization

Get all profiles or filter within profiles of the authenticated user's organization based on some optional parameters.

Scope The scope ORGANIZATION_PROFILE_READ is needed for this endpoint.

Role The authenticated user should have the role ROLE_ACCOUNT_SPACE_OWNER.

Parameters The following optional parameters can be given to filter the results on.

Authorizations:
oauth2
query Parameters
birthday
string <date>
Example: birthday=1970-03-27

Filters the result by birthday

identificationNumber
string
Example: identificationNumber=client1234

Filters the result by identificationNumber

Responses

Response samples

Content type
application/json
{
  • "collection": [
    ],
  • "limit": 10,
  • "offset": 0,
  • "total_count": 2
}

Get a collection of profiles of a space

Get all profiles or filter within profiles of the specified Healthspace filtered on some optional parameters.

Scope The scope SPACE_PROFILE_READ is needed for this endpoint.

Role The authenticated user should have the role ROLE_SPACE_MEMBER_MANAGER which is part of the group assistants.

Parameters See the PARAMS section below to see on which parameters the collection.

Authorizations:
oauth2
path Parameters
space
required
string
Example: 4361b17b37c9

Space id

query Parameters
identificationNumber
string
Example: identificationNumber=77515b15d6bf

Filters the collection result by identificationNumber (string)

birthday
string <date>
Example: birthday=1979-01-05

Filters the collection result by birthday (yyyy-mm-dd)

account
string
Example: account=a2b75d614ef1

Filters the collection result by account_id (string)

user_type
string
Enum: "staff" "client"

Filters the collection result by user_type

string or integer

Starts the collection result at the provided item (default: 0)

string or integer

Limits the collection result by the provided amount of items (default: 10)

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [ ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 0
}

public-profiles

Public Profiles

Get a collection of all active staff accounts are set to visible for the provided space

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [ ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 0
}

record

My Record

Returns all of the Files in the current user's Record

beta

Authorizations:
oauth2

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [ ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 0
}

space

Space

Returns a collection of all spaces that belong to the organization of the organization owner that is logged in

Returns a collection of spaces the organization the currently authenticated user is owner of.

Scope The access_token should have the scope ORGANIZATION_SPACE_READ for this endpoint.

Role The authenticated user should have the role ROLE_ACCOUNT_SPACE_OWNER.

Authorizations:
oauth2
query Parameters
string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of spaces to return (defaults to 10)

string or integer
Examples:
  • offset=10 - Example of an offset value as a string
  • offset=25 - Example of an offset value as an integer

Index of first space to be returned (defaults to 0)

Responses

Response samples

Content type
application/json
{
  • "collection": [
    ],
  • "offset": 0,
  • "limit": 10,
  • "total_count": 2
}

Returns the space with the provided id or alias

Returns a specific space by id or by alias.

Note that when requesting by alias you must use alias: before the alias.

The alias of a healthspace is used as part of the URL before .karify.com, so the structure is https://{{space_alias}}.karify.com.

Scope

No specific scope in the access_token is needed for this endpoint.

Role

No specific role is needed for the authenticated user using this endpoint.

Authorizations:
oauth2cookie
path Parameters
required
string or string

Space ID or alias

Responses

Response samples

Content type
application/json
Example
{
  • "id": "bewegenspace",
  • "alias": "bewegen-is-vooruitgaan",
  • "name": "Bewegen is vooruitgaan",
  • "description": "Join deze space als je in de buurt van Amsterdam woont en een afspraak wil maken. Je kunt zo ook makkelijk je dossier bijhouden en doelen voor jezelf aanmaken etc.",
  • "treatments": "Fysiotherapy - Haptonomy",
  • "subscription_type": "allowed",
  • "organization": {
    },
  • "timezone": "Europe/Amsterdam",
  • "opening_hours_status": "show-hours",
  • "preferred_locale": "nl",
  • "is_global": false,
  • "enabled": true,
  • "time_slots": [
    ],
  • "created_at": "2013-02-11T11:00:00+01:00",
  • "updated_at": "2021-04-15T16:37:22+02:00"
}

space-theme

Space Theme

Returns the theme for the provided space

Returns the theme of a given space.

Scope

No specific scope in the access_token is needed for this endpoint.

Role

No specific role is needed for the authenticated user using this endpoint.

Authorizations:
oauth2cookie
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

Responses

Response samples

Content type
application/json
Example
{}

Returns the background image for the provided space

Authorizations:
oauth2cookie
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

cacheBust
required
string [ 1 .. 12 ] characters
Examples:
  • 1729779718 - Example of a cache busting value

Cache busting value. Normally the timestamp of when the space theme was last updated.

Responses

Response samples

Content type


Returns the icon for the provided space

Authorizations:
oauth2cookie
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

cacheBust
required
string [ 1 .. 12 ] characters
Examples:
  • 1729779718 - Example of a cache busting value

Cache busting value. Normally the timestamp of when the space theme was last updated.

Responses

Response samples

Content type
No sample

user-questionnaires

User Questionnaires

Get all available USER questionnaires for the logged in client from the organization of the healthspace, ordered by name and creation date

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

query Parameters
string or integer
Examples:
  • limit=4 - Example of a limit value as a string
  • limit=9 - Example of a limit value as an integer

Maximum number of Questionnaires to return (defaults to 10)

string or integer
Examples:
  • offset=10 - Example of an offset value as a string
  • offset=25 - Example of an offset value as an integer

Index of first Questionnaires to be returned (defaults to 0)

status[]
Array of strings
Items Enum: "CREATED" "IN_PROGRESS" "REVIEW" "FINAL"
Examples:
  • status[]=IN_PROGRESS - Example of filtering by a single status
  • status[]=CREATED&status[]=FINAL - Example of filtering by multiple statuses

Filter the collection of questionnaires based on the given status or statuses

Responses

Response samples

Content type
application/json
Example
{
  • "collection": [
    ],
  • "offset": 0,
  • "limit": 1,
  • "total_count": 1
}

Get a single USER questionnaire

beta

Authorizations:
oauth2
path Parameters
space
required
string = 12 characters
Examples:
  • 4361b17b37c9 - Example of a space ID

Space ID

questionnaire
required
string [ 3 .. 255 ] characters
Examples:
  • ROM_12345 - Example of a questionnaire ID

Questionnaire ID

Responses

Response samples

Content type
application/json
Example

A ROM questionnaire that has been created and does not have any answers yet filled in

{
  • "id": "ROM_1212",
  • "description": "Questionnaire 1",
  • "type": "ROM",
  • "status": "CREATED",
  • "progress": 0,
  • "json_schema": {
    },
  • "json_ui_schema": {
    },
  • "created_at": "2021-01-01T00:00:00Z"
}