mirror of
https://github.com/juanfont/headscale.git
synced 2026-05-27 20:51:31 +09:00
types/config, types/node: model default-auto-update from auto_update.enabled
Tailscale stamps tailcfg.NodeAttrDefaultAutoUpdate on every node's CapMap with a JSON bool reflecting the tailnet-wide auto-update default. Headscale grows an auto_update.enabled config option and emits the cap accordingly from TailNode -- the cap leaves the unmodelledTailnetStateCaps strip list and is compared in full by the nodeAttrs compat suite. testNodeAttrsSuccess drives cfg.AutoUpdate.Enabled from tf.Input.Tailnet.Settings.DevicesAutoUpdatesOn so each capture's expected emission matches the SaaS state it was taken under. Two captures cover both branches: - nodeattrs-tailnet-devices-auto-updates-on -> [true] - nodeattrs-tailnet-devices-auto-updates-off -> [false] The Tailscale v2 TailnetSettings API does not expose the Send Files toggle, so the compat suite cannot vary cfg.Taildrop.Enabled per capture. TestTaildropDisabledWithholdsFileSharingCap covers the off path directly in servertest.
This commit is contained in:
@@ -1203,6 +1203,18 @@ func (nv NodeView) TailNode(
|
||||
capMap[tailcfg.CapabilityFileSharing] = []tailcfg.RawMessage{}
|
||||
}
|
||||
|
||||
// default-auto-update is always emitted; the value is a JSON bool
|
||||
// reflecting cfg.AutoUpdate.Enabled. Clients read this on first
|
||||
// netmap and store the default locally; subsequent control-plane
|
||||
// changes are ignored unless the client has not yet opted in or
|
||||
// out.
|
||||
autoUpdateVal := tailcfg.RawMessage("false")
|
||||
if cfg.AutoUpdate.Enabled {
|
||||
autoUpdateVal = tailcfg.RawMessage("true")
|
||||
}
|
||||
|
||||
capMap[tailcfg.NodeAttrDefaultAutoUpdate] = []tailcfg.RawMessage{autoUpdateVal}
|
||||
|
||||
// Policy nodeAttrs overlay the baseline on the self view. Peers
|
||||
// pass nil; their CapMap is replaced downstream by [policyv2.PeerCapMap].
|
||||
maps.Copy(capMap, selfPolicyCaps)
|
||||
|
||||
Reference in New Issue
Block a user