mirror of
https://github.com/gravitl/netmaker.git
synced 2025-09-05 20:54:18 +08:00
* move relevant acl and tag code to CE and Pro pkgs * intialise pro acl funcs * list gateways by user access * check user gw access by policies * filter out user policies on CE * filter out tagged policies on CE * fix ce acl comms * allow gateways tag * allow gateway tag on CE, remove failover and gw check on acl policy * add gw rules func to pro * add inet gw support on CE * add egress acl API * add egress acl API * fix(go): set is_gw when converting api node to server node; * fix(go): set is_gw when converting api node to server node; * fix policy validity checker for inet gws * move dns option to host model * fix node removal from egress policy on delete * add migration logic for ManageDNS * fix dns json field * fix nil error on node tags * add egress info to relayed nodes --------- Co-authored-by: Vishal Dalwadi <dalwadivishal26@gmail.com>
130 lines
4.5 KiB
Go
130 lines
4.5 KiB
Go
package models
|
|
|
|
import (
|
|
"net"
|
|
"strings"
|
|
"time"
|
|
)
|
|
|
|
// ApiHost - the host struct for API usage
|
|
type ApiHost struct {
|
|
ID string `json:"id"`
|
|
Verbosity int `json:"verbosity"`
|
|
FirewallInUse string `json:"firewallinuse"`
|
|
Version string `json:"version"`
|
|
Name string `json:"name"`
|
|
OS string `json:"os"`
|
|
Debug bool `json:"debug"`
|
|
IsStaticPort bool `json:"isstaticport"`
|
|
IsStatic bool `json:"isstatic"`
|
|
ListenPort int `json:"listenport"`
|
|
WgPublicListenPort int `json:"wg_public_listen_port" yaml:"wg_public_listen_port"`
|
|
MTU int `json:"mtu" yaml:"mtu"`
|
|
Interfaces []ApiIface `json:"interfaces" yaml:"interfaces"`
|
|
DefaultInterface string `json:"defaultinterface" yaml:"defautlinterface"`
|
|
EndpointIP string `json:"endpointip" yaml:"endpointip"`
|
|
EndpointIPv6 string `json:"endpointipv6" yaml:"endpointipv6"`
|
|
PublicKey string `json:"publickey"`
|
|
MacAddress string `json:"macaddress"`
|
|
Nodes []string `json:"nodes"`
|
|
IsDefault bool `json:"isdefault" yaml:"isdefault"`
|
|
NatType string `json:"nat_type" yaml:"nat_type"`
|
|
PersistentKeepalive int `json:"persistentkeepalive" yaml:"persistentkeepalive"`
|
|
AutoUpdate bool `json:"autoupdate" yaml:"autoupdate"`
|
|
DNS string `json:"dns" yaml:"dns"`
|
|
}
|
|
|
|
// ApiIface - the interface struct for API usage
|
|
// The original Iface struct contains a net.Address, which does not get marshalled correctly
|
|
type ApiIface struct {
|
|
Name string `json:"name"`
|
|
AddressString string `json:"addressString"`
|
|
}
|
|
|
|
// Host.ConvertNMHostToAPI - converts a Netmaker host to an API editable host
|
|
func (h *Host) ConvertNMHostToAPI() *ApiHost {
|
|
a := ApiHost{}
|
|
a.Debug = h.Debug
|
|
a.EndpointIP = h.EndpointIP.String()
|
|
if a.EndpointIP == "<nil>" {
|
|
a.EndpointIP = ""
|
|
}
|
|
a.EndpointIPv6 = h.EndpointIPv6.String()
|
|
if a.EndpointIPv6 == "<nil>" {
|
|
a.EndpointIPv6 = ""
|
|
}
|
|
a.FirewallInUse = h.FirewallInUse
|
|
a.ID = h.ID.String()
|
|
a.Interfaces = make([]ApiIface, len(h.Interfaces))
|
|
for i := range a.Interfaces {
|
|
a.Interfaces[i] = ApiIface{
|
|
Name: h.Interfaces[i].Name,
|
|
AddressString: h.Interfaces[i].Address.String(),
|
|
}
|
|
}
|
|
a.DefaultInterface = h.DefaultInterface
|
|
a.IsStaticPort = h.IsStaticPort
|
|
a.IsStatic = h.IsStatic
|
|
a.ListenPort = h.ListenPort
|
|
a.MTU = h.MTU
|
|
a.MacAddress = h.MacAddress.String()
|
|
a.Name = h.Name
|
|
a.OS = h.OS
|
|
a.Nodes = h.Nodes
|
|
a.WgPublicListenPort = h.WgPublicListenPort
|
|
a.PublicKey = h.PublicKey.String()
|
|
a.Verbosity = h.Verbosity
|
|
a.Version = h.Version
|
|
a.IsDefault = h.IsDefault
|
|
a.NatType = h.NatType
|
|
a.PersistentKeepalive = int(h.PersistentKeepalive.Seconds())
|
|
a.AutoUpdate = h.AutoUpdate
|
|
a.DNS = h.DNS
|
|
return &a
|
|
}
|
|
|
|
// APIHost.ConvertAPIHostToNMHost - convert's a given apihost struct to
|
|
// a Host struct
|
|
func (a *ApiHost) ConvertAPIHostToNMHost(currentHost *Host) *Host {
|
|
h := Host{}
|
|
h.ID = currentHost.ID
|
|
h.HostPass = currentHost.HostPass
|
|
h.DaemonInstalled = currentHost.DaemonInstalled
|
|
if len(a.EndpointIP) == 0 || strings.Contains(a.EndpointIP, "nil") {
|
|
h.EndpointIP = currentHost.EndpointIP
|
|
} else {
|
|
h.EndpointIP = net.ParseIP(a.EndpointIP)
|
|
}
|
|
if len(a.EndpointIPv6) == 0 || strings.Contains(a.EndpointIPv6, "nil") {
|
|
h.EndpointIPv6 = currentHost.EndpointIPv6
|
|
} else {
|
|
h.EndpointIPv6 = net.ParseIP(a.EndpointIPv6)
|
|
}
|
|
h.Debug = a.Debug
|
|
h.FirewallInUse = a.FirewallInUse
|
|
h.IPForwarding = currentHost.IPForwarding
|
|
h.Interface = currentHost.Interface
|
|
h.Interfaces = currentHost.Interfaces
|
|
h.DefaultInterface = currentHost.DefaultInterface
|
|
h.IsDocker = currentHost.IsDocker
|
|
h.IsK8S = currentHost.IsK8S
|
|
h.IsStaticPort = a.IsStaticPort
|
|
h.IsStatic = a.IsStatic
|
|
h.ListenPort = a.ListenPort
|
|
h.MTU = a.MTU
|
|
h.MacAddress = currentHost.MacAddress
|
|
h.PublicKey = currentHost.PublicKey
|
|
h.Name = a.Name
|
|
h.Version = currentHost.Version
|
|
h.Verbosity = a.Verbosity
|
|
h.Nodes = currentHost.Nodes
|
|
h.TrafficKeyPublic = currentHost.TrafficKeyPublic
|
|
h.OS = currentHost.OS
|
|
h.IsDefault = a.IsDefault
|
|
h.NatType = currentHost.NatType
|
|
h.TurnEndpoint = currentHost.TurnEndpoint
|
|
h.PersistentKeepalive = time.Duration(a.PersistentKeepalive) * time.Second
|
|
h.AutoUpdate = a.AutoUpdate
|
|
h.DNS = a.DNS
|
|
return &h
|
|
}
|