API Documentation
General
Enterprise
- GETGet appearance
- PUTUpdate appearance
- POSTIssue signed app token for reconnecting PTY
- GETGet entitlements
- GETGet groups
- GETGet group by ID
- DELDelete group by name
- PATCHUpdate group by name
- GETGet JFrog XRay scan by workspace agent ID.
- POSTPost JFrog XRay scan by workspace agent ID.
- GETGet licenses
- DELDelete license
- PUTUpdate notification template dispatch method
- GETGet OAuth2 applications.
- POSTCreate OAuth2 application.
- GETGet OAuth2 application.
- PUTUpdate OAuth2 application.
- DELDelete OAuth2 application.
- GETGet OAuth2 application secrets.
- POSTCreate OAuth2 application secret.
- DELDelete OAuth2 application secret.
- POSTOAuth2 authorization request.
- POSTOAuth2 token exchange.
- DELDelete OAuth2 application tokens.
- GETGet groups by organization
- POSTCreate group for organization
- GETGet group by organization and group name
- GETGet workspace quota by user
- GETGet provisioner daemons
- GETServe provisioner daemon
- GETList provisioner key
- POSTCreate provisioner key
- GETList provisioner key daemons
- DELDelete provisioner key
- GETGet the available organization idp sync claim fields
- GETGet group IdP Sync settings by organization
- PATCHUpdate group IdP Sync settings by organization
- GETGet role IdP Sync settings by organization
- PATCHUpdate role IdP Sync settings by organization
- GETGet active replicas
- GETSCIM 2.0: Service Provider Config
- GETSCIM 2.0: Get users
- POSTSCIM 2.0: Create new user
- GETSCIM 2.0: Get user by ID
- PATCHSCIM 2.0: Update user account
- GETGet organization IdP Sync settings
- PATCHUpdate organization IdP Sync settings
- GETGet template ACLs
- PATCHUpdate template ACL
- GETGet template available acl users/groups
- GETGet user quiet hours schedule
- PUTUpdate user quiet hours schedule
- GETGet workspace quota by user deprecated
- GETGet workspace proxies
- POSTCreate workspace proxy
- POSTReport workspace app stats
- GETWorkspace Proxy Coordinate
- GETGet workspace proxy crypto keys
- POSTDeregister workspace proxy
- POSTIssue signed workspace app token
- POSTRegister workspace proxy
- GETGet workspace proxy
- DELDelete workspace proxy
- PATCHUpdate workspace proxy
Authorization
Debug
Agents
- GETDebug OIDC context for a user
- GETGet DERP map updates
- GETUser-scoped tailnet RPC connection
- POSTAuthenticate agent on AWS instance
- POSTAuthenticate agent on Azure instance
- GETGet connection info for workspace agent generic
- POSTAuthenticate agent on Google Cloud instance
- GETGet workspace agent external auth
- GETRemoved: Get workspace agent git auth
- GETGet workspace agent Git SSH key
- POSTPost workspace agent log source
- PATCHPatch workspace agent logs
- GETWorkspace agent RPC API
- GETGet workspace agent by ID
- GETGet connection info for workspace agent
- GETCoordinate workspace agent
- GETGet listening ports for workspace agent
- GETGet logs by workspace agent
- GETOpen PTY to workspace agent
- GETRemoved: Get logs by workspace agent
- GETWatch for workspace agent metadata updates
Git
Insights
Organizations
Notifications
Members
Workspaces
- POSTCreate user workspace by organization
- GETGet workspace metadata by user and workspace name
- POSTCreate user workspace
- GETList workspaces
- GETGet workspace metadata by ID
- PATCHUpdate workspace metadata by ID
- PUTUpdate workspace autostart schedule by ID
- PUTUpdate workspace automatic updates by ID
- PUTUpdate workspace dormancy status by id.
- PUTExtend workspace deadline by ID
- PUTFavorite workspace by ID.
- DELUnfavorite workspace by ID.
- GETResolve workspace autostart by id.
- GETGet workspace timings by ID
- PUTUpdate workspace TTL by ID
- POSTPost Workspace Usage by ID
- GETWatch workspace by ID
Templates
- GETGet templates by organization
- POSTCreate template by organization
- GETGet template examples by organization
- GETGet templates by organization and template name
- GETGet template version by organization, template, and name
- GETGet previous template version by organization, template, and name
- POSTCreate template version by organization
- GETGet all templates
- GETGet template examples
- GETGet template metadata by ID
- DELDelete template by ID
- PATCHUpdate template metadata by ID
- GETGet template DAUs by ID
- GETList template versions by template ID
- PATCHUpdate active template version by template ID
- POSTArchive template unused versions by template id
- GETGet template version by template ID and name
- GETGet template version by ID
- PATCHPatch template version by ID
- POSTArchive template version
- PATCHCancel template version by ID
- POSTCreate template version dry-run
- GETGet template version dry-run by job ID
- PATCHCancel template version dry-run by job ID
- GETGet template version dry-run logs by job ID
- GETGet template version dry-run resources by job ID
- GETGet external auth by template version
- GETGet logs by template version
- GETRemoved: Get parameters by template version
- GETGet resources by template version
- GETGet rich parameters by template version
- GETRemoved: Get schema by template version
- POSTUnarchive template version
- GETGet template variables by template version
WorkspaceProxies
Users
- GETGet users
- POSTCreate new user
- GETGet authentication methods
- GETCheck initial user created
- POSTCreate initial user
- POSTLog out user
- GETOAuth 2.0 GitHub Callback
- GETOpenID Connect Callback
- GETGet user by name
- DELDelete user
- PUTUpdate user appearance settings
- GETGet autofill build parameters for user
- GETGet user Git SSH key
- PUTRegenerate user SSH key
- POSTCreate new session key
- GETGet user tokens
- POSTCreate token API key
- GETGet API key by token name
- GETGet API key by ID
- DELDelete API key
- GETGet user login type
- GETGet organizations by user
- GETGet organization by user and organization name
- PUTUpdate user password
- PUTUpdate user profile
- GETGet user roles
- PUTAssign role to user
- PUTActivate user account
- PUTSuspend user account
Builds
- GETGet workspace build by user, workspace name, and build number
- GETGet workspace build
- PATCHCancel workspace build
- GETGet workspace build logs
- GETGet build parameters for workspace build
- GETRemoved: Get workspace resources for workspace build
- GETGet provisioner state for workspace build
- GETGet workspace build timings by ID
- GETGet workspace builds by workspace ID
- POSTCreate workspace build
List workspaces
curl --request GET \
--url https://cloud.local.wirtual.dev/api/v2/workspaces \
--header 'Wirtual-Session-Token: <api-key>'
{
"count": 123,
"workspaces": [
{
"allow_renames": true,
"automatic_updates": "<any>",
"autostart_schedule": "<string>",
"created_at": "2023-11-07T05:31:56Z",
"deleting_at": "2023-11-07T05:31:56Z",
"dormant_at": "2023-11-07T05:31:56Z",
"favorite": true,
"health": {
"failing_agents": [
"3c90c3cc-0d44-4b50-8888-8dd25736052a"
],
"healthy": false
},
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"last_used_at": "2023-11-07T05:31:56Z",
"latest_build": {
"build_number": 123,
"created_at": "2023-11-07T05:31:56Z",
"daily_cost": 123,
"deadline": "2023-11-07T05:31:56Z",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"initiator_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"initiator_name": "<string>",
"job": {
"canceled_at": "2023-11-07T05:31:56Z",
"completed_at": "2023-11-07T05:31:56Z",
"created_at": "2023-11-07T05:31:56Z",
"error": "<string>",
"error_code": "<any>",
"file_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"queue_position": 123,
"queue_size": 123,
"started_at": "2023-11-07T05:31:56Z",
"status": "<any>",
"tags": {},
"worker_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a"
},
"max_deadline": "2023-11-07T05:31:56Z",
"reason": "<any>",
"resources": [
{
"agents": [
{
"api_version": "<string>",
"apps": [
{
"command": "<string>",
"display_name": "<string>",
"external": true,
"health": "disabled",
"healthcheck": {
"interval": 123,
"threshold": 123,
"url": "<string>"
},
"hidden": true,
"icon": "<string>",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"sharing_level": "<any>",
"slug": "<string>",
"subdomain": true,
"subdomain_name": "<string>",
"url": "<string>"
}
],
"architecture": "<string>",
"connection_timeout_seconds": 123,
"created_at": "2023-11-07T05:31:56Z",
"directory": "<string>",
"disconnected_at": "2023-11-07T05:31:56Z",
"display_apps": [
"vscode"
],
"environment_variables": {},
"expanded_directory": "<string>",
"first_connected_at": "2023-11-07T05:31:56Z",
"health": {
"healthy": false,
"reason": "agent has lost connection"
},
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"instance_id": "<string>",
"last_connected_at": "2023-11-07T05:31:56Z",
"latency": {},
"lifecycle_state": "created",
"log_sources": [
{
"created_at": "2023-11-07T05:31:56Z",
"display_name": "<string>",
"icon": "<string>",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"workspace_agent_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a"
}
],
"logs_length": 123,
"logs_overflowed": true,
"name": "<string>",
"operating_system": "<string>",
"ready_at": "2023-11-07T05:31:56Z",
"resource_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"scripts": [
{
"cron": "<string>",
"display_name": "<string>",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"log_path": "<string>",
"log_source_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"run_on_start": true,
"run_on_stop": true,
"script": "<string>",
"start_blocks_login": true,
"timeout": 123
}
],
"started_at": "2023-11-07T05:31:56Z",
"startup_script_behavior": "<any>",
"status": "connecting",
"subsystems": [
"envbox"
],
"troubleshooting_url": "<string>",
"updated_at": "2023-11-07T05:31:56Z",
"version": "<string>"
}
],
"created_at": "2023-11-07T05:31:56Z",
"daily_cost": 123,
"hide": true,
"icon": "<string>",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"job_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"metadata": [
{
"key": "<string>",
"sensitive": true,
"value": "<string>"
}
],
"name": "<string>",
"type": "<string>",
"workspace_transition": "<any>"
}
],
"status": "<any>",
"template_version_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"template_version_name": "<string>",
"transition": "<any>",
"updated_at": "2023-11-07T05:31:56Z",
"workspace_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"workspace_name": "<string>",
"workspace_owner_avatar_url": "<string>",
"workspace_owner_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"workspace_owner_name": "<string>"
},
"name": "<string>",
"organization_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"organization_name": "<string>",
"outdated": true,
"owner_avatar_url": "<string>",
"owner_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"owner_name": "<string>",
"template_active_version_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"template_allow_user_cancel_workspace_jobs": true,
"template_display_name": "<string>",
"template_icon": "<string>",
"template_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"template_name": "<string>",
"template_require_active_version": true,
"ttl_ms": 123,
"updated_at": "2023-11-07T05:31:56Z"
}
]
}
Authorizations
Query Parameters
Search query in the format key:value
. Available keys are: owner, template, name, status, has-agent, dormant, last_used_after, last_used_before.
Page limit
Page offset
Response
DeletingAt indicates the time at which the workspace will be permanently deleted. A workspace is eligible for deletion if it is dormant (a non-nil dormant_at value) and a value has been specified for time_til_dormant_autodelete on its template.
DormantAt being non-nil indicates a workspace that is dormant. A dormant workspace is no longer accessible must be activated. It is subject to deletion if it breaches the duration of the time_til_ field on its template.
Health shows the health of the workspace and information about what is causing an unhealthy status.
vscode
, vscode_insiders
, web_terminal
, port_forwarding_helper
, ssh_helper
Health reports the health of the agent.
DERPLatency is mapped by region name (e.g. "New York City", "Seattle").
created
, starting
, start_timeout
, start_error
, ready
, shutting_down
, shutdown_timeout
, shutdown_error
, off
connecting
, connected
, disconnected
, timeout
envbox
, envbuilder
, exectrace
curl --request GET \
--url https://cloud.local.wirtual.dev/api/v2/workspaces \
--header 'Wirtual-Session-Token: <api-key>'
{
"count": 123,
"workspaces": [
{
"allow_renames": true,
"automatic_updates": "<any>",
"autostart_schedule": "<string>",
"created_at": "2023-11-07T05:31:56Z",
"deleting_at": "2023-11-07T05:31:56Z",
"dormant_at": "2023-11-07T05:31:56Z",
"favorite": true,
"health": {
"failing_agents": [
"3c90c3cc-0d44-4b50-8888-8dd25736052a"
],
"healthy": false
},
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"last_used_at": "2023-11-07T05:31:56Z",
"latest_build": {
"build_number": 123,
"created_at": "2023-11-07T05:31:56Z",
"daily_cost": 123,
"deadline": "2023-11-07T05:31:56Z",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"initiator_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"initiator_name": "<string>",
"job": {
"canceled_at": "2023-11-07T05:31:56Z",
"completed_at": "2023-11-07T05:31:56Z",
"created_at": "2023-11-07T05:31:56Z",
"error": "<string>",
"error_code": "<any>",
"file_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"queue_position": 123,
"queue_size": 123,
"started_at": "2023-11-07T05:31:56Z",
"status": "<any>",
"tags": {},
"worker_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a"
},
"max_deadline": "2023-11-07T05:31:56Z",
"reason": "<any>",
"resources": [
{
"agents": [
{
"api_version": "<string>",
"apps": [
{
"command": "<string>",
"display_name": "<string>",
"external": true,
"health": "disabled",
"healthcheck": {
"interval": 123,
"threshold": 123,
"url": "<string>"
},
"hidden": true,
"icon": "<string>",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"sharing_level": "<any>",
"slug": "<string>",
"subdomain": true,
"subdomain_name": "<string>",
"url": "<string>"
}
],
"architecture": "<string>",
"connection_timeout_seconds": 123,
"created_at": "2023-11-07T05:31:56Z",
"directory": "<string>",
"disconnected_at": "2023-11-07T05:31:56Z",
"display_apps": [
"vscode"
],
"environment_variables": {},
"expanded_directory": "<string>",
"first_connected_at": "2023-11-07T05:31:56Z",
"health": {
"healthy": false,
"reason": "agent has lost connection"
},
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"instance_id": "<string>",
"last_connected_at": "2023-11-07T05:31:56Z",
"latency": {},
"lifecycle_state": "created",
"log_sources": [
{
"created_at": "2023-11-07T05:31:56Z",
"display_name": "<string>",
"icon": "<string>",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"workspace_agent_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a"
}
],
"logs_length": 123,
"logs_overflowed": true,
"name": "<string>",
"operating_system": "<string>",
"ready_at": "2023-11-07T05:31:56Z",
"resource_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"scripts": [
{
"cron": "<string>",
"display_name": "<string>",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"log_path": "<string>",
"log_source_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"run_on_start": true,
"run_on_stop": true,
"script": "<string>",
"start_blocks_login": true,
"timeout": 123
}
],
"started_at": "2023-11-07T05:31:56Z",
"startup_script_behavior": "<any>",
"status": "connecting",
"subsystems": [
"envbox"
],
"troubleshooting_url": "<string>",
"updated_at": "2023-11-07T05:31:56Z",
"version": "<string>"
}
],
"created_at": "2023-11-07T05:31:56Z",
"daily_cost": 123,
"hide": true,
"icon": "<string>",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"job_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"metadata": [
{
"key": "<string>",
"sensitive": true,
"value": "<string>"
}
],
"name": "<string>",
"type": "<string>",
"workspace_transition": "<any>"
}
],
"status": "<any>",
"template_version_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"template_version_name": "<string>",
"transition": "<any>",
"updated_at": "2023-11-07T05:31:56Z",
"workspace_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"workspace_name": "<string>",
"workspace_owner_avatar_url": "<string>",
"workspace_owner_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"workspace_owner_name": "<string>"
},
"name": "<string>",
"organization_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"organization_name": "<string>",
"outdated": true,
"owner_avatar_url": "<string>",
"owner_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"owner_name": "<string>",
"template_active_version_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"template_allow_user_cancel_workspace_jobs": true,
"template_display_name": "<string>",
"template_icon": "<string>",
"template_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"template_name": "<string>",
"template_require_active_version": true,
"ttl_ms": 123,
"updated_at": "2023-11-07T05:31:56Z"
}
]
}