api_node.go 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. package models
  2. import (
  3. "net"
  4. "time"
  5. "github.com/google/uuid"
  6. )
  7. // ApiNode is a stripped down Node DTO that exposes only required fields to external systems
  8. type ApiNode struct {
  9. ID string `json:"id,omitempty" validate:"required,min=5,id_unique"`
  10. HostID string `json:"hostid,omitempty" validate:"required,min=5,id_unique"`
  11. Address string `json:"address" validate:"omitempty,ipv4"`
  12. Address6 string `json:"address6" validate:"omitempty,ipv6"`
  13. LocalAddress string `json:"localaddress" validate:"omitempty,ipv4"`
  14. AllowedIPs []string `json:"allowedips"`
  15. LastModified int64 `json:"lastmodified"`
  16. ExpirationDateTime int64 `json:"expdatetime"`
  17. LastCheckIn int64 `json:"lastcheckin"`
  18. LastPeerUpdate int64 `json:"lastpeerupdate"`
  19. Network string `json:"network"`
  20. NetworkRange string `json:"networkrange"`
  21. NetworkRange6 string `json:"networkrange6"`
  22. IsRelayed bool `json:"isrelayed"`
  23. IsRelay bool `json:"isrelay"`
  24. RelayedBy string `json:"relayedby" bson:"relayedby" yaml:"relayedby"`
  25. RelayedNodes []string `json:"relaynodes" yaml:"relayedNodes"`
  26. IsEgressGateway bool `json:"isegressgateway"`
  27. IsIngressGateway bool `json:"isingressgateway"`
  28. EgressGatewayRanges []string `json:"egressgatewayranges"`
  29. EgressGatewayNatEnabled bool `json:"egressgatewaynatenabled"`
  30. FailoverNode string `json:"failovernode"`
  31. DNSOn bool `json:"dnson"`
  32. IngressDns string `json:"ingressdns"`
  33. Server string `json:"server"`
  34. InternetGateway string `json:"internetgateway"`
  35. Connected bool `json:"connected"`
  36. PendingDelete bool `json:"pendingdelete"`
  37. // == PRO ==
  38. DefaultACL string `json:"defaultacl,omitempty" validate:"checkyesornoorunset"`
  39. Failover bool `json:"failover"`
  40. }
  41. // ApiNode.ConvertToServerNode - converts an api node to a server node
  42. func (a *ApiNode) ConvertToServerNode(currentNode *Node) *Node {
  43. convertedNode := Node{}
  44. convertedNode.Network = a.Network
  45. convertedNode.Server = a.Server
  46. convertedNode.Action = currentNode.Action
  47. convertedNode.Connected = a.Connected
  48. convertedNode.ID, _ = uuid.Parse(a.ID)
  49. convertedNode.HostID, _ = uuid.Parse(a.HostID)
  50. convertedNode.IsRelay = a.IsRelay
  51. convertedNode.IsRelayed = a.IsRelayed
  52. convertedNode.RelayedBy = a.RelayedBy
  53. convertedNode.RelayedNodes = a.RelayedNodes
  54. convertedNode.PendingDelete = a.PendingDelete
  55. convertedNode.Failover = a.Failover
  56. convertedNode.IsEgressGateway = a.IsEgressGateway
  57. convertedNode.IsIngressGateway = a.IsIngressGateway
  58. // prevents user from changing ranges, must delete and recreate
  59. convertedNode.EgressGatewayRanges = currentNode.EgressGatewayRanges
  60. convertedNode.IngressGatewayRange = currentNode.IngressGatewayRange
  61. convertedNode.IngressGatewayRange6 = currentNode.IngressGatewayRange6
  62. convertedNode.DNSOn = a.DNSOn
  63. convertedNode.IngressDNS = a.IngressDns
  64. convertedNode.EgressGatewayRequest = currentNode.EgressGatewayRequest
  65. convertedNode.EgressGatewayNatEnabled = currentNode.EgressGatewayNatEnabled
  66. convertedNode.RelayedNodes = a.RelayedNodes
  67. convertedNode.DefaultACL = a.DefaultACL
  68. convertedNode.OwnerID = currentNode.OwnerID
  69. _, networkRange, err := net.ParseCIDR(a.NetworkRange)
  70. if err == nil {
  71. convertedNode.NetworkRange = *networkRange
  72. }
  73. _, networkRange6, err := net.ParseCIDR(a.NetworkRange6)
  74. if err == nil {
  75. convertedNode.NetworkRange6 = *networkRange6
  76. }
  77. if len(a.LocalAddress) > 0 {
  78. _, localAddr, err := net.ParseCIDR(a.LocalAddress)
  79. if err == nil {
  80. convertedNode.LocalAddress = *localAddr
  81. }
  82. } else if !isEmptyAddr(currentNode.LocalAddress.String()) {
  83. convertedNode.LocalAddress = currentNode.LocalAddress
  84. }
  85. udpAddr, err := net.ResolveUDPAddr("udp", a.InternetGateway)
  86. if err == nil {
  87. convertedNode.InternetGateway = udpAddr
  88. }
  89. ip, addr, err := net.ParseCIDR(a.Address)
  90. if err == nil {
  91. convertedNode.Address = *addr
  92. convertedNode.Address.IP = ip
  93. }
  94. ip6, addr6, err := net.ParseCIDR(a.Address6)
  95. if err == nil {
  96. convertedNode.Address6 = *addr6
  97. convertedNode.Address6.IP = ip6
  98. }
  99. convertedNode.FailoverNode, _ = uuid.Parse(a.FailoverNode)
  100. convertedNode.LastModified = time.Unix(a.LastModified, 0)
  101. convertedNode.LastCheckIn = time.Unix(a.LastCheckIn, 0)
  102. convertedNode.LastPeerUpdate = time.Unix(a.LastPeerUpdate, 0)
  103. convertedNode.ExpirationDateTime = time.Unix(a.ExpirationDateTime, 0)
  104. return &convertedNode
  105. }
  106. // Node.ConvertToAPINode - converts a node to an API node
  107. func (nm *Node) ConvertToAPINode() *ApiNode {
  108. apiNode := ApiNode{}
  109. apiNode.ID = nm.ID.String()
  110. apiNode.HostID = nm.HostID.String()
  111. apiNode.Address = nm.Address.String()
  112. if isEmptyAddr(apiNode.Address) {
  113. apiNode.Address = ""
  114. }
  115. apiNode.Address6 = nm.Address6.String()
  116. if isEmptyAddr(apiNode.Address6) {
  117. apiNode.Address6 = ""
  118. }
  119. apiNode.LocalAddress = nm.LocalAddress.String()
  120. if isEmptyAddr(apiNode.LocalAddress) {
  121. apiNode.LocalAddress = ""
  122. }
  123. apiNode.LastModified = nm.LastModified.Unix()
  124. apiNode.LastCheckIn = nm.LastCheckIn.Unix()
  125. apiNode.LastPeerUpdate = nm.LastPeerUpdate.Unix()
  126. apiNode.ExpirationDateTime = nm.ExpirationDateTime.Unix()
  127. apiNode.Network = nm.Network
  128. apiNode.NetworkRange = nm.NetworkRange.String()
  129. if isEmptyAddr(apiNode.NetworkRange) {
  130. apiNode.NetworkRange = ""
  131. }
  132. apiNode.NetworkRange6 = nm.NetworkRange6.String()
  133. if isEmptyAddr(apiNode.NetworkRange6) {
  134. apiNode.NetworkRange6 = ""
  135. }
  136. apiNode.IsRelayed = nm.IsRelayed
  137. apiNode.IsRelay = nm.IsRelay
  138. apiNode.RelayedBy = nm.RelayedBy
  139. apiNode.RelayedNodes = nm.RelayedNodes
  140. apiNode.IsEgressGateway = nm.IsEgressGateway
  141. apiNode.IsIngressGateway = nm.IsIngressGateway
  142. apiNode.EgressGatewayRanges = nm.EgressGatewayRanges
  143. apiNode.EgressGatewayNatEnabled = nm.EgressGatewayNatEnabled
  144. apiNode.FailoverNode = nm.FailoverNode.String()
  145. if isUUIDSet(apiNode.FailoverNode) {
  146. apiNode.FailoverNode = ""
  147. }
  148. apiNode.DNSOn = nm.DNSOn
  149. apiNode.IngressDns = nm.IngressDNS
  150. apiNode.Server = nm.Server
  151. apiNode.InternetGateway = nm.InternetGateway.String()
  152. if isEmptyAddr(apiNode.InternetGateway) {
  153. apiNode.InternetGateway = ""
  154. }
  155. apiNode.Connected = nm.Connected
  156. apiNode.PendingDelete = nm.PendingDelete
  157. apiNode.DefaultACL = nm.DefaultACL
  158. apiNode.Failover = nm.Failover
  159. return &apiNode
  160. }
  161. func isEmptyAddr(addr string) bool {
  162. return addr == "<nil>" || addr == ":0"
  163. }
  164. func isUUIDSet(uuid string) bool {
  165. return uuid != "00000000-0000-0000-0000-000000000000"
  166. }