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 deployment config
curl --request GET \
--url https://cloud.local.wirtual.dev/api/v2/deployment/config \
--header 'Wirtual-Session-Token: <api-key>'
{
"config": {
"access_url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
},
"additional_csp_policy": [
"<string>"
],
"address": {
"host": "<string>",
"port": "<string>"
},
"agent_fallback_troubleshooting_url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
},
"agent_stat_refresh_interval": 123,
"allow_workspace_renames": true,
"autobuild_poll_interval": 123,
"browser_only": true,
"cache_directory": "<string>",
"cli_upgrade_message": "<string>",
"config": "<string>",
"config_ssh": {
"deploymentName": "<string>",
"sshconfigOptions": [
"<string>"
]
},
"dangerous": {
"allow_all_cors": true,
"allow_path_app_sharing": true,
"allow_path_app_site_owner_access": true
},
"derp": {
"config": {
"block_direct": true,
"force_websockets": true,
"path": "<string>",
"url": "<string>"
},
"server": {
"enable": true,
"region_code": "<string>",
"region_id": 123,
"region_name": "<string>",
"relay_url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
},
"stun_addresses": [
"<string>"
]
}
},
"disable_owner_workspace_exec": true,
"disable_password_auth": true,
"disable_path_apps": true,
"docs_url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
},
"enable_terraform_debug_mode": true,
"experiments": [
"<string>"
],
"external_auth": {
"value": [
{
"app_install_url": "<string>",
"app_installations_url": "<string>",
"auth_url": "<string>",
"client_id": "<string>",
"device_code_url": "<string>",
"device_flow": true,
"display_icon": "<string>",
"display_name": "<string>",
"id": "<string>",
"no_refresh": true,
"regex": "<string>",
"scopes": [
"<string>"
],
"token_url": "<string>",
"type": "<string>",
"validate_url": "<string>"
}
]
},
"external_token_encryption_keys": [
"<string>"
],
"healthcheck": {
"refresh": 123,
"threshold_database": 123
},
"http_address": "<string>",
"in_memory_database": true,
"job_hang_detector_interval": 123,
"logging": {
"human": "<string>",
"json": "<string>",
"log_filter": [
"<string>"
],
"stackdriver": "<string>"
},
"metrics_cache_refresh_interval": 123,
"notifications": {
"dispatch_timeout": 123,
"email": {
"auth": {
"identity": "<string>",
"password": "<string>",
"password_file": "<string>",
"username": "<string>"
},
"force_tls": true,
"from": "<string>",
"hello": "<string>",
"smarthost": "<string>",
"tls": {
"ca_file": "<string>",
"cert_file": "<string>",
"insecure_skip_verify": true,
"key_file": "<string>",
"server_name": "<string>",
"start_tls": true
}
},
"fetch_interval": 123,
"lease_count": 123,
"lease_period": 123,
"max_send_attempts": 123,
"method": "<string>",
"retry_interval": 123,
"sync_buffer_size": 123,
"sync_interval": 123,
"webhook": {
"endpoint": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
}
}
},
"oauth2": {
"github": {
"allow_everyone": true,
"allow_signups": true,
"allowed_orgs": [
"<string>"
],
"allowed_teams": [
"<string>"
],
"client_id": "<string>",
"client_secret": "<string>",
"enterprise_base_url": "<string>"
}
},
"oidc": {
"allow_signups": true,
"auth_url_params": {},
"client_cert_file": "<string>",
"client_id": "<string>",
"client_key_file": "<string>",
"client_secret": "<string>",
"email_domain": [
"<string>"
],
"email_field": "<string>",
"group_allow_list": [
"<string>"
],
"group_auto_create": true,
"group_mapping": {},
"group_regex_filter": {},
"groups_field": "<string>",
"icon_url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
},
"ignore_email_verified": true,
"ignore_user_info": true,
"issuer_url": "<string>",
"name_field": "<string>",
"organization_assign_default": true,
"organization_field": "<string>",
"organization_mapping": {},
"scopes": [
"<string>"
],
"sign_in_text": "<string>",
"signups_disabled_text": "<string>",
"skip_issuer_checks": true,
"user_role_field": "<string>",
"user_role_mapping": {},
"user_roles_default": [
"<string>"
],
"username_field": "<string>"
},
"pg_auth": "<string>",
"pg_connection_url": "<string>",
"pprof": {
"address": {
"host": "<string>",
"port": "<string>"
},
"enable": true
},
"prometheus": {
"address": {
"host": "<string>",
"port": "<string>"
},
"aggregate_agent_stats_by": [
"<string>"
],
"collect_agent_stats": true,
"collect_db_metrics": true,
"enable": true
},
"provisioner": {
"daemon_poll_interval": 123,
"daemon_poll_jitter": 123,
"daemon_psk": "<string>",
"daemon_types": [
"<string>"
],
"daemons": 123,
"force_cancel_interval": 123
},
"proxy_health_status_interval": 123,
"proxy_trusted_headers": [
"<string>"
],
"proxy_trusted_origins": [
"<string>"
],
"rate_limit": {
"api": 123,
"disable_all": true
},
"redirect_to_access_url": true,
"scim_api_key": "<string>",
"secure_auth_cookie": true,
"session_lifetime": {
"default_duration": 123,
"default_token_lifetime": 123,
"disable_expiry_refresh": true,
"max_token_lifetime": 123
},
"ssh_keygen_algorithm": "<string>",
"strict_transport_security": 123,
"strict_transport_security_options": [
"<string>"
],
"support": {
"links": {
"value": [
{
"icon": "bug",
"name": "<string>",
"target": "<string>"
}
]
}
},
"swagger": {
"enable": true
},
"telemetry": {
"enable": true,
"trace": true,
"url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
}
},
"terms_of_service_url": "<string>",
"tls": {
"address": {
"host": "<string>",
"port": "<string>"
},
"allow_insecure_ciphers": true,
"cert_file": [
"<string>"
],
"client_auth": "<string>",
"client_ca_file": "<string>",
"client_cert_file": "<string>",
"client_key_file": "<string>",
"enable": true,
"key_file": [
"<string>"
],
"min_version": "<string>",
"redirect_http": true,
"supported_ciphers": [
"<string>"
]
},
"trace": {
"capture_logs": true,
"data_dog": true,
"enable": true,
"honeycomb_api_key": "<string>"
},
"update_check": true,
"user_quiet_hours_schedule": {
"allow_user_custom": true,
"default_schedule": "<string>"
},
"verbose": true,
"web_terminal_renderer": "<string>",
"wgtunnel_host": "<string>",
"wildcard_access_url": "<string>",
"write_config": true
},
"options": [
{
"annotations": {},
"default": "<string>",
"description": "<string>",
"env": "<string>",
"flag": "<string>",
"flag_shorthand": "<string>",
"group": {
"description": "<string>",
"name": "<string>",
"parent": {},
"yaml": "<string>"
},
"hidden": true,
"name": "<string>",
"required": true,
"use_instead": [
{}
],
"value": {},
"value_source": "",
"yaml": "<string>"
}
]
}
Authorizations
Response
append a query ('?') even if RawQuery is empty
fragment for references, without '#'
host or host:port (see Hostname and Port methods)
do not emit empty host (authority)
encoded opaque data
path (relative paths may omit leading slash)
encoded fragment hint (see EscapedFragment method)
encoded path hint (see EscapedPath method)
encoded query values, without '?'
username and password information
append a query ('?') even if RawQuery is empty
fragment for references, without '#'
host or host:port (see Hostname and Port methods)
do not emit empty host (authority)
encoded opaque data
path (relative paths may omit leading slash)
encoded fragment hint (see EscapedFragment method)
encoded path hint (see EscapedPath method)
encoded query values, without '?'
username and password information
append a query ('?') even if RawQuery is empty
fragment for references, without '#'
host or host:port (see Hostname and Port methods)
do not emit empty host (authority)
encoded opaque data
path (relative paths may omit leading slash)
encoded fragment hint (see EscapedFragment method)
encoded path hint (see EscapedPath method)
encoded query values, without '?'
username and password information
append a query ('?') even if RawQuery is empty
fragment for references, without '#'
host or host:port (see Hostname and Port methods)
do not emit empty host (authority)
encoded opaque data
path (relative paths may omit leading slash)
encoded fragment hint (see EscapedFragment method)
encoded path hint (see EscapedPath method)
encoded query values, without '?'
username and password information
DisplayIcon is a URL to an icon to display in the UI.
DisplayName is shown in the UI to identify the auth config.
ID is a unique identifier for the auth config.
It defaults to type
when not provided.
Regex allows API requesters to match an auth config by a string (e.g. wirtual.dev) instead of by it's type.
Git clone makes use of this by parsing the URL from: 'Username for "https://github.com":' And sending it to the Wirtual server to match against the Regex.
Type is the type of external auth config.
HTTPAddress is a string because it may be set to zero to disable.
How long to wait while a notification is being sent before giving up.
SMTP settings.
Authentication details.
Identity for PLAIN auth.
Password for LOGIN/PLAIN auth.
File from which to load the password for LOGIN/PLAIN auth.
Username for LOGIN/PLAIN auth.
ForceTLS causes a TLS connection to be attempted.
The sender's address.
The hostname identifying the SMTP server.
The intermediary SMTP host through which emails are sent (host:port).
TLS details.
CAFile specifies the location of the CA certificate to use.
CertFile specifies the location of the certificate to use.
InsecureSkipVerify skips target certificate validation.
KeyFile specifies the location of the key to use.
ServerName to verify the hostname for the targets.
StartTLS attempts to upgrade plain connections to TLS.
How often to query the database for queued notifications.
How many notifications a notifier should lease per fetch interval.
How long a notifier should lease a message. This is effectively how long a notification is 'owned' by a notifier, and once this period expires it will be available for lease by another notifier. Leasing is important in order for multiple running notifiers to not pick the same messages to deliver concurrently. This lease period will only expire if a notifier shuts down ungracefully; a dispatch of the notification releases the lease.
The upper limit of attempts to send a notification.
Which delivery method to use (available options: 'smtp', 'webhook').
The minimum time between retries.
The notifications system buffers message updates in memory to ease pressure on the database. This option controls how many updates are kept in memory. The lower this value the lower the change of state inconsistency in a non-graceful shutdown - but it also increases load on the database. It is recommended to keep this option at its default value.
The notifications system buffers message updates in memory to ease pressure on the database. This option controls how often it synchronizes its state with the database. The shorter this value the lower the change of state inconsistency in a non-graceful shutdown - but it also increases load on the database. It is recommended to keep this option at its default value.
Webhook settings.
The URL to which the payload will be sent with an HTTP POST request.
append a query ('?') even if RawQuery is empty
fragment for references, without '#'
host or host:port (see Hostname and Port methods)
do not emit empty host (authority)
encoded opaque data
path (relative paths may omit leading slash)
encoded fragment hint (see EscapedFragment method)
encoded path hint (see EscapedPath method)
encoded query values, without '?'
username and password information
ClientKeyFile & ClientCertFile are used in place of ClientSecret for PKI auth.
append a query ('?') even if RawQuery is empty
fragment for references, without '#'
host or host:port (see Hostname and Port methods)
do not emit empty host (authority)
encoded opaque data
path (relative paths may omit leading slash)
encoded fragment hint (see EscapedFragment method)
encoded path hint (see EscapedPath method)
encoded query values, without '?'
username and password information
Daemons is the number of built-in terraform provisioners.
DefaultDuration is only for browser, workspace app and oauth sessions.
DisableExpiryRefresh will disable automatically refreshing api keys when they are used from the api. This means the api key lifetime at creation is the lifetime of the api key.
append a query ('?') even if RawQuery is empty
fragment for references, without '#'
host or host:port (see Hostname and Port methods)
do not emit empty host (authority)
encoded opaque data
path (relative paths may omit leading slash)
encoded fragment hint (see EscapedFragment method)
encoded path hint (see EscapedPath method)
encoded query values, without '?'
username and password information
Annotations enable extensions to serpent higher up in the stack. It's useful for help formatting and documentation generation.
Default is parsed into Value if set.
Env is the environment variable used to configure this option. If unset, environment configuring is disabled.
Flag is the long name of the flag used to configure this option. If unset, flag configuring is disabled.
FlagShorthand is the one-character shorthand for the flag. If unset, no shorthand is used.
Group is a group hierarchy that helps organize this option in help, configs and other documentation.
Required means this value must be set by some means. It requires
ValueSource != ValueSourceNone
If Default
is set, then Required
is ignored.
UseInstead is a list of options that should be used instead of this one. The field is used to generate a deprecation warning.
Annotations enable extensions to serpent higher up in the stack. It's useful for help formatting and documentation generation.
Default is parsed into Value if set.
Env is the environment variable used to configure this option. If unset, environment configuring is disabled.
Flag is the long name of the flag used to configure this option. If unset, flag configuring is disabled.
FlagShorthand is the one-character shorthand for the flag. If unset, no shorthand is used.
Group is a group hierarchy that helps organize this option in help, configs and other documentation.
Required means this value must be set by some means. It requires
ValueSource != ValueSourceNone
If Default
is set, then Required
is ignored.
UseInstead is a list of options that should be used instead of this one. The field is used to generate a deprecation warning.
Annotations enable extensions to serpent higher up in the stack. It's useful for help formatting and documentation generation.
Default is parsed into Value if set.
Env is the environment variable used to configure this option. If unset, environment configuring is disabled.
Flag is the long name of the flag used to configure this option. If unset, flag configuring is disabled.
FlagShorthand is the one-character shorthand for the flag. If unset, no shorthand is used.
Group is a group hierarchy that helps organize this option in help, configs and other documentation.
Required means this value must be set by some means. It requires
ValueSource != ValueSourceNone
If Default
is set, then Required
is ignored.
UseInstead is a list of options that should be used instead of this one. The field is used to generate a deprecation warning.
Annotations enable extensions to serpent higher up in the stack. It's useful for help formatting and documentation generation.
Default is parsed into Value if set.
Env is the environment variable used to configure this option. If unset, environment configuring is disabled.
Flag is the long name of the flag used to configure this option. If unset, flag configuring is disabled.
FlagShorthand is the one-character shorthand for the flag. If unset, no shorthand is used.
Group is a group hierarchy that helps organize this option in help, configs and other documentation.
Required means this value must be set by some means. It requires
ValueSource != ValueSourceNone
If Default
is set, then Required
is ignored.
UseInstead is a list of options that should be used instead of this one. The field is used to generate a deprecation warning.
Value includes the types listed in values.go.
, flag
, env
, yaml
, default
YAML is the YAML key used to configure this option. If unset, YAML configuring is disabled.
Value includes the types listed in values.go.
, flag
, env
, yaml
, default
YAML is the YAML key used to configure this option. If unset, YAML configuring is disabled.
Value includes the types listed in values.go.
, flag
, env
, yaml
, default
YAML is the YAML key used to configure this option. If unset, YAML configuring is disabled.
Value includes the types listed in values.go.
, flag
, env
, yaml
, default
YAML is the YAML key used to configure this option. If unset, YAML configuring is disabled.
curl --request GET \
--url https://cloud.local.wirtual.dev/api/v2/deployment/config \
--header 'Wirtual-Session-Token: <api-key>'
{
"config": {
"access_url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
},
"additional_csp_policy": [
"<string>"
],
"address": {
"host": "<string>",
"port": "<string>"
},
"agent_fallback_troubleshooting_url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
},
"agent_stat_refresh_interval": 123,
"allow_workspace_renames": true,
"autobuild_poll_interval": 123,
"browser_only": true,
"cache_directory": "<string>",
"cli_upgrade_message": "<string>",
"config": "<string>",
"config_ssh": {
"deploymentName": "<string>",
"sshconfigOptions": [
"<string>"
]
},
"dangerous": {
"allow_all_cors": true,
"allow_path_app_sharing": true,
"allow_path_app_site_owner_access": true
},
"derp": {
"config": {
"block_direct": true,
"force_websockets": true,
"path": "<string>",
"url": "<string>"
},
"server": {
"enable": true,
"region_code": "<string>",
"region_id": 123,
"region_name": "<string>",
"relay_url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
},
"stun_addresses": [
"<string>"
]
}
},
"disable_owner_workspace_exec": true,
"disable_password_auth": true,
"disable_path_apps": true,
"docs_url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
},
"enable_terraform_debug_mode": true,
"experiments": [
"<string>"
],
"external_auth": {
"value": [
{
"app_install_url": "<string>",
"app_installations_url": "<string>",
"auth_url": "<string>",
"client_id": "<string>",
"device_code_url": "<string>",
"device_flow": true,
"display_icon": "<string>",
"display_name": "<string>",
"id": "<string>",
"no_refresh": true,
"regex": "<string>",
"scopes": [
"<string>"
],
"token_url": "<string>",
"type": "<string>",
"validate_url": "<string>"
}
]
},
"external_token_encryption_keys": [
"<string>"
],
"healthcheck": {
"refresh": 123,
"threshold_database": 123
},
"http_address": "<string>",
"in_memory_database": true,
"job_hang_detector_interval": 123,
"logging": {
"human": "<string>",
"json": "<string>",
"log_filter": [
"<string>"
],
"stackdriver": "<string>"
},
"metrics_cache_refresh_interval": 123,
"notifications": {
"dispatch_timeout": 123,
"email": {
"auth": {
"identity": "<string>",
"password": "<string>",
"password_file": "<string>",
"username": "<string>"
},
"force_tls": true,
"from": "<string>",
"hello": "<string>",
"smarthost": "<string>",
"tls": {
"ca_file": "<string>",
"cert_file": "<string>",
"insecure_skip_verify": true,
"key_file": "<string>",
"server_name": "<string>",
"start_tls": true
}
},
"fetch_interval": 123,
"lease_count": 123,
"lease_period": 123,
"max_send_attempts": 123,
"method": "<string>",
"retry_interval": 123,
"sync_buffer_size": 123,
"sync_interval": 123,
"webhook": {
"endpoint": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
}
}
},
"oauth2": {
"github": {
"allow_everyone": true,
"allow_signups": true,
"allowed_orgs": [
"<string>"
],
"allowed_teams": [
"<string>"
],
"client_id": "<string>",
"client_secret": "<string>",
"enterprise_base_url": "<string>"
}
},
"oidc": {
"allow_signups": true,
"auth_url_params": {},
"client_cert_file": "<string>",
"client_id": "<string>",
"client_key_file": "<string>",
"client_secret": "<string>",
"email_domain": [
"<string>"
],
"email_field": "<string>",
"group_allow_list": [
"<string>"
],
"group_auto_create": true,
"group_mapping": {},
"group_regex_filter": {},
"groups_field": "<string>",
"icon_url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
},
"ignore_email_verified": true,
"ignore_user_info": true,
"issuer_url": "<string>",
"name_field": "<string>",
"organization_assign_default": true,
"organization_field": "<string>",
"organization_mapping": {},
"scopes": [
"<string>"
],
"sign_in_text": "<string>",
"signups_disabled_text": "<string>",
"skip_issuer_checks": true,
"user_role_field": "<string>",
"user_role_mapping": {},
"user_roles_default": [
"<string>"
],
"username_field": "<string>"
},
"pg_auth": "<string>",
"pg_connection_url": "<string>",
"pprof": {
"address": {
"host": "<string>",
"port": "<string>"
},
"enable": true
},
"prometheus": {
"address": {
"host": "<string>",
"port": "<string>"
},
"aggregate_agent_stats_by": [
"<string>"
],
"collect_agent_stats": true,
"collect_db_metrics": true,
"enable": true
},
"provisioner": {
"daemon_poll_interval": 123,
"daemon_poll_jitter": 123,
"daemon_psk": "<string>",
"daemon_types": [
"<string>"
],
"daemons": 123,
"force_cancel_interval": 123
},
"proxy_health_status_interval": 123,
"proxy_trusted_headers": [
"<string>"
],
"proxy_trusted_origins": [
"<string>"
],
"rate_limit": {
"api": 123,
"disable_all": true
},
"redirect_to_access_url": true,
"scim_api_key": "<string>",
"secure_auth_cookie": true,
"session_lifetime": {
"default_duration": 123,
"default_token_lifetime": 123,
"disable_expiry_refresh": true,
"max_token_lifetime": 123
},
"ssh_keygen_algorithm": "<string>",
"strict_transport_security": 123,
"strict_transport_security_options": [
"<string>"
],
"support": {
"links": {
"value": [
{
"icon": "bug",
"name": "<string>",
"target": "<string>"
}
]
}
},
"swagger": {
"enable": true
},
"telemetry": {
"enable": true,
"trace": true,
"url": {
"forceQuery": true,
"fragment": "<string>",
"host": "<string>",
"omitHost": true,
"opaque": "<string>",
"path": "<string>",
"rawFragment": "<string>",
"rawPath": "<string>",
"rawQuery": "<string>",
"scheme": "<string>",
"user": {}
}
},
"terms_of_service_url": "<string>",
"tls": {
"address": {
"host": "<string>",
"port": "<string>"
},
"allow_insecure_ciphers": true,
"cert_file": [
"<string>"
],
"client_auth": "<string>",
"client_ca_file": "<string>",
"client_cert_file": "<string>",
"client_key_file": "<string>",
"enable": true,
"key_file": [
"<string>"
],
"min_version": "<string>",
"redirect_http": true,
"supported_ciphers": [
"<string>"
]
},
"trace": {
"capture_logs": true,
"data_dog": true,
"enable": true,
"honeycomb_api_key": "<string>"
},
"update_check": true,
"user_quiet_hours_schedule": {
"allow_user_custom": true,
"default_schedule": "<string>"
},
"verbose": true,
"web_terminal_renderer": "<string>",
"wgtunnel_host": "<string>",
"wildcard_access_url": "<string>",
"write_config": true
},
"options": [
{
"annotations": {},
"default": "<string>",
"description": "<string>",
"env": "<string>",
"flag": "<string>",
"flag_shorthand": "<string>",
"group": {
"description": "<string>",
"name": "<string>",
"parent": {},
"yaml": "<string>"
},
"hidden": true,
"name": "<string>",
"required": true,
"use_instead": [
{}
],
"value": {},
"value_source": "",
"yaml": "<string>"
}
]
}