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
Debug Info Deployment Health
curl --request GET \
--url https://cloud.local.wirtual.dev/api/v2/debug/health \
--header 'Wirtual-Session-Token: <api-key>'
{
"access_url": {
"access_url": "<string>",
"dismissed": true,
"error": "<string>",
"healthy": true,
"healthz_response": "<string>",
"reachable": true,
"severity": "<any>",
"status_code": 123,
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
},
"database": {
"dismissed": true,
"error": "<string>",
"healthy": true,
"latency": "<string>",
"latency_ms": 123,
"reachable": true,
"severity": "<any>",
"threshold_ms": 123,
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
},
"derp": {
"dismissed": true,
"error": "<string>",
"healthy": true,
"netcheck": {
"captivePortal": "<string>",
"globalV4": "<string>",
"globalV6": "<string>",
"hairPinning": "<string>",
"icmpv4": true,
"ipv4": true,
"ipv4CanSend": true,
"ipv6": true,
"ipv6CanSend": true,
"mappingVariesByDestIP": "<string>",
"oshasIPv6": true,
"pcp": "<string>",
"pmp": "<string>",
"preferredDERP": 123,
"regionLatency": {},
"regionV4Latency": {},
"regionV6Latency": {},
"udp": true,
"upnP": "<string>"
},
"netcheck_err": "<string>",
"netcheck_logs": [
"<string>"
],
"regions": {},
"severity": "<any>",
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
},
"healthy": true,
"provisioner_daemons": {
"dismissed": true,
"error": "<string>",
"items": [
{
"provisioner_daemon": {
"api_version": "<string>",
"created_at": "2023-11-07T05:31:56Z",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"key_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"last_seen_at": "2023-11-07T05:31:56Z",
"name": "<string>",
"organization_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"provisioners": [
"<string>"
],
"tags": {},
"version": "<string>"
},
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
}
],
"severity": "<any>",
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
},
"severity": "<any>",
"time": "2023-11-07T05:31:56Z",
"websocket": {
"body": "<string>",
"code": 123,
"dismissed": true,
"error": "<string>",
"healthy": true,
"severity": "<any>",
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
},
"wirtual_version": "<string>",
"workspace_proxy": {
"dismissed": true,
"error": "<string>",
"healthy": true,
"severity": "<any>",
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
],
"workspace_proxies": {
"regions": [
{
"created_at": "2023-11-07T05:31:56Z",
"deleted": true,
"derp_enabled": true,
"derp_only": true,
"display_name": "<string>",
"healthy": true,
"icon_url": "<string>",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"name": "<string>",
"path_app_url": "<string>",
"status": {
"checked_at": "2023-11-07T05:31:56Z",
"report": {
"errors": [
"<string>"
],
"warnings": [
"<string>"
]
},
"status": "ok"
},
"updated_at": "2023-11-07T05:31:56Z",
"version": "<string>",
"wildcard_hostname": "<string>"
}
]
}
}
}
Authorizations
Query Parameters
Force a healthcheck to run
Response
Healthy is deprecated and left for backward compatibility purposes, use Severity
instead.
Healthy is deprecated and left for backward compatibility purposes, use Severity
instead.
Healthy is deprecated and left for backward compatibility purposes, use Severity
instead.
CaptivePortal is set when we think there's a captive portal that is intercepting HTTP traffic.
ip:port of global IPv4
[ip]:port of global IPv6
HairPinning is whether the router supports communicating between two local devices through the NATted public IP address (on IPv4).
an ICMPv4 round trip completed
an IPv4 STUN round trip completed
an IPv4 packet was able to be sent
an IPv6 STUN round trip completed
an IPv6 packet was able to be sent
MappingVariesByDestIP is whether STUN results depend which STUN server you're talking to (on IPv4).
could bind a socket to ::1
PCP is whether PCP appears present on the LAN. Empty means not checked.
PMP is whether NAT-PMP appears present on the LAN. Empty means not checked.
or 0 for unknown
keyed by DERP Region ID
keyed by DERP Region ID
keyed by DERP Region ID
a UDP STUN round trip completed
UPnP is whether UPnP appears present on the LAN. Empty means not checked.
Healthy is deprecated and left for backward compatibility purposes, use Severity
instead.
Healthy is deprecated and left for backward compatibility purposes, use Severity
instead.
Avoid is whether the client should avoid picking this as its home region. The region should only be used if a peer is there. Clients already using this region as their home should migrate away to a new region without Avoid set.
EmbeddedRelay is true when the region is bundled with the Coder control plane.
Nodes are the DERP nodes running in this region, in priority order for the current client. Client TLS connections should ideally only go to the first entry (falling back to the second if necessary). STUN packets should go to the first 1 or 2.
If nodes within a region route packets amongst themselves, but not to other regions. That said, each user/domain should get a the same preferred node order, so if all nodes for a user/network pick the first one (as they should, when things are healthy), the inter-cluster routing is minimal to zero.
RegionCode is a short name for the region. It's usually a popular city or airport code in the region: "nyc", "sf", "sin", "fra", etc.
RegionID is a unique integer for a geographic region.
It corresponds to the legacy derpN.tailscale.com hostnames used by older clients. (Older clients will continue to resolve derpN.tailscale.com when contacting peers, rather than use the server-provided DERPMap)
RegionIDs must be non-zero, positive, and guaranteed to fit in a JavaScript number.
RegionIDs in range 900-999 are reserved for end users to run their own DERP nodes.
RegionName is a long English name for the region: "New York City", "San Francisco", "Singapore", "Frankfurt", etc.
Healthy is true if the report returns no errors.
Deprecated: use Severity
instead
Time is the time the report was generated at.
Healthy is deprecated and left for backward compatibility purposes, use Severity
instead.
The Wirtual version of the server that the report was generated on.
Healthy is deprecated and left for backward compatibility purposes, use Severity
instead.
PathAppURL is the URL to the base path for path apps. Optional unless wildcard_hostname is set. E.g. https://us.example.com
Status is the latest status check of the proxy. This will be empty for deleted proxies. This value can be used to determine if a workspace proxy is healthy and ready to use.
Report provides more information about the health of the workspace proxy.
ok
, unreachable
, unhealthy
, unregistered
WildcardHostname is the wildcard hostname for subdomain apps. E.g. *.us.example.com E.g. *--suffix.au.example.com Optional. Does not need to be on the same domain as PathAppURL.
curl --request GET \
--url https://cloud.local.wirtual.dev/api/v2/debug/health \
--header 'Wirtual-Session-Token: <api-key>'
{
"access_url": {
"access_url": "<string>",
"dismissed": true,
"error": "<string>",
"healthy": true,
"healthz_response": "<string>",
"reachable": true,
"severity": "<any>",
"status_code": 123,
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
},
"database": {
"dismissed": true,
"error": "<string>",
"healthy": true,
"latency": "<string>",
"latency_ms": 123,
"reachable": true,
"severity": "<any>",
"threshold_ms": 123,
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
},
"derp": {
"dismissed": true,
"error": "<string>",
"healthy": true,
"netcheck": {
"captivePortal": "<string>",
"globalV4": "<string>",
"globalV6": "<string>",
"hairPinning": "<string>",
"icmpv4": true,
"ipv4": true,
"ipv4CanSend": true,
"ipv6": true,
"ipv6CanSend": true,
"mappingVariesByDestIP": "<string>",
"oshasIPv6": true,
"pcp": "<string>",
"pmp": "<string>",
"preferredDERP": 123,
"regionLatency": {},
"regionV4Latency": {},
"regionV6Latency": {},
"udp": true,
"upnP": "<string>"
},
"netcheck_err": "<string>",
"netcheck_logs": [
"<string>"
],
"regions": {},
"severity": "<any>",
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
},
"healthy": true,
"provisioner_daemons": {
"dismissed": true,
"error": "<string>",
"items": [
{
"provisioner_daemon": {
"api_version": "<string>",
"created_at": "2023-11-07T05:31:56Z",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"key_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"last_seen_at": "2023-11-07T05:31:56Z",
"name": "<string>",
"organization_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"provisioners": [
"<string>"
],
"tags": {},
"version": "<string>"
},
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
}
],
"severity": "<any>",
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
},
"severity": "<any>",
"time": "2023-11-07T05:31:56Z",
"websocket": {
"body": "<string>",
"code": 123,
"dismissed": true,
"error": "<string>",
"healthy": true,
"severity": "<any>",
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
]
},
"wirtual_version": "<string>",
"workspace_proxy": {
"dismissed": true,
"error": "<string>",
"healthy": true,
"severity": "<any>",
"warnings": [
{
"code": "EUNKNOWN",
"message": "<string>"
}
],
"workspace_proxies": {
"regions": [
{
"created_at": "2023-11-07T05:31:56Z",
"deleted": true,
"derp_enabled": true,
"derp_only": true,
"display_name": "<string>",
"healthy": true,
"icon_url": "<string>",
"id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
"name": "<string>",
"path_app_url": "<string>",
"status": {
"checked_at": "2023-11-07T05:31:56Z",
"report": {
"errors": [
"<string>"
],
"warnings": [
"<string>"
]
},
"status": "ok"
},
"updated_at": "2023-11-07T05:31:56Z",
"version": "<string>",
"wildcard_hostname": "<string>"
}
]
}
}
}