mqtt.go 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. package models
  2. import (
  3. "net"
  4. "golang.zx2c4.com/wireguard/wgctrl/wgtypes"
  5. )
  6. // HostPeerUpdate - struct for host peer updates
  7. type HostPeerUpdate struct {
  8. Host Host `json:"host" bson:"host" yaml:"host"`
  9. ChangeDefaultGw bool `json:"change_default_gw"`
  10. DefaultGwIp net.IP `json:"default_gw_ip"`
  11. IsInternetGw bool `json:"is_inet_gw"`
  12. NodeAddrs []net.IPNet `json:"nodes_addrs" yaml:"nodes_addrs"`
  13. Server string `json:"server" bson:"server" yaml:"server"`
  14. ServerVersion string `json:"serverversion" bson:"serverversion" yaml:"serverversion"`
  15. ServerAddrs []ServerAddr `json:"serveraddrs" bson:"serveraddrs" yaml:"serveraddrs"`
  16. NodePeers []wgtypes.PeerConfig `json:"peers" bson:"peers" yaml:"peers"`
  17. Peers []wgtypes.PeerConfig
  18. PeerIDs PeerMap `json:"peerids" bson:"peerids" yaml:"peerids"`
  19. HostNetworkInfo HostInfoMap `json:"host_network_info,omitempty" bson:"host_network_info,omitempty" yaml:"host_network_info,omitempty"`
  20. EgressRoutes []EgressNetworkRoutes `json:"egress_network_routes"`
  21. FwUpdate FwUpdate `json:"fw_update"`
  22. ReplacePeers bool `json:"replace_peers"`
  23. EndpointDetection bool `json:"endpoint_detection"`
  24. ManageDNS bool `yaml:"manage_dns"`
  25. }
  26. type FwRule struct {
  27. SrcIP net.IPNet `json:"src_ip"`
  28. DstIP net.IPNet `json:"dst_ip"`
  29. Allow bool `json:"allow"`
  30. }
  31. // IngressInfo - struct for ingress info
  32. type IngressInfo struct {
  33. IngressID string `json:"ingress_id"`
  34. Network net.IPNet `json:"network"`
  35. Network6 net.IPNet `json:"network6"`
  36. StaticNodeIps []net.IP `json:"static_node_ips"`
  37. Rules []FwRule `json:"rules"`
  38. AllowAll bool `json:"allow_all"`
  39. EgressRanges []net.IPNet `json:"egress_ranges"`
  40. EgressRanges6 []net.IPNet `json:"egress_ranges6"`
  41. }
  42. // EgressInfo - struct for egress info
  43. type EgressInfo struct {
  44. EgressID string `json:"egress_id" yaml:"egress_id"`
  45. Network net.IPNet `json:"network" yaml:"network"`
  46. EgressGwAddr net.IPNet `json:"egress_gw_addr" yaml:"egress_gw_addr"`
  47. Network6 net.IPNet `json:"network6" yaml:"network6"`
  48. EgressGwAddr6 net.IPNet `json:"egress_gw_addr6" yaml:"egress_gw_addr6"`
  49. EgressGWCfg EgressGatewayRequest `json:"egress_gateway_cfg" yaml:"egress_gateway_cfg"`
  50. }
  51. // EgressNetworkRoutes - struct for egress network routes for adding routes to peer's interface
  52. type EgressNetworkRoutes struct {
  53. EgressGwAddr net.IPNet `json:"egress_gw_addr" yaml:"egress_gw_addr"`
  54. EgressGwAddr6 net.IPNet `json:"egress_gw_addr6" yaml:"egress_gw_addr6"`
  55. NodeAddr net.IPNet `json:"node_addr"`
  56. NodeAddr6 net.IPNet `json:"node_addr6"`
  57. EgressRanges []string `json:"egress_ranges"`
  58. }
  59. // PeerRouteInfo - struct for peer info for an ext. client
  60. type PeerRouteInfo struct {
  61. PeerAddr net.IPNet `json:"peer_addr" yaml:"peer_addr"`
  62. PeerKey string `json:"peer_key" yaml:"peer_key"`
  63. Allow bool `json:"allow" yaml:"allow"`
  64. ID string `json:"id,omitempty" yaml:"id,omitempty"`
  65. }
  66. // ExtClientInfo - struct for ext. client and it's peers
  67. type ExtClientInfo struct {
  68. IngGwAddr net.IPNet `json:"ingress_gw_addr" yaml:"ingress_gw_addr"`
  69. Network net.IPNet `json:"network" yaml:"network"`
  70. Masquerade bool `json:"masquerade" yaml:"masquerade"`
  71. ExtPeerAddr net.IPNet `json:"ext_peer_addr" yaml:"ext_peer_addr"`
  72. ExtPeerKey string `json:"ext_peer_key" yaml:"ext_peer_key"`
  73. Peers map[string]PeerRouteInfo `json:"peers" yaml:"peers"`
  74. }
  75. // KeyUpdate - key update struct
  76. type KeyUpdate struct {
  77. Network string `json:"network" bson:"network"`
  78. Interface string `json:"interface" bson:"interface"`
  79. }
  80. // FwUpdate - struct for firewall updates
  81. type FwUpdate struct {
  82. Networks []net.IPNet `json:"networks"`
  83. IsEgressGw bool `json:"is_egress_gw"`
  84. IsIngressGw bool `json:"is_ingress_gw"`
  85. EgressInfo map[string]EgressInfo `json:"egress_info"`
  86. IngressInfo map[string]IngressInfo `json:"ingress_info"`
  87. AclRules map[string]AclRule `json:"acl_rules"`
  88. }
  89. // FailOverMeReq - struct for failover req
  90. type FailOverMeReq struct {
  91. NodeID string `json:"node_id"`
  92. }