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
Get workspace metadata by user and workspace name
curl --request GET \
--url https://cloud.local.wirtual.dev/api/v2/users/{user}/workspace/{workspacename} \
--header 'Wirtual-Session-Token: <api-key>'
{
"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
Path Parameters
User ID, name, or me
Workspace name
Query Parameters
Return data instead of HTTP 404 if the workspace is deleted
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.
DisplayName is a friendly name for the app.
External specifies whether the URL should be opened externally on the client or not.
disabled
, initializing
, healthy
, unhealthy
Healthcheck specifies the configuration for checking app health.
Icon is a relative path or external URL that specifies an icon to be displayed in the dashboard.
Slug is a unique identifier within the agent.
Subdomain denotes whether the app should be accessed via a path on the
wirtual server
or via a hostname-based dev URL. If this is set to true
and there is no app wildcard configured on the server, the app will not
be accessible in the UI.
SubdomainName is the application domain exposed on the wirtual server
.
URL is the address being proxied to inside the workspace. If external is specified, this will be opened on the client.
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/users/{user}/workspace/{workspacename} \
--header 'Wirtual-Session-Token: <api-key>'
{
"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"
}