2023-09-29 18:40:35 +01:00
|
|
|
// Copyright (c) Tailscale Inc & AUTHORS
|
|
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
|
|
|
|
package syspolicy
|
|
|
|
|
|
|
|
type Key string
|
|
|
|
|
|
|
|
const (
|
|
|
|
// Keys with a string value
|
2023-10-25 01:07:25 +01:00
|
|
|
ControlURL Key = "LoginURL" // default ""; if blank, ipn uses ipn.DefaultControlURL.
|
|
|
|
LogTarget Key = "LogTarget" // default ""; if blank logging uses logtail.DefaultHost.
|
|
|
|
Tailnet Key = "Tailnet" // default ""; if blank, no tailnet name is sent to the server.
|
2023-11-29 21:48:25 +00:00
|
|
|
// ExitNodeID is the exit node's node id. default ""; if blank, no exit node is forced.
|
|
|
|
// Exit node ID takes precedence over exit node IP.
|
|
|
|
// To find the node ID, go to /api.md#device.
|
|
|
|
ExitNodeID Key = "ExitNodeID"
|
|
|
|
ExitNodeIP Key = "ExitNodeIP" // default ""; if blank, no exit node is forced. Value is exit node IP.
|
2023-09-29 18:40:35 +01:00
|
|
|
|
|
|
|
// Keys with a string value that specifies an option: "always", "never", "user-decides".
|
2023-11-01 21:20:25 +00:00
|
|
|
// The default is "user-decides" unless otherwise stated. Enforcement of
|
2023-12-07 17:01:31 +00:00
|
|
|
// these policies is typically performed in ipnlocal.applySysPolicy(). GUIs
|
|
|
|
// typically hide menu items related to policies that are enforced.
|
2023-09-29 18:40:35 +01:00
|
|
|
EnableIncomingConnections Key = "AllowIncomingConnections"
|
|
|
|
EnableServerMode Key = "UnattendedMode"
|
2023-11-04 19:51:20 +00:00
|
|
|
ExitNodeAllowLANAccess Key = "ExitNodeAllowLANAccess"
|
2023-12-05 18:30:32 +00:00
|
|
|
EnableTailscaleDNS Key = "UseTailscaleDNSSettings"
|
|
|
|
EnableTailscaleSubnets Key = "UseTailscaleSubnets"
|
2023-12-07 17:01:31 +00:00
|
|
|
// CheckUpdates is the key to signal if the updater should periodically
|
|
|
|
// check for updates.
|
|
|
|
CheckUpdates Key = "CheckUpdates"
|
|
|
|
// ApplyUpdates is the key to signal if updates should be automatically
|
|
|
|
// installed. Its value is "InstallUpdates" because of an awkwardly-named
|
|
|
|
// visibility option "ApplyUpdates" on MacOS.
|
|
|
|
ApplyUpdates Key = "InstallUpdates"
|
2023-12-07 17:01:31 +00:00
|
|
|
// EnableRunExitNode controls if the device acts as an exit node. Even when
|
|
|
|
// running as an exit node, the device must be approved by a tailnet
|
|
|
|
// administrator. Its name is slightly awkward because RunExitNodeVisibility
|
|
|
|
// predates this option but is preserved for backwards compatibility.
|
|
|
|
EnableRunExitNode Key = "AdvertiseExitNode"
|
2023-09-29 18:40:35 +01:00
|
|
|
|
|
|
|
// Keys with a string value that controls visibility: "show", "hide".
|
2023-11-01 21:20:25 +00:00
|
|
|
// The default is "show" unless otherwise stated. Enforcement of these
|
|
|
|
// policies is typically performed by the UI code for the relevant operating
|
|
|
|
// system.
|
2024-02-22 18:10:31 +00:00
|
|
|
AdminConsoleVisibility Key = "AdminConsole"
|
|
|
|
NetworkDevicesVisibility Key = "NetworkDevices"
|
|
|
|
TestMenuVisibility Key = "TestMenu"
|
|
|
|
UpdateMenuVisibility Key = "UpdateMenu"
|
|
|
|
ResetToDefaultsVisibility Key = "ResetToDefaults"
|
2023-12-07 17:01:31 +00:00
|
|
|
// RunExitNodeVisibility controls if the "run as exit node" menu item is
|
|
|
|
// visible, without controlling the setting itself. This is preserved for
|
|
|
|
// backwards compatibility but prefer EnableRunExitNode in new deployments.
|
2023-09-29 18:40:35 +01:00
|
|
|
RunExitNodeVisibility Key = "RunExitNode"
|
|
|
|
PreferencesMenuVisibility Key = "PreferencesMenu"
|
2023-11-07 02:42:28 +00:00
|
|
|
ExitNodeMenuVisibility Key = "ExitNodesPicker"
|
2023-12-07 17:01:31 +00:00
|
|
|
// AutoUpdateVisibility is the key to signal if the menu item for automatic
|
|
|
|
// installation of updates should be visible. It is only used by macsys
|
|
|
|
// installations and uses the Sparkle naming convention, even though it does
|
|
|
|
// not actually control updates, merely the UI for that setting.
|
|
|
|
AutoUpdateVisibility Key = "ApplyUpdates"
|
2023-09-29 18:40:35 +01:00
|
|
|
|
|
|
|
// Keys with a string value formatted for use with time.ParseDuration().
|
|
|
|
KeyExpirationNoticeTime Key = "KeyExpirationNotice" // default 24 hours
|
|
|
|
|
|
|
|
// Boolean Keys that are only applicable on Windows. Booleans are stored in the registry as
|
|
|
|
// DWORD or QWORD (either is acceptable). 0 means false, and anything else means true.
|
|
|
|
// The default is 0 unless otherwise stated.
|
|
|
|
LogSCMInteractions Key = "LogSCMInteractions"
|
|
|
|
FlushDNSOnSessionUnlock Key = "FlushDNSOnSessionUnlock"
|
2023-10-16 08:39:20 +01:00
|
|
|
|
|
|
|
// PostureChecking indicates if posture checking is enabled and the client shall gather
|
2023-10-06 14:00:04 +01:00
|
|
|
// posture data.
|
2023-10-16 08:39:20 +01:00
|
|
|
// Key is a string value that specifies an option: "always", "never", "user-decides".
|
|
|
|
// The default is "user-decides" unless otherwise stated.
|
2023-10-06 14:00:04 +01:00
|
|
|
PostureChecking Key = "PostureChecking"
|
2024-02-20 23:08:06 +00:00
|
|
|
|
|
|
|
// ManagedByOrganizationName indicates the name of the organization managing the Tailscale
|
|
|
|
// install. It is displayed inside the client UI in a prominent location.
|
|
|
|
ManagedByOrganizationName Key = "ManagedByOrganizationName"
|
|
|
|
// ManagedByCaption is an info message displayed inside the client UI as a caption when
|
|
|
|
// ManagedByOrganizationName is set. It can be used to provide a pointer to support resources
|
|
|
|
// for Tailscale within the organization.
|
|
|
|
ManagedByCaption Key = "ManagedByCaption"
|
2024-02-22 18:10:31 +00:00
|
|
|
// ManagedByURL is a valid URL pointing to a support help desk for Tailscale within the
|
2024-02-20 23:08:06 +00:00
|
|
|
// organization. A button in the client UI provides easy access to this URL.
|
|
|
|
ManagedByURL Key = "ManagedByURL"
|
2023-09-29 18:40:35 +01:00
|
|
|
)
|