Knock Tenants API
Manage Tenants — the top-level accounts or workspaces in your product. Tenants power tenant-scoped branding, preferences, and message-targeting.
Manage Tenants — the top-level accounts or workspaces in your product. Tenants power tenant-scoped branding, preferences, and message-targeting.
openapi: 3.0.3
info:
title: Knock Tenants API
version: '1.0'
description: Manage Tenants — the top-level accounts or workspaces in your product. Tenants power tenant-scoped branding,
preferences, and message-targeting.
contact:
name: Knock
url: https://knock.app
license:
name: Proprietary
servers:
- url: https://api.knock.app
variables: {}
security:
- BearerAuth: []
paths:
/v1/tenants/{id}:
delete:
callbacks: {}
description: Delete a tenant and all associated data. This operation cannot be undone.
operationId: deleteTenant
parameters:
- description: The unique identifier for the tenant.
in: path
name: id
required: true
schema:
type: string
x-struct: null
x-validate: null
responses:
'204':
description: No Content
summary: Delete a tenant
tags:
- Tenants
x-ratelimit-tier: 2
get:
callbacks: {}
description: Get a tenant by ID.
operationId: getTenant
parameters:
- description: The unique identifier for the tenant.
in: path
name: id
required: true
schema:
type: string
x-struct: null
x-validate: null
- description: When true, merges environment-level default preferences into the tenant's `settings.preference_set` field
before returning the response. Defaults to false.
in: query
name: resolve_full_preference_settings
required: false
schema:
type: boolean
x-struct: null
x-validate: null
responses:
'200':
content:
application/json:
schema:
$ref: '#/components/schemas/Tenant'
description: OK
summary: Get a tenant
tags:
- Tenants
x-ratelimit-tier: 4
put:
callbacks: {}
description: Sets a tenant within an environment, performing an upsert operation. Any existing properties will be merged
with the incoming properties.
operationId: setTenant
parameters:
- description: The unique identifier for the tenant.
in: path
name: id
required: true
schema:
type: string
x-struct: null
x-validate: null
- description: When true, merges environment-level default preferences into the tenant's `settings.preference_set` field
before returning the response. Defaults to false.
in: query
name: resolve_full_preference_settings
required: false
schema:
type: boolean
x-struct: null
x-validate: null
requestBody:
content:
application/json:
example:
name: Jurassic Park
settings:
branding:
icon_url: https://example.com/trex_silhouette_icon.png
logo_url: https://example.com/amber_fossil_logo.png
primary_color: '#DF1A22'
primary_color_contrast: '#FFDE00'
schema:
$ref: '#/components/schemas/SetTenantRequest'
description: Tenant
required: true
responses:
'200':
content:
application/json:
schema:
$ref: '#/components/schemas/SetTenantResponse'
description: OK
summary: Set a tenant
tags:
- Tenants
x-ratelimit-tier: 3
/v1/tenants:
get:
callbacks: {}
description: List tenants for the current environment.
operationId: listTenants
parameters:
- description: Filter tenants by ID.
in: query
name: tenant_id
required: false
schema:
type: string
x-struct: null
x-validate: null
- description: Filter tenants by name.
in: query
name: name
required: false
schema:
type: string
x-struct: null
x-validate: null
- description: The cursor to fetch entries after.
in: query
name: after
required: false
schema:
type: string
x-struct: null
x-validate: null
- description: The cursor to fetch entries before.
in: query
name: before
required: false
schema:
type: string
x-struct: null
x-validate: null
- description: The number of items per page (defaults to 50).
in: query
name: page_size
required: false
schema:
type: integer
x-struct: null
x-validate: null
responses:
'200':
content:
application/json:
schema:
$ref: '#/components/schemas/ListTenantsResponse'
description: OK
summary: List tenants
tags:
- Tenants
x-ratelimit-tier: 4
/v1/tenants/bulk/delete:
post:
callbacks: {}
description: Delete up to 1,000 tenants at a time in a single operation. This operation cannot be undone.
operationId: bulkDeleteTenants
parameters:
- description: The IDs of the tenants to delete.
in: query
name: tenant_ids[]
required: true
schema:
items:
type: string
x-struct: null
x-validate: null
type: array
x-struct: null
x-validate: null
responses:
'200':
content:
application/json:
schema:
$ref: '#/components/schemas/BulkOperation'
description: OK
summary: Bulk delete tenants
tags:
- Tenants
- Bulk operations
x-ratelimit-tier: 1
/v1/tenants/bulk/set:
post:
callbacks: {}
description: Set or update up to 1,000 tenants in a single operation.
operationId: bulkSetTenants
parameters: []
requestBody:
content:
application/json:
example:
tenants:
- id: tenant_1
name: Acme Corp, Inc.
schema:
$ref: '#/components/schemas/BulkSetTenantsRequest'
description: Params
required: true
responses:
'200':
content:
application/json:
schema:
$ref: '#/components/schemas/BulkOperation'
description: OK
summary: Bulk set tenants
tags:
- Tenants
- Bulk operations
x-ratelimit-tier: 1
components:
securitySchemes:
BearerAuth:
type: http
scheme: bearer
description: Knock API key as a Bearer token. Use a public key (pk_...) for client-side requests or a secret key (sk_...)
for server-side.
schemas:
ListTenantsResponse:
description: A response containing a list of tenants.
example:
entries:
- __typename: Tenant
id: tenant_jp123
name: Jurassic Park
settings:
branding:
icon_url: https://example.com/trex_silhouette_icon.png
logo_url: https://example.com/amber_fossil_logo.png
primary_color: '#DF1A22'
primary_color_contrast: '#FFDE00'
preference_set:
categories:
safety:
channel_types:
email: true
push: true
channel_types:
email: true
in_app_feed: true
push: true
id: default
workflows:
park_alert:
channel_types:
email: true
push: true
page_info:
__typename: PageInfo
after: null
before: null
page_size: 25
properties:
entries:
description: A list of tenants.
items:
$ref: '#/components/schemas/Tenant'
type: array
x-struct: null
x-validate: null
page_info:
$ref: '#/components/schemas/PageInfo'
required:
- entries
- page_info
title: ListTenantsResponse
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.ListTenantsResponse
x-validate: null
PageInfo:
description: Pagination information for a list of resources.
example:
__typename: PageInfo
after: null
before: null
page_size: 25
properties:
__typename:
description: The typename of the schema.
example: PageInfo
type: string
x-struct: null
x-validate: null
after:
description: The cursor to fetch entries after.
nullable: true
type: string
x-struct: null
x-validate: null
before:
description: The cursor to fetch entries before.
nullable: true
type: string
x-struct: null
x-validate: null
page_size:
description: The number of items per page (defaults to 50).
type: integer
x-struct: null
x-validate: null
required:
- __typename
- page_size
title: PageInfo
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.PageInfo
x-validate: null
Tenant:
additionalProperties: true
description: A tenant entity.
example:
__typename: Tenant
id: tenant_jp123
name: Jurassic Park
settings:
branding:
icon_url: https://example.com/trex_silhouette_icon.png
logo_url: https://example.com/amber_fossil_logo.png
primary_color: '#DF1A22'
primary_color_contrast: '#FFDE00'
preference_set:
categories:
safety:
channel_types:
email: true
push: true
channel_types:
email: true
in_app_feed: true
push: true
id: default
workflows:
park_alert:
channel_types:
email: true
push: true
properties:
__typename:
description: The typename of the schema.
example: Tenant
type: string
x-struct: null
x-validate: null
id:
description: The unique identifier for the tenant.
nullable: false
type: string
x-struct: null
x-validate: null
name:
description: An optional name for the tenant.
nullable: true
type: string
x-struct: null
x-validate: null
settings:
description: The settings for the tenant. Includes branding and preference set.
nullable: true
properties:
branding:
description: The branding for the tenant.
nullable: true
properties:
icon_url:
description: The icon URL for the tenant. Must point to a valid image with an image MIME type.
example: https://example.com/trex_silhouette_icon.png
format: uri
nullable: true
type: string
x-struct: null
x-validate: null
logo_url:
description: The logo URL for the tenant. Must point to a valid image with an image MIME type.
example: https://example.com/amber_fossil_logo.png
format: uri
nullable: true
type: string
x-struct: null
x-validate: null
primary_color:
description: The primary color for the tenant, provided as a hex value.
example: '#DF1A22'
nullable: true
type: string
x-struct: null
x-validate: null
primary_color_contrast:
description: The primary color contrast for the tenant, provided as a hex value.
example: '#FFDE00'
nullable: true
type: string
x-struct: null
x-validate: null
type: object
x-struct: null
x-validate: null
preference_set:
anyOf:
- $ref: '#/components/schemas/PreferenceSet'
- nullable: true
x-struct: null
x-validate: null
description: The preference set for the tenant. Used to override the default preference set.
x-struct: null
x-validate: null
type: object
x-struct: null
x-validate: null
required:
- __typename
- id
title: Tenant
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.Tenant
x-validate: null
PreferenceSet:
description: A preference set represents a specific set of notification preferences for a recipient. A recipient can
have multiple preference sets.
example:
categories:
marketing: false
transactional:
channel_types:
email: false
channel_types:
email: true
push: false
sms:
conditions:
- argument: US
operator: equal_to
variable: recipient.country_code
commercial_subscribed: true
id: default
workflows: null
properties:
categories:
anyOf:
- additionalProperties:
$ref: '#/components/schemas/PreferenceSetWorkflowCategorySetting'
description: An object where the key is the category and the values are the preference settings for that category.
example:
marketing:
channel_types:
email: false
title: PreferenceSetCategories
type: object
x-struct: null
x-validate: null
- nullable: true
x-struct: null
x-validate: null
description: An object where the key is the category and the values are the preference settings for that category.
x-struct: null
x-validate: null
channel_types:
anyOf:
- $ref: '#/components/schemas/PreferenceSetChannelTypes'
- nullable: true
x-struct: null
x-validate: null
description: An object where the key is the channel type and the values are the preference settings for that channel
type.
x-struct: null
x-validate: null
channels:
anyOf:
- $ref: '#/components/schemas/PreferenceSetChannels'
- nullable: true
x-struct: null
x-validate: null
description: An object where the key is the channel ID and the values are the preference settings for that channel
ID.
x-struct: null
x-validate: null
commercial_subscribed:
description: Whether the recipient is subscribed to commercial communications. When false, the recipient will not
receive commercial workflow notifications.
nullable: true
type: boolean
x-struct: null
x-validate: null
id:
description: Unique identifier for the preference set.
example: default
type: string
x-struct: null
x-validate: null
workflows:
anyOf:
- additionalProperties:
$ref: '#/components/schemas/PreferenceSetWorkflowCategorySetting'
description: An object where the key is the workflow key and the values are the preference settings for that workflow.
example:
dinosaurs-loose:
channel_types:
email: false
title: PreferenceSetWorkflows
type: object
x-struct: null
x-validate: null
- nullable: true
x-struct: null
x-validate: null
description: An object where the key is the workflow key and the values are the preference settings for that workflow.
x-struct: null
x-validate: null
required:
- id
title: PreferenceSet
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.PreferenceSet
x-validate: null
PreferenceSetWorkflowCategorySetting:
description: Workflow or category preferences within a preference set
example:
channel_types:
email: false
channels:
aef6e715-df82-4ab6-b61e-b743e249f7b6: true
oneOf:
- example: false
type: boolean
x-struct: null
x-validate: null
- description: The settings object for a workflow or category, where you can specify channel types or conditions.
example:
channel_types:
email: false
channels:
aef6e715-df82-4ab6-b61e-b743e249f7b6: true
conditions: null
properties:
channel_types:
anyOf:
- $ref: '#/components/schemas/PreferenceSetChannelTypes'
- nullable: true
x-struct: null
x-validate: null
description: An object where the key is the channel type and the values are the preference settings for that channel
type.
x-struct: null
x-validate: null
channels:
anyOf:
- $ref: '#/components/schemas/PreferenceSetChannels'
- nullable: true
x-struct: null
x-validate: null
description: An object where the key is the channel ID and the values are the preference settings for that channel
ID.
x-struct: null
x-validate: null
conditions:
description: A list of conditions to apply to a channel type.
items:
$ref: '#/components/schemas/Condition'
nullable: true
type: array
x-struct: null
x-validate: null
title: PreferenceSetWorkflowCategorySettingObject
type: object
x-struct: null
x-validate: null
title: PreferenceSetWorkflowCategorySetting
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.PreferenceSetWorkflowCategorySetting
x-validate: null
Condition:
description: A condition to be evaluated.
example:
argument: frog_genome
operator: contains
variable: specimen.dna_sequence
properties:
argument:
description: The argument value to compare against in the condition.
example: some_property
nullable: true
type: string
x-struct: null
x-validate: null
operator:
description: The operator to use in the condition evaluation.
enum:
- equal_to
- not_equal_to
- greater_than
- less_than
- greater_than_or_equal_to
- less_than_or_equal_to
- contains
- not_contains
- empty
- not_empty
- exists
- not_exists
- contains_all
- is_timestamp
- is_not_timestamp
- is_timestamp_on_or_after
- is_timestamp_before
- is_timestamp_on_or_after_date
- is_timestamp_before_date
- is_timestamp_between
- is_between
- is_audience_member
- is_not_audience_member
example: equal_to
type: string
x-struct: null
x-validate: null
variable:
description: The variable to be evaluated in the condition.
example: recipient.property
type: string
x-struct: null
x-validate: null
required:
- variable
- operator
- argument
title: Condition
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.Condition
x-validate: null
PreferenceSetChannels:
additionalProperties:
description: Whether the specific channel (by channel_id) is enabled for the preference set, or a settings object
with conditions.
oneOf:
- type: boolean
x-struct: null
x-validate: null
- $ref: '#/components/schemas/PreferenceSetChannelSetting'
x-struct: null
x-validate: null
description: Channel preferences.
example:
2f641633-95d3-4555-9222-9f1eb7888a80:
conditions:
- argument: US
operator: equal_to
variable: recipient.country_code
aef6e715-df82-4ab6-b61e-b743e249f7b6: true
title: PreferenceSetChannels
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.PreferenceSetChannels
x-validate: null
PreferenceSetChannelSetting:
description: A set of settings for a specific channel. Currently, this can only be a list of conditions to apply.
example:
conditions:
- argument: US
operator: equal_to
variable: recipient.country_code
properties:
conditions:
description: A list of conditions to apply to a specific channel.
items:
$ref: '#/components/schemas/Condition'
type: array
x-struct: null
x-validate: null
required:
- conditions
title: PreferenceSetChannelSetting
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.PreferenceSetChannels.PreferenceSetChannelSetting
x-validate: null
PreferenceSetChannelTypes:
description: Channel type preferences.
example:
email: true
sms:
conditions:
- argument: US
operator: equal_to
variable: recipient.country_code
properties:
chat:
description: Whether the channel type is enabled for the preference set.
oneOf:
- type: boolean
x-struct: null
x-validate: null
- $ref: '#/components/schemas/PreferenceSetChannelTypeSetting'
x-struct: null
x-validate: null
email:
description: Whether the channel type is enabled for the preference set.
oneOf:
- type: boolean
x-struct: null
x-validate: null
- $ref: '#/components/schemas/PreferenceSetChannelTypeSetting'
x-struct: null
x-validate: null
http:
description: Whether the channel type is enabled for the preference set.
oneOf:
- type: boolean
x-struct: null
x-validate: null
- $ref: '#/components/schemas/PreferenceSetChannelTypeSetting'
x-struct: null
x-validate: null
in_app_feed:
description: Whether the channel type is enabled for the preference set.
oneOf:
- type: boolean
x-struct: null
x-validate: null
- $ref: '#/components/schemas/PreferenceSetChannelTypeSetting'
x-struct: null
x-validate: null
push:
description: Whether the channel type is enabled for the preference set.
oneOf:
- type: boolean
x-struct: null
x-validate: null
- $ref: '#/components/schemas/PreferenceSetChannelTypeSetting'
x-struct: null
x-validate: null
sms:
description: Whether the channel type is enabled for the preference set.
oneOf:
- type: boolean
x-struct: null
x-validate: null
- $ref: '#/components/schemas/PreferenceSetChannelTypeSetting'
x-struct: null
x-validate: null
title: PreferenceSetChannelTypes
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.PreferenceSetChannelTypes
x-validate: null
PreferenceSetChannelTypeSetting:
description: A set of settings for a channel type. Currently, this can only be a list of conditions to apply.
example:
conditions:
- argument: US
operator: equal_to
variable: recipient.country_code
properties:
conditions:
description: A list of conditions to apply to a channel type.
items:
$ref: '#/components/schemas/Condition'
type: array
x-struct: null
x-validate: null
required:
- conditions
title: PreferenceSetChannelTypeSetting
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.PreferenceSetChannelTypes.PreferenceSetChannelTypeSetting
x-validate: null
SetTenantRequest:
additionalProperties: true
description: A tenant to be set in the system. You can supply any additional properties on the tenant object.
example:
name: Jurassic Park
settings:
branding:
icon_url: https://example.com/trex_silhouette_icon.png
logo_url: https://example.com/amber_fossil_logo.png
primary_color: '#DF1A22'
primary_color_contrast: '#FFDE00'
properties:
channel_data:
description: The channel data for the tenant.
oneOf:
- nullable: true
x-struct: null
x-validate: null
- $ref: '#/components/schemas/InlineChannelDataRequest'
x-struct: null
x-validate: null
name:
description: An optional name for the tenant.
nullable: true
type: string
x-struct: null
x-validate: null
settings:
description: The settings for the tenant. Includes branding and preference set.
properties:
branding:
description: The branding for the tenant.
properties:
icon_url:
description: The icon URL for the tenant. Must point to a valid image with an image MIME type.
nullable: true
type: string
x-struct: null
x-validate: null
logo_url:
description: The logo URL for the tenant. Must point to a valid image with an image MIME type.
nullable: true
type: string
x-struct: null
x-validate: null
primary_color:
description: The primary color for the tenant, provided as a hex value.
nullable: true
type: string
x-struct: null
x-validate: null
primary_color_contrast:
description: The primary color contrast for the tenant, provided as a hex value.
nullable: true
type: string
x-struct: null
x-validate: null
type: object
x-struct: null
x-validate: null
preference_set:
description: The preference set for the tenant. Used to override the default preference set.
oneOf:
- nullable: true
x-struct: null
x-validate: null
- $ref: '#/components/schemas/PreferenceSetRequest'
x-struct: null
x-validate: null
type: object
x-struct: null
x-validate: null
title: SetTenantRequest
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.SetTenantRequest
x-validate: null
PreferenceSetRequest:
description: A request to set a preference set for a recipient.
example:
__persistence_strategy__: merge
categories:
marketing: false
transactional:
channel_types:
email: false
channel_types:
email: true
channels:
2f641633-95d3-4555-9222-9f1eb7888a80:
conditions:
- argument: US
operator: equal_to
variable: recipient.country_code
aef6e715-df82-4ab6-b61e-b743e249f7b6: true
commercial_subscribed: true
workflows:
dinosaurs-loose:
channel_types:
email: false
properties:
__persistence_strategy__:
description: Controls how the preference set is persisted. 'replace' will completely replace the preference set,
'merge' will merge with existing preferences.
enum:
- merge
- replace
type: string
x-struct: null
x-validate: null
categories:
anyOf:
- additionalProperties:
$ref: '#/components/schemas/PreferenceSetWorkflowCategorySetting'
description: An object where the key is the category and the values are the preference settings for that category.
example:
marketing:
channel_types:
email: false
transactional: true
title: PreferenceSetRequestCategories
type: object
x-struct: null
x-validate: null
- nullable: true
x-struct: null
x-validate: null
description: An object where the key is the category and the values are the preference settings for that category.
x-struct: null
x-validate: null
channel_types:
anyOf:
- $ref: '#/components/schemas/PreferenceSetChannelTypes'
- nullable: true
x-struct: null
x-validate: null
description: An object where the key is the channel type and the values are the preference settings for that channel
type.
x-struct: null
x-validate: null
channels:
anyOf:
- $ref: '#/components/schemas/PreferenceSetChannels'
- nullable: true
x-struct: null
x-validate: null
description: An object where the key is the channel ID and the values are the preference settings for that channel
ID.
x-struct: null
x-validate: null
commercial_subscribed:
description: Whether the recipient is subscribed to commercial communications. When false, the recipient will not
receive commercial workflow notifications.
nullable: true
type: boolean
x-struct: null
x-validate: null
workflows:
anyOf:
- additionalProperties:
$ref: '#/components/schemas/PreferenceSetWorkflowCategorySetting'
description: An object where the key is the workflow key and the values are the preference settings for that workflow.
example:
dinosaurs-loose:
channel_types:
email: false
sms: true
welcome-sequence: true
title: PreferenceSetRequestWorkflows
type: object
x-struct: null
x-validate: null
- nullable: true
x-struct: null
x-validate: null
description: An object where the key is the workflow key and the values are the preference settings for that workflow.
x-struct: null
x-validate: null
title: PreferenceSetRequest
type: object
x-struct: Elixir.SwitchboardWeb.V1.Specs.PreferenceSetRequest
x-validate: null
InlineChannelDataRequest:
additionalProperties:
description: Channel data for a given channel type.
nullable: false
oneOf:
- $ref: '#/components/schemas/PushChannelDataTokensOnly'
- $ref: '#/components/schemas/PushChannelDataDevicesOnly'
- $ref: '#/components/schemas/AWSSNSPushChannelDataTargetARNsOnly'
- $ref: '#/components/schemas/AWSSNSPushChannelDataDevicesOnly'
- $ref: '#/components/schemas/OneSignalChannelDataPlayerIdsOnly'
- $ref: '#/components/schemas/SlackChannelData'
- $ref: '#/components/schemas/MsTeamsChannelData'
- $ref: '#/components/schemas/DiscordChannelData'
# --- truncated at 32 KB (57 KB total) ---
# Full source: https://raw.githubusercontent.com/api-evangelist/knock-app/refs/heads/main/openapi/knock-tenants-api-openapi.yml