2022-05-01 16:15:14 -07:00
|
|
|
// Copyright (c) 2022 Tailscale Inc & AUTHORS All rights reserved.
|
2020-07-24 17:59:49 +10:00
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2022-05-01 16:24:54 -07:00
|
|
|
// Code generated by tailscale.com/cmd/cloner; DO NOT EDIT.
|
2020-07-24 17:59:49 +10:00
|
|
|
|
|
|
|
package tailcfg
|
|
|
|
|
|
|
|
import (
|
2022-07-24 20:08:42 -07:00
|
|
|
"net/netip"
|
2022-04-29 13:30:54 -07:00
|
|
|
"time"
|
|
|
|
|
2021-08-05 14:05:24 -07:00
|
|
|
"tailscale.com/types/dnstype"
|
2021-09-03 13:17:46 -07:00
|
|
|
"tailscale.com/types/key"
|
2020-09-04 15:19:54 -07:00
|
|
|
"tailscale.com/types/opt"
|
|
|
|
"tailscale.com/types/structs"
|
2020-07-24 17:59:49 +10:00
|
|
|
)
|
|
|
|
|
|
|
|
// Clone makes a deep copy of User.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *User) Clone() *User {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(User)
|
|
|
|
*dst = *src
|
2020-07-27 10:40:34 -07:00
|
|
|
dst.Logins = append(src.Logins[:0:0], src.Logins...)
|
2020-07-24 17:59:49 +10:00
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
2021-09-15 10:05:34 -07:00
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
2021-09-16 15:58:43 -07:00
|
|
|
var _UserCloneNeedsRegeneration = User(struct {
|
2020-09-04 15:19:54 -07:00
|
|
|
ID UserID
|
|
|
|
LoginName string
|
|
|
|
DisplayName string
|
|
|
|
ProfilePicURL string
|
|
|
|
Domain string
|
|
|
|
Logins []LoginID
|
|
|
|
Created time.Time
|
|
|
|
}{})
|
|
|
|
|
2020-07-24 17:59:49 +10:00
|
|
|
// Clone makes a deep copy of Node.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *Node) Clone() *Node {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(Node)
|
|
|
|
*dst = *src
|
2020-07-27 10:40:34 -07:00
|
|
|
dst.Addresses = append(src.Addresses[:0:0], src.Addresses...)
|
|
|
|
dst.AllowedIPs = append(src.AllowedIPs[:0:0], src.AllowedIPs...)
|
|
|
|
dst.Endpoints = append(src.Endpoints[:0:0], src.Endpoints...)
|
2022-02-15 08:19:44 -08:00
|
|
|
dst.Hostinfo = src.Hostinfo
|
2021-10-20 14:26:31 -07:00
|
|
|
dst.Tags = append(src.Tags[:0:0], src.Tags...)
|
2021-07-27 08:01:29 -07:00
|
|
|
dst.PrimaryRoutes = append(src.PrimaryRoutes[:0:0], src.PrimaryRoutes...)
|
2020-07-24 17:59:49 +10:00
|
|
|
if dst.LastSeen != nil {
|
|
|
|
dst.LastSeen = new(time.Time)
|
|
|
|
*dst.LastSeen = *src.LastSeen
|
|
|
|
}
|
2021-04-15 16:03:59 -07:00
|
|
|
if dst.Online != nil {
|
|
|
|
dst.Online = new(bool)
|
|
|
|
*dst.Online = *src.Online
|
|
|
|
}
|
2021-04-01 14:03:34 -07:00
|
|
|
dst.Capabilities = append(src.Capabilities[:0:0], src.Capabilities...)
|
2020-07-24 17:59:49 +10:00
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
2021-09-15 10:05:34 -07:00
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
2021-09-16 15:58:43 -07:00
|
|
|
var _NodeCloneNeedsRegeneration = Node(struct {
|
2021-01-27 11:50:31 -05:00
|
|
|
ID NodeID
|
|
|
|
StableID StableNodeID
|
|
|
|
Name string
|
|
|
|
User UserID
|
|
|
|
Sharer UserID
|
2021-11-01 20:55:52 -07:00
|
|
|
Key key.NodePublic
|
2021-01-27 11:50:31 -05:00
|
|
|
KeyExpiry time.Time
|
2021-09-03 13:17:46 -07:00
|
|
|
Machine key.MachinePublic
|
2021-11-02 14:41:56 -07:00
|
|
|
DiscoKey key.DiscoPublic
|
2022-07-24 20:08:42 -07:00
|
|
|
Addresses []netip.Prefix
|
|
|
|
AllowedIPs []netip.Prefix
|
2021-01-27 11:50:31 -05:00
|
|
|
Endpoints []string
|
|
|
|
DERP string
|
2022-02-15 08:19:44 -08:00
|
|
|
Hostinfo HostinfoView
|
2021-01-27 11:50:31 -05:00
|
|
|
Created time.Time
|
2021-10-20 14:26:31 -07:00
|
|
|
Tags []string
|
2022-07-24 20:08:42 -07:00
|
|
|
PrimaryRoutes []netip.Prefix
|
2021-01-27 11:50:31 -05:00
|
|
|
LastSeen *time.Time
|
2021-04-15 16:03:59 -07:00
|
|
|
Online *bool
|
2021-01-27 11:50:31 -05:00
|
|
|
KeepAlive bool
|
|
|
|
MachineAuthorized bool
|
2021-04-01 14:03:34 -07:00
|
|
|
Capabilities []string
|
2021-01-27 11:50:31 -05:00
|
|
|
ComputedName string
|
|
|
|
computedHostIfDifferent string
|
|
|
|
ComputedNameWithHost string
|
2020-09-04 15:19:54 -07:00
|
|
|
}{})
|
|
|
|
|
2020-07-27 10:40:34 -07:00
|
|
|
// Clone makes a deep copy of Hostinfo.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *Hostinfo) Clone() *Hostinfo {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(Hostinfo)
|
|
|
|
*dst = *src
|
|
|
|
dst.RoutableIPs = append(src.RoutableIPs[:0:0], src.RoutableIPs...)
|
|
|
|
dst.RequestTags = append(src.RequestTags[:0:0], src.RequestTags...)
|
|
|
|
dst.Services = append(src.Services[:0:0], src.Services...)
|
|
|
|
dst.NetInfo = src.NetInfo.Clone()
|
2022-02-17 15:00:41 -08:00
|
|
|
dst.SSH_HostKeys = append(src.SSH_HostKeys[:0:0], src.SSH_HostKeys...)
|
2020-07-27 10:40:34 -07:00
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
2021-09-15 10:05:34 -07:00
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
2021-09-16 15:58:43 -07:00
|
|
|
var _HostinfoCloneNeedsRegeneration = Hostinfo(struct {
|
2020-09-04 15:19:54 -07:00
|
|
|
IPNVersion string
|
|
|
|
FrontendLogID string
|
|
|
|
BackendLogID string
|
|
|
|
OS string
|
|
|
|
OSVersion string
|
2022-04-07 11:42:48 -07:00
|
|
|
Desktop opt.Bool
|
2021-02-15 12:58:56 -08:00
|
|
|
Package string
|
2020-09-04 15:19:54 -07:00
|
|
|
DeviceModel string
|
|
|
|
Hostname string
|
2020-11-24 10:51:13 -05:00
|
|
|
ShieldsUp bool
|
2020-11-30 18:05:51 -08:00
|
|
|
ShareeNode bool
|
2020-09-04 15:19:54 -07:00
|
|
|
GoArch string
|
2022-07-24 20:08:42 -07:00
|
|
|
RoutableIPs []netip.Prefix
|
2020-09-04 15:19:54 -07:00
|
|
|
RequestTags []string
|
|
|
|
Services []Service
|
|
|
|
NetInfo *NetInfo
|
2022-02-17 15:00:41 -08:00
|
|
|
SSH_HostKeys []string
|
2022-06-29 22:58:44 -07:00
|
|
|
Cloud string
|
2020-09-04 15:19:54 -07:00
|
|
|
}{})
|
|
|
|
|
2020-07-24 17:59:49 +10:00
|
|
|
// Clone makes a deep copy of NetInfo.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *NetInfo) Clone() *NetInfo {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(NetInfo)
|
|
|
|
*dst = *src
|
|
|
|
if dst.DERPLatency != nil {
|
|
|
|
dst.DERPLatency = map[string]float64{}
|
|
|
|
for k, v := range src.DERPLatency {
|
|
|
|
dst.DERPLatency[k] = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return dst
|
|
|
|
}
|
2020-08-21 08:31:19 -04:00
|
|
|
|
2021-09-15 10:05:34 -07:00
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
2021-09-16 15:58:43 -07:00
|
|
|
var _NetInfoCloneNeedsRegeneration = NetInfo(struct {
|
2020-09-04 15:19:54 -07:00
|
|
|
MappingVariesByDestIP opt.Bool
|
|
|
|
HairPinning opt.Bool
|
|
|
|
WorkingIPv6 opt.Bool
|
2022-07-18 16:56:10 -07:00
|
|
|
OSHasIPv6 opt.Bool
|
2020-09-04 15:19:54 -07:00
|
|
|
WorkingUDP opt.Bool
|
2021-03-09 15:09:10 -08:00
|
|
|
HavePortMap bool
|
2020-09-04 15:19:54 -07:00
|
|
|
UPnP opt.Bool
|
|
|
|
PMP opt.Bool
|
|
|
|
PCP opt.Bool
|
|
|
|
PreferredDERP int
|
|
|
|
LinkType string
|
|
|
|
DERPLatency map[string]float64
|
|
|
|
}{})
|
|
|
|
|
2020-09-04 07:41:30 -04:00
|
|
|
// Clone makes a deep copy of Login.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *Login) Clone() *Login {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(Login)
|
|
|
|
*dst = *src
|
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
2021-09-15 10:05:34 -07:00
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
2021-09-16 15:58:43 -07:00
|
|
|
var _LoginCloneNeedsRegeneration = Login(struct {
|
2020-09-04 15:19:54 -07:00
|
|
|
_ structs.Incomparable
|
|
|
|
ID LoginID
|
|
|
|
Provider string
|
|
|
|
LoginName string
|
|
|
|
DisplayName string
|
|
|
|
ProfilePicURL string
|
|
|
|
Domain string
|
|
|
|
}{})
|
|
|
|
|
2020-09-04 07:41:30 -04:00
|
|
|
// Clone makes a deep copy of DNSConfig.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *DNSConfig) Clone() *DNSConfig {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(DNSConfig)
|
|
|
|
*dst = *src
|
2022-05-03 14:41:58 -07:00
|
|
|
dst.Resolvers = make([]*dnstype.Resolver, len(src.Resolvers))
|
2021-04-08 01:35:14 -07:00
|
|
|
for i := range dst.Resolvers {
|
2022-05-03 14:41:58 -07:00
|
|
|
dst.Resolvers[i] = src.Resolvers[i].Clone()
|
2021-04-08 01:35:14 -07:00
|
|
|
}
|
|
|
|
if dst.Routes != nil {
|
2022-05-03 14:41:58 -07:00
|
|
|
dst.Routes = map[string][]*dnstype.Resolver{}
|
2021-04-08 01:35:14 -07:00
|
|
|
for k := range src.Routes {
|
2022-05-03 14:41:58 -07:00
|
|
|
dst.Routes[k] = append([]*dnstype.Resolver{}, src.Routes[k]...)
|
2021-04-08 01:35:14 -07:00
|
|
|
}
|
|
|
|
}
|
2022-05-03 14:41:58 -07:00
|
|
|
dst.FallbackResolvers = make([]*dnstype.Resolver, len(src.FallbackResolvers))
|
2021-04-19 21:30:39 -07:00
|
|
|
for i := range dst.FallbackResolvers {
|
2022-05-03 14:41:58 -07:00
|
|
|
dst.FallbackResolvers[i] = src.FallbackResolvers[i].Clone()
|
2021-04-19 21:30:39 -07:00
|
|
|
}
|
2020-09-04 07:41:30 -04:00
|
|
|
dst.Domains = append(src.Domains[:0:0], src.Domains...)
|
2021-04-08 01:35:14 -07:00
|
|
|
dst.Nameservers = append(src.Nameservers[:0:0], src.Nameservers...)
|
2021-06-15 12:12:15 -07:00
|
|
|
dst.CertDomains = append(src.CertDomains[:0:0], src.CertDomains...)
|
2021-06-16 10:58:25 -07:00
|
|
|
dst.ExtraRecords = append(src.ExtraRecords[:0:0], src.ExtraRecords...)
|
2021-11-29 14:18:09 -08:00
|
|
|
dst.ExitNodeFilteredSet = append(src.ExitNodeFilteredSet[:0:0], src.ExitNodeFilteredSet...)
|
2020-09-04 07:41:30 -04:00
|
|
|
return dst
|
|
|
|
}
|
2020-09-04 15:19:54 -07:00
|
|
|
|
2021-09-15 10:05:34 -07:00
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
2021-09-16 15:58:43 -07:00
|
|
|
var _DNSConfigCloneNeedsRegeneration = DNSConfig(struct {
|
2022-05-03 14:41:58 -07:00
|
|
|
Resolvers []*dnstype.Resolver
|
|
|
|
Routes map[string][]*dnstype.Resolver
|
|
|
|
FallbackResolvers []*dnstype.Resolver
|
2021-11-29 14:18:09 -08:00
|
|
|
Domains []string
|
|
|
|
Proxied bool
|
2022-07-24 20:08:42 -07:00
|
|
|
Nameservers []netip.Addr
|
2021-11-29 14:18:09 -08:00
|
|
|
PerDomain bool
|
|
|
|
CertDomains []string
|
|
|
|
ExtraRecords []DNSRecord
|
|
|
|
ExitNodeFilteredSet []string
|
2021-04-08 01:35:14 -07:00
|
|
|
}{})
|
|
|
|
|
2020-10-06 14:02:57 -04:00
|
|
|
// Clone makes a deep copy of RegisterResponse.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *RegisterResponse) Clone() *RegisterResponse {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(RegisterResponse)
|
|
|
|
*dst = *src
|
|
|
|
dst.User = *src.User.Clone()
|
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
2021-09-15 10:05:34 -07:00
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
2021-09-16 15:58:43 -07:00
|
|
|
var _RegisterResponseCloneNeedsRegeneration = RegisterResponse(struct {
|
2020-10-06 14:02:57 -04:00
|
|
|
User User
|
|
|
|
Login Login
|
|
|
|
NodeKeyExpired bool
|
|
|
|
MachineAuthorized bool
|
|
|
|
AuthURL string
|
2021-10-26 10:19:35 -07:00
|
|
|
Error string
|
2020-10-06 14:02:57 -04:00
|
|
|
}{})
|
|
|
|
|
2021-06-22 22:01:11 -07:00
|
|
|
// Clone makes a deep copy of DERPRegion.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *DERPRegion) Clone() *DERPRegion {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(DERPRegion)
|
|
|
|
*dst = *src
|
|
|
|
dst.Nodes = make([]*DERPNode, len(src.Nodes))
|
|
|
|
for i := range dst.Nodes {
|
|
|
|
dst.Nodes[i] = src.Nodes[i].Clone()
|
|
|
|
}
|
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
2021-09-15 10:05:34 -07:00
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
2021-09-16 15:58:43 -07:00
|
|
|
var _DERPRegionCloneNeedsRegeneration = DERPRegion(struct {
|
2021-06-22 22:01:11 -07:00
|
|
|
RegionID int
|
|
|
|
RegionCode string
|
|
|
|
RegionName string
|
|
|
|
Avoid bool
|
|
|
|
Nodes []*DERPNode
|
|
|
|
}{})
|
|
|
|
|
|
|
|
// Clone makes a deep copy of DERPMap.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *DERPMap) Clone() *DERPMap {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(DERPMap)
|
|
|
|
*dst = *src
|
|
|
|
if dst.Regions != nil {
|
|
|
|
dst.Regions = map[int]*DERPRegion{}
|
|
|
|
for k, v := range src.Regions {
|
|
|
|
dst.Regions[k] = v.Clone()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
2021-09-15 10:05:34 -07:00
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
2021-09-16 15:58:43 -07:00
|
|
|
var _DERPMapCloneNeedsRegeneration = DERPMap(struct {
|
2021-06-22 16:24:32 -07:00
|
|
|
Regions map[int]*DERPRegion
|
|
|
|
OmitDefaultRegions bool
|
2021-06-22 22:01:11 -07:00
|
|
|
}{})
|
|
|
|
|
|
|
|
// Clone makes a deep copy of DERPNode.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *DERPNode) Clone() *DERPNode {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(DERPNode)
|
|
|
|
*dst = *src
|
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
2021-09-15 10:05:34 -07:00
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
2021-09-16 15:58:43 -07:00
|
|
|
var _DERPNodeCloneNeedsRegeneration = DERPNode(struct {
|
2021-07-09 11:16:43 -07:00
|
|
|
Name string
|
|
|
|
RegionID int
|
|
|
|
HostName string
|
|
|
|
CertName string
|
|
|
|
IPv4 string
|
|
|
|
IPv6 string
|
|
|
|
STUNPort int
|
|
|
|
STUNOnly bool
|
|
|
|
DERPPort int
|
|
|
|
InsecureForTests bool
|
|
|
|
STUNTestIP string
|
2021-06-22 22:01:11 -07:00
|
|
|
}{})
|
|
|
|
|
2022-07-26 20:48:38 -07:00
|
|
|
// Clone makes a deep copy of SSHRule.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *SSHRule) Clone() *SSHRule {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(SSHRule)
|
|
|
|
*dst = *src
|
|
|
|
if dst.RuleExpires != nil {
|
|
|
|
dst.RuleExpires = new(time.Time)
|
|
|
|
*dst.RuleExpires = *src.RuleExpires
|
|
|
|
}
|
|
|
|
dst.Principals = make([]*SSHPrincipal, len(src.Principals))
|
|
|
|
for i := range dst.Principals {
|
|
|
|
dst.Principals[i] = src.Principals[i].Clone()
|
|
|
|
}
|
|
|
|
if dst.SSHUsers != nil {
|
|
|
|
dst.SSHUsers = map[string]string{}
|
|
|
|
for k, v := range src.SSHUsers {
|
|
|
|
dst.SSHUsers[k] = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if dst.Action != nil {
|
|
|
|
dst.Action = new(SSHAction)
|
|
|
|
*dst.Action = *src.Action
|
|
|
|
}
|
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
|
|
|
var _SSHRuleCloneNeedsRegeneration = SSHRule(struct {
|
|
|
|
RuleExpires *time.Time
|
|
|
|
Principals []*SSHPrincipal
|
|
|
|
SSHUsers map[string]string
|
|
|
|
Action *SSHAction
|
|
|
|
}{})
|
|
|
|
|
|
|
|
// Clone makes a deep copy of SSHPrincipal.
|
|
|
|
// The result aliases no memory with the original.
|
|
|
|
func (src *SSHPrincipal) Clone() *SSHPrincipal {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
dst := new(SSHPrincipal)
|
|
|
|
*dst = *src
|
|
|
|
dst.PubKeys = append(src.PubKeys[:0:0], src.PubKeys...)
|
|
|
|
return dst
|
|
|
|
}
|
|
|
|
|
|
|
|
// A compilation failure here means this code must be regenerated, with the command at the top of this file.
|
|
|
|
var _SSHPrincipalCloneNeedsRegeneration = SSHPrincipal(struct {
|
|
|
|
Node StableNodeID
|
|
|
|
NodeIP string
|
|
|
|
UserLogin string
|
|
|
|
Any bool
|
|
|
|
PubKeys []string
|
|
|
|
}{})
|
|
|
|
|
2020-09-04 15:19:54 -07:00
|
|
|
// Clone duplicates src into dst and reports whether it succeeded.
|
|
|
|
// To succeed, <src, dst> must be of types <*T, *T> or <*T, **T>,
|
2022-07-26 20:48:38 -07:00
|
|
|
// where T is one of User,Node,Hostinfo,NetInfo,Login,DNSConfig,RegisterResponse,DERPRegion,DERPMap,DERPNode,SSHRule,SSHPrincipal.
|
2022-03-16 16:27:57 -07:00
|
|
|
func Clone(dst, src any) bool {
|
2020-09-04 15:19:54 -07:00
|
|
|
switch src := src.(type) {
|
|
|
|
case *User:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *User:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **User:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
case *Node:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *Node:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **Node:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
case *Hostinfo:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *Hostinfo:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **Hostinfo:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
case *NetInfo:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *NetInfo:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **NetInfo:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
case *Login:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *Login:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **Login:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
case *DNSConfig:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *DNSConfig:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **DNSConfig:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
2020-10-06 14:02:57 -04:00
|
|
|
case *RegisterResponse:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *RegisterResponse:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **RegisterResponse:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
2021-06-22 22:01:11 -07:00
|
|
|
case *DERPRegion:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *DERPRegion:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **DERPRegion:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
case *DERPMap:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *DERPMap:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **DERPMap:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
case *DERPNode:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *DERPNode:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **DERPNode:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
2022-07-26 20:48:38 -07:00
|
|
|
case *SSHRule:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *SSHRule:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **SSHRule:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
case *SSHPrincipal:
|
|
|
|
switch dst := dst.(type) {
|
|
|
|
case *SSHPrincipal:
|
|
|
|
*dst = *src.Clone()
|
|
|
|
return true
|
|
|
|
case **SSHPrincipal:
|
|
|
|
*dst = src.Clone()
|
|
|
|
return true
|
|
|
|
}
|
2020-09-04 15:19:54 -07:00
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|