API reference
Register a new client
Register a new client with ToolHive
Request Body schema: application/jsonrequired
Client to register
| groups | Array of strings Groups is the list of groups configured on the client. | 
| name | string Name is the type of the client to register. | 
Responses
Request samples
- Payload
{- "groups": [- "string"
 ],
- "name": "string"
}Response samples
- 200
- 400
{- "groups": [- "string"
 ],
- "name": "string"
}Register multiple clients
Register multiple clients with ToolHive
Request Body schema: application/jsonrequired
Clients to register
| groups | Array of strings Groups is the list of groups configured on the client. | 
| names | Array of strings Names is the list of client names to operate on. | 
Responses
Request samples
- Payload
{- "groups": [- "string"
 ],
- "names": [- "string"
 ]
}Response samples
- 200
- 400
[- {- "groups": [- "string"
 ],
- "name": "string"
 }
]Unregister multiple clients
Unregister multiple clients from ToolHive
Request Body schema: application/jsonrequired
Clients to unregister
| groups | Array of strings Groups is the list of groups configured on the client. | 
| names | Array of strings Names is the list of client names to operate on. | 
Responses
Request samples
- Payload
{- "groups": [- "string"
 ],
- "names": [- "string"
 ]
}Response samples
- 400
"string"Create a new group
Create a new group with the specified name
Request Body schema: application/jsonrequired
Group creation request
| name | string Name of the group to create | 
Responses
Request samples
- Payload
{- "name": "string"
}Response samples
- 201
- 400
- 409
- 500
{- "name": "string"
}Get a registry
Get details of a specific registry
path Parameters
| name required | string Registry name | 
Responses
Response samples
- 200
- 404
{- "last_updated": "string",
- "name": "string",
- "registry": {- "groups": [- {- "description": "string",
- "name": "string",
- "remote_servers": {- "property1": {- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "headers": [- {- "choices": [- "string"
 ],
- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "oauth_config": {- "authorize_url": "string",
- "callback_port": 0,
- "client_id": "string",
- "issuer": "string",
- "oauth_params": {- "property1": "string",
- "property2": "string"
 },
- "scopes": [- "string"
 ],
- "token_url": "string",
- "use_pkce": true
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string",
- "url": "string"
 },
- "property2": {- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "headers": [- {- "choices": [- "string"
 ],
- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "oauth_config": {- "authorize_url": "string",
- "callback_port": 0,
- "client_id": "string",
- "issuer": "string",
- "oauth_params": {- "property1": "string",
- "property2": "string"
 },
- "scopes": [- "string"
 ],
- "token_url": "string",
- "use_pkce": true
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string",
- "url": "string"
 }
 },
- "servers": {- "property1": {- "args": [- "string"
 ],
- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "docker_tags": [- "string"
 ],
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "image": "string",
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "permissions": {- "name": "string",
- "network": {- "inbound": {- "allow_host": [- null
 ]
 },
- "outbound": {- "allow_host": [- null
 ],
- "allow_port": [- null
 ],
- "insecure_allow_all": true
 }
 },
- "privileged": true,
- "read": [- "string"
 ],
- "write": [- "string"
 ]
 },
- "provenance": {- "attestation": {- "predicate": null,
- "predicate_type": "string"
 },
- "cert_issuer": "string",
- "repository_ref": "string",
- "repository_uri": "string",
- "runner_environment": "string",
- "signer_identity": "string",
- "sigstore_url": "string"
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "target_port": 0,
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string"
 },
- "property2": {- "args": [- "string"
 ],
- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "docker_tags": [- "string"
 ],
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "image": "string",
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "permissions": {- "name": "string",
- "network": {- "inbound": {- "allow_host": [- null
 ]
 },
- "outbound": {- "allow_host": [- null
 ],
- "allow_port": [- null
 ],
- "insecure_allow_all": true
 }
 },
- "privileged": true,
- "read": [- "string"
 ],
- "write": [- "string"
 ]
 },
- "provenance": {- "attestation": {- "predicate": null,
- "predicate_type": "string"
 },
- "cert_issuer": "string",
- "repository_ref": "string",
- "repository_uri": "string",
- "runner_environment": "string",
- "signer_identity": "string",
- "sigstore_url": "string"
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "target_port": 0,
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string"
 }
 }
 }
 ],
- "last_updated": "string",
- "remote_servers": {- "property1": {- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "headers": [- {- "choices": [- "string"
 ],
- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "oauth_config": {- "authorize_url": "string",
- "callback_port": 0,
- "client_id": "string",
- "issuer": "string",
- "oauth_params": {- "property1": "string",
- "property2": "string"
 },
- "scopes": [- "string"
 ],
- "token_url": "string",
- "use_pkce": true
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string",
- "url": "string"
 },
- "property2": {- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "headers": [- {- "choices": [- "string"
 ],
- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "oauth_config": {- "authorize_url": "string",
- "callback_port": 0,
- "client_id": "string",
- "issuer": "string",
- "oauth_params": {- "property1": "string",
- "property2": "string"
 },
- "scopes": [- "string"
 ],
- "token_url": "string",
- "use_pkce": true
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string",
- "url": "string"
 }
 },
- "servers": {- "property1": {- "args": [- "string"
 ],
- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "docker_tags": [- "string"
 ],
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "image": "string",
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "permissions": {- "name": "string",
- "network": {- "inbound": {- "allow_host": [- "string"
 ]
 },
- "outbound": {- "allow_host": [- "string"
 ],
- "allow_port": [- 0
 ],
- "insecure_allow_all": true
 }
 },
- "privileged": true,
- "read": [- "string"
 ],
- "write": [- "string"
 ]
 },
- "provenance": {- "attestation": {- "predicate": null,
- "predicate_type": "string"
 },
- "cert_issuer": "string",
- "repository_ref": "string",
- "repository_uri": "string",
- "runner_environment": "string",
- "signer_identity": "string",
- "sigstore_url": "string"
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "target_port": 0,
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string"
 },
- "property2": {- "args": [- "string"
 ],
- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "docker_tags": [- "string"
 ],
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "image": "string",
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "permissions": {- "name": "string",
- "network": {- "inbound": {- "allow_host": [- "string"
 ]
 },
- "outbound": {- "allow_host": [- "string"
 ],
- "allow_port": [- 0
 ],
- "insecure_allow_all": true
 }
 },
- "privileged": true,
- "read": [- "string"
 ],
- "write": [- "string"
 ]
 },
- "provenance": {- "attestation": {- "predicate": null,
- "predicate_type": "string"
 },
- "cert_issuer": "string",
- "repository_ref": "string",
- "repository_uri": "string",
- "runner_environment": "string",
- "signer_identity": "string",
- "sigstore_url": "string"
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "target_port": 0,
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string"
 }
 },
- "version": "string"
 },
- "server_count": 0,
- "source": "string",
- "type": "string",
- "version": "string"
}Update registry configuration
Update registry URL or local path for the default registry
path Parameters
| name required | string Registry name (must be 'default') | 
Request Body schema: application/jsonrequired
Registry configuration
| allow_private_ip | boolean Allow private IP addresses for registry URL | 
| local_path | string Local registry file path | 
| url | string Registry URL (for remote registries) | 
Responses
Request samples
- Payload
{- "allow_private_ip": true,
- "local_path": "string",
- "url": "string"
}Response samples
- 200
- 400
- 404
{- "message": "string",
- "type": "string"
}List servers in a registry
Get a list of servers in a specific registry
path Parameters
| name required | string Registry name | 
Responses
Response samples
- 200
- 404
{- "remote_servers": [- {- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "headers": [- {- "choices": [- "string"
 ],
- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "oauth_config": {- "authorize_url": "string",
- "callback_port": 0,
- "client_id": "string",
- "issuer": "string",
- "oauth_params": {- "property1": "string",
- "property2": "string"
 },
- "scopes": [- "string"
 ],
- "token_url": "string",
- "use_pkce": true
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string",
- "url": "string"
 }
 ],
- "servers": [- {- "args": [- "string"
 ],
- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "docker_tags": [- "string"
 ],
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "image": "string",
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "permissions": {- "name": "string",
- "network": {- "inbound": {- "allow_host": [- "string"
 ]
 },
- "outbound": {- "allow_host": [- "string"
 ],
- "allow_port": [- 0
 ],
- "insecure_allow_all": true
 }
 },
- "privileged": true,
- "read": [- "string"
 ],
- "write": [- "string"
 ]
 },
- "provenance": {- "attestation": {- "predicate": null,
- "predicate_type": "string"
 },
- "cert_issuer": "string",
- "repository_ref": "string",
- "repository_uri": "string",
- "runner_environment": "string",
- "signer_identity": "string",
- "sigstore_url": "string"
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "target_port": 0,
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string"
 }
 ]
}Get a server from a registry
Get details of a specific server in a registry
path Parameters
| name required | string Registry name | 
| serverName required | string ImageMetadata name | 
Responses
Response samples
- 200
- 404
{- "is_remote": true,
- "remote_server": {- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "headers": [- {- "choices": [- "string"
 ],
- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "oauth_config": {- "authorize_url": "string",
- "callback_port": 0,
- "client_id": "string",
- "issuer": "string",
- "oauth_params": {- "property1": "string",
- "property2": "string"
 },
- "scopes": [- "string"
 ],
- "token_url": "string",
- "use_pkce": true
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string",
- "url": "string"
 },
- "server": {- "args": [- "string"
 ],
- "custom_metadata": {- "property1": null,
- "property2": null
 },
- "description": "string",
- "docker_tags": [- "string"
 ],
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "image": "string",
- "metadata": {- "last_updated": "string",
- "pulls": 0,
- "stars": 0
 },
- "name": "string",
- "permissions": {- "name": "string",
- "network": {- "inbound": {- "allow_host": [- "string"
 ]
 },
- "outbound": {- "allow_host": [- "string"
 ],
- "allow_port": [- 0
 ],
- "insecure_allow_all": true
 }
 },
- "privileged": true,
- "read": [- "string"
 ],
- "write": [- "string"
 ]
 },
- "provenance": {- "attestation": {- "predicate": null,
- "predicate_type": "string"
 },
- "cert_issuer": "string",
- "repository_ref": "string",
- "repository_uri": "string",
- "runner_environment": "string",
- "signer_identity": "string",
- "sigstore_url": "string"
 },
- "repository_url": "string",
- "status": "string",
- "tags": [- "string"
 ],
- "target_port": 0,
- "tier": "string",
- "tools": [- "string"
 ],
- "transport": "string"
 }
}Setup or reconfigure secrets provider
Setup the secrets provider with the specified type and configuration.
Request Body schema: application/jsonrequired
Setup secrets provider request
| password | string Password for encrypted provider (optional, can be set via environment variable) TODO Review environment variable for this | 
| provider_type | string Type of the secrets provider (encrypted, 1password, none) | 
Responses
Request samples
- Payload
{- "password": "string",
- "provider_type": "string"
}Response samples
- 201
- 400
- 500
{- "message": "string",
- "provider_type": "string"
}Create a new secret
Create a new secret in the default provider (encrypted provider only)
Request Body schema: application/jsonrequired
Create secret request
| key | string Secret key name | 
| value | string Secret value | 
Responses
Request samples
- Payload
{- "key": "string",
- "value": "string"
}Response samples
- 201
- 400
- 404
- 405
- 409
- 500
{- "key": "string",
- "message": "string"
}Update a secret
Update an existing secret in the default provider (encrypted provider only)
path Parameters
| key required | string Secret key | 
Request Body schema: application/jsonrequired
Update secret request
| value | string New secret value | 
Responses
Request samples
- Payload
{- "value": "string"
}Response samples
- 200
- 400
- 404
- 405
- 500
{- "key": "string",
- "message": "string"
}List all workloads
Get a list of all running workloads, optionally filtered by group
query Parameters
| all | boolean List all workloads, including stopped ones | 
| group | string Filter workloads by group name | 
Responses
Response samples
- 200
- 404
{- "workloads": [- {- "created_at": "string",
- "group": "string",
- "labels": {- "property1": "string",
- "property2": "string"
 },
- "name": "string",
- "package": "string",
- "port": 0,
- "proxy_mode": "string",
- "remote": true,
- "status": "string",
- "status_context": "string",
- "tool_type": "string",
- "tools": [- "string"
 ],
- "transport_type": "string",
- "url": "string"
 }
 ]
}Create a new workload
Create and start a new workload
Request Body schema: application/jsonrequired
Create workload request
| authz_config | string Authorization configuration | 
| cmd_arguments | Array of strings Command arguments to pass to the container | 
| object Environment variables to set in the container | |
| group | string Group name this workload belongs to | 
| Array of objects (registry.Header)  | |
| host | string Host to bind to | 
| image | string Docker image to use | 
| name | string Name of the workload | 
| network_isolation | boolean Whether network isolation is turned on. This applies the rules in the permission profile. | 
| object (v1.remoteOAuthConfig)  OAuth configuration for remote server authentication | |
| object (v1.oidcOptions)  OIDC configuration options | |
| object (permissions.Profile)  PermissionProfile is the permission profile to use | |
| proxy_mode | string Proxy mode to use | 
| proxy_port | integer Port for the HTTP proxy to listen on | 
| Array of objects (secrets.SecretParameter)  Secret parameters to inject | |
| target_port | integer Port to expose from the container | 
| tools | Array of strings Tools filter | 
| object Tools override | |
| transport | string Transport configuration | 
| trust_proxy_headers | boolean Whether to trust X-Forwarded-* headers from reverse proxies | 
| url | string Remote server specific fields | 
| volumes | Array of strings Volume mounts | 
Responses
Request samples
- Payload
{- "authz_config": "string",
- "cmd_arguments": [- "string"
 ],
- "env_vars": {- "property1": "string",
- "property2": "string"
 },
- "group": "string",
- "headers": [- {- "choices": [- "string"
 ],
- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "host": "string",
- "image": "string",
- "name": "string",
- "network_isolation": true,
- "oauth_config": {- "authorize_url": "string",
- "callback_port": 0,
- "client_id": "string",
- "client_secret": {- "name": "string",
- "target": "string"
 },
- "issuer": "string",
- "oauth_params": {- "property1": "string",
- "property2": "string"
 },
- "scopes": [- "string"
 ],
- "skip_browser": true,
- "token_url": "string",
- "use_pkce": true
 },
- "oidc": {- "audience": "string",
- "client_id": "string",
- "client_secret": "string",
- "introspection_url": "string",
- "issuer": "string",
- "jwks_url": "string"
 },
- "permission_profile": {- "name": "string",
- "network": {- "inbound": {- "allow_host": [- "string"
 ]
 },
- "outbound": {- "allow_host": [- "string"
 ],
- "allow_port": [- 0
 ],
- "insecure_allow_all": true
 }
 },
- "privileged": true,
- "read": [- "string"
 ],
- "write": [- "string"
 ]
 },
- "proxy_mode": "string",
- "proxy_port": 0,
- "secrets": [- {- "name": "string",
- "target": "string"
 }
 ],
- "target_port": 0,
- "tools": [- "string"
 ],
- "tools_override": {- "property1": {- "description": "string",
- "name": "string"
 },
- "property2": {- "description": "string",
- "name": "string"
 }
 },
- "transport": "string",
- "trust_proxy_headers": true,
- "url": "string",
- "volumes": [- "string"
 ]
}Response samples
- 201
- 400
- 409
{- "name": "string",
- "port": 0
}Get workload details
Get details of a specific workload
path Parameters
| name required | string Workload name | 
Responses
Response samples
- 200
- 404
{- "authz_config": "string",
- "cmd_arguments": [- "string"
 ],
- "env_vars": {- "property1": "string",
- "property2": "string"
 },
- "group": "string",
- "headers": [- {- "choices": [- "string"
 ],
- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "host": "string",
- "image": "string",
- "name": "string",
- "network_isolation": true,
- "oauth_config": {- "authorize_url": "string",
- "callback_port": 0,
- "client_id": "string",
- "client_secret": {- "name": "string",
- "target": "string"
 },
- "issuer": "string",
- "oauth_params": {- "property1": "string",
- "property2": "string"
 },
- "scopes": [- "string"
 ],
- "skip_browser": true,
- "token_url": "string",
- "use_pkce": true
 },
- "oidc": {- "audience": "string",
- "client_id": "string",
- "client_secret": "string",
- "introspection_url": "string",
- "issuer": "string",
- "jwks_url": "string"
 },
- "permission_profile": {- "name": "string",
- "network": {- "inbound": {- "allow_host": [- "string"
 ]
 },
- "outbound": {- "allow_host": [- "string"
 ],
- "allow_port": [- 0
 ],
- "insecure_allow_all": true
 }
 },
- "privileged": true,
- "read": [- "string"
 ],
- "write": [- "string"
 ]
 },
- "proxy_mode": "string",
- "proxy_port": 0,
- "secrets": [- {- "name": "string",
- "target": "string"
 }
 ],
- "target_port": 0,
- "tools": [- "string"
 ],
- "tools_override": {- "property1": {- "description": "string",
- "name": "string"
 },
- "property2": {- "description": "string",
- "name": "string"
 }
 },
- "transport": "string",
- "trust_proxy_headers": true,
- "url": "string",
- "volumes": [- "string"
 ]
}Update workload
Update an existing workload configuration
path Parameters
| name required | string Workload name | 
Request Body schema: application/jsonrequired
Update workload request
| authz_config | string Authorization configuration | 
| cmd_arguments | Array of strings Command arguments to pass to the container | 
| object Environment variables to set in the container | |
| group | string Group name this workload belongs to | 
| Array of objects (registry.Header)  | |
| host | string Host to bind to | 
| image | string Docker image to use | 
| network_isolation | boolean Whether network isolation is turned on. This applies the rules in the permission profile. | 
| object (v1.remoteOAuthConfig)  OAuth configuration for remote server authentication | |
| object (v1.oidcOptions)  OIDC configuration options | |
| object (permissions.Profile)  PermissionProfile is the permission profile to use | |
| proxy_mode | string Proxy mode to use | 
| proxy_port | integer Port for the HTTP proxy to listen on | 
| Array of objects (secrets.SecretParameter)  Secret parameters to inject | |
| target_port | integer Port to expose from the container | 
| tools | Array of strings Tools filter | 
| object Tools override | |
| transport | string Transport configuration | 
| trust_proxy_headers | boolean Whether to trust X-Forwarded-* headers from reverse proxies | 
| url | string Remote server specific fields | 
| volumes | Array of strings Volume mounts | 
Responses
Request samples
- Payload
{- "authz_config": "string",
- "cmd_arguments": [- "string"
 ],
- "env_vars": {- "property1": "string",
- "property2": "string"
 },
- "group": "string",
- "headers": [- {- "choices": [- "string"
 ],
- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "host": "string",
- "image": "string",
- "network_isolation": true,
- "oauth_config": {- "authorize_url": "string",
- "callback_port": 0,
- "client_id": "string",
- "client_secret": {- "name": "string",
- "target": "string"
 },
- "issuer": "string",
- "oauth_params": {- "property1": "string",
- "property2": "string"
 },
- "scopes": [- "string"
 ],
- "skip_browser": true,
- "token_url": "string",
- "use_pkce": true
 },
- "oidc": {- "audience": "string",
- "client_id": "string",
- "client_secret": "string",
- "introspection_url": "string",
- "issuer": "string",
- "jwks_url": "string"
 },
- "permission_profile": {- "name": "string",
- "network": {- "inbound": {- "allow_host": [- "string"
 ]
 },
- "outbound": {- "allow_host": [- "string"
 ],
- "allow_port": [- 0
 ],
- "insecure_allow_all": true
 }
 },
- "privileged": true,
- "read": [- "string"
 ],
- "write": [- "string"
 ]
 },
- "proxy_mode": "string",
- "proxy_port": 0,
- "secrets": [- {- "name": "string",
- "target": "string"
 }
 ],
- "target_port": 0,
- "tools": [- "string"
 ],
- "tools_override": {- "property1": {- "description": "string",
- "name": "string"
 },
- "property2": {- "description": "string",
- "name": "string"
 }
 },
- "transport": "string",
- "trust_proxy_headers": true,
- "url": "string",
- "volumes": [- "string"
 ]
}Response samples
- 200
- 400
- 404
{- "name": "string",
- "port": 0
}Export workload configuration
Export a workload's run configuration as JSON
path Parameters
| name required | string Workload name | 
Responses
Response samples
- 200
- 404
{- "audit_config": {- "component": "string",
- "event_types": [- "string"
 ],
- "exclude_event_types": [- "string"
 ],
- "include_request_data": true,
- "include_response_data": true,
- "log_file": "string",
- "max_data_size": 0
 },
- "audit_config_path": "string",
- "authz_config": {- "cedar": {- "entities_json": "string",
- "policies": [- "string"
 ]
 },
- "type": "string",
- "version": "string"
 },
- "authz_config_path": "string",
- "base_name": "string",
- "cmd_args": [- "string"
 ],
- "container_labels": {- "property1": "string",
- "property2": "string"
 },
- "container_name": "string",
- "debug": true,
- "env_file_dir": "string",
- "env_vars": {- "property1": "string",
- "property2": "string"
 },
- "group": "string",
- "host": "string",
- "ignore_config": {- "loadGlobal": true,
- "printOverlays": true
 },
- "image": "string",
- "isolate_network": true,
- "jwks_auth_token_file": "string",
- "k8s_pod_template_patch": "string",
- "middleware_configs": [- {- "parameters": { },
- "type": "string"
 }
 ],
- "name": "string",
- "oidc_config": {- "allowPrivateIP": true,
- "audience": "string",
- "authTokenFile": "string",
- "cacertPath": "string",
- "clientID": "string",
- "clientSecret": "string",
- "introspectionURL": "string",
- "issuer": "string",
- "jwksurl": "string",
- "resourceURL": "string"
 },
- "permission_profile": {- "name": "string",
- "network": {- "inbound": {- "allow_host": [- "string"
 ]
 },
- "outbound": {- "allow_host": [- "string"
 ],
- "allow_port": [- 0
 ],
- "insecure_allow_all": true
 }
 },
- "privileged": true,
- "read": [- "string"
 ],
- "write": [- "string"
 ]
 },
- "permission_profile_name_or_path": "string",
- "port": 0,
- "proxy_mode": "string",
- "remote_auth_config": {- "authorize_url": "string",
- "callback_port": 0,
- "client_id": "string",
- "client_secret": "string",
- "client_secret_file": "string",
- "env_vars": [- {- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "headers": [- {- "choices": [- "string"
 ],
- "default": "string",
- "description": "string",
- "name": "string",
- "required": true,
- "secret": true
 }
 ],
- "issuer": "string",
- "oauth_params": {- "property1": "string",
- "property2": "string"
 },
- "scopes": [- "string"
 ],
- "skip_browser": true,
- "timeout": "5m",
- "token_url": "string",
- "use_pkce": true
 },
- "remote_url": "string",
- "schema_version": "string",
- "secrets": [- "string"
 ],
- "target_host": "string",
- "target_port": 0,
- "telemetry_config": {- "enablePrometheusMetricsPath": true,
- "endpoint": "string",
- "environmentVariables": [- "string"
 ],
- "headers": {- "property1": "string",
- "property2": "string"
 },
- "insecure": true,
- "metricsEnabled": true,
- "samplingRate": 0,
- "serviceName": "string",
- "serviceVersion": "string",
- "tracingEnabled": true
 },
- "thv_ca_bundle": "string",
- "tools_filter": [- "string"
 ],
- "tools_override": {- "property1": {- "description": "string",
- "name": "string"
 },
- "property2": {- "description": "string",
- "name": "string"
 }
 },
- "transport": "string",
- "trust_proxy_headers": true,
- "volumes": [- "string"
 ]
}Delete workloads in bulk
Delete multiple workloads by name or by group
Request Body schema: application/jsonrequired
Bulk delete request (names or group)
| group | string Group name to operate on (mutually exclusive with names) | 
| names | Array of strings Names of the workloads to operate on | 
Responses
Request samples
- Payload
{- "group": "string",
- "names": [- "string"
 ]
}Response samples
- 202
- 400
"string"Restart workloads in bulk
Restart multiple workloads by name or by group
Request Body schema: application/jsonrequired
Bulk restart request (names or group)
| group | string Group name to operate on (mutually exclusive with names) | 
| names | Array of strings Names of the workloads to operate on | 
Responses
Request samples
- Payload
{- "group": "string",
- "names": [- "string"
 ]
}Response samples
- 202
- 400
"string"Stop workloads in bulk
Stop multiple workloads by name or by group
Request Body schema: application/jsonrequired
Bulk stop request (names or group)
| group | string Group name to operate on (mutually exclusive with names) | 
| names | Array of strings Names of the workloads to operate on | 
Responses
Request samples
- Payload
{- "group": "string",
- "names": [- "string"
 ]
}Response samples
- 202
- 400
"string"