123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- package models
- import (
- // "../mongoconn"
- "time"
- "go.mongodb.org/mongo-driver/bson/primitive"
- )
- //Network Struct
- //At some point, need to replace all instances of Name with something else like Identifier
- type Network struct {
- ID primitive.ObjectID `json:"_id,omitempty" bson:"_id,omitempty"`
- AddressRange string `json:"addressrange" bson:"addressrange" validate:"required,cidr"`
- // bug in validator --- required_with does not work with bools issue#683
- // AddressRange6 string `json:"addressrange6" bson:"addressrange6" validate:"required_with=isdualstack true,cidrv6"`
- AddressRange6 string `json:"addressrange6" bson:"addressrange6" validate:"addressrange6_valid"`
- //can't have min=1 with omitempty
- DisplayName string `json:"displayname,omitempty" bson:"displayname,omitempty" validate:"omitempty,alphanum,min=2,max=20,displayname_unique"`
- NetID string `json:"netid" bson:"netid" validate:"required,alphanum,min=1,max=12,netid_valid"`
- NodesLastModified int64 `json:"nodeslastmodified" bson:"nodeslastmodified"`
- NetworkLastModified int64 `json:"networklastmodified" bson:"networklastmodified"`
- DefaultInterface string `json:"defaultinterface" bson:"defaultinterface"`
- DefaultListenPort int32 `json:"defaultlistenport,omitempty" bson:"defaultlistenport,omitempty" validate:"omitempty,min=1024,max=65535"`
- DefaultPostUp string `json:"defaultpostup" bson:"defaultpostup"`
- DefaultPostDown string `json:"defaultpostdown" bson:"defaultpostdown"`
- KeyUpdateTimeStamp int64 `json:"keyupdatetimestamp" bson:"keyupdatetimestamp"`
- DefaultKeepalive int32 `json:"defaultkeepalive" bson:"defaultkeepalive" validate:"omitempty,max=1000"`
- DefaultSaveConfig *bool `json:"defaultsaveconfig" bson:"defaultsaveconfig"`
- AccessKeys []AccessKey `json:"accesskeys" bson:"accesskeys"`
- AllowManualSignUp *bool `json:"allowmanualsignup" bson:"allowmanualsignup"`
- IsLocal *bool `json:"islocal" bson:"islocal"`
- IsDualStack *bool `json:"isdualstack" bson:"isdualstack"`
- IsIPv4 string `json:"isipv4" bson:"isipv4"`
- IsIPv6 string `json:"isipv6" bson:"isipv6"`
- IsGRPCHub string `json:"isgrpchub" bson:"isgrpchub"`
- LocalRange string `json:"localrange" bson:"localrange" validate:"omitempty,cidr"`
- //can't have min=1 with omitempty
- DefaultCheckInInterval int32 `json:"checkininterval,omitempty" bson:"checkininterval,omitempty" validate:"omitempty,numeric,min=2,max=100000"`
- }
- type NetworkUpdate struct {
- ID primitive.ObjectID `json:"_id,omitempty" bson:"_id,omitempty"`
- AddressRange string `json:"addressrange" bson:"addressrange" validate:"omitempty,cidr"`
- // bug in validator --- required_with does not work with bools issue#683
- // AddressRange6 string `json:"addressrange6" bson:"addressrange6" validate:"required_with=isdualstack true,cidrv6"`
- AddressRange6 string `json:"addressrange6" bson:"addressrange6" validate:"omitempty,cidr"`
- //can't have min=1 with omitempty
- DisplayName string `json:"displayname,omitempty" bson:"displayname,omitempty" validate:"omitempty,alphanum,min=2,max=20"`
- NetID string `json:"netid" bson:"netid" validate:"omitempty,alphanum,min=1,max=12"`
- NodesLastModified int64 `json:"nodeslastmodified" bson:"nodeslastmodified"`
- NetworkLastModified int64 `json:"networklastmodified" bson:"networklastmodified"`
- DefaultInterface string `json:"defaultinterface" bson:"defaultinterface"`
- DefaultListenPort int32 `json:"defaultlistenport,omitempty" bson:"defaultlistenport,omitempty" validate:"omitempty,min=1024,max=65535"`
- DefaultPostUp string `json:"defaultpostup" bson:"defaultpostup"`
- DefaultPostDown string `json:"defaultpostdown" bson:"defaultpostdown"`
- KeyUpdateTimeStamp int64 `json:"keyupdatetimestamp" bson:"keyupdatetimestamp"`
- DefaultKeepalive int32 `json:"defaultkeepalive" bson:"defaultkeepalive" validate:"omitempty,max=1000"`
- DefaultSaveConfig *bool `json:"defaultsaveconfig" bson:"defaultsaveconfig"`
- AccessKeys []AccessKey `json:"accesskeys" bson:"accesskeys"`
- AllowManualSignUp *bool `json:"allowmanualsignup" bson:"allowmanualsignup"`
- IsLocal *bool `json:"islocal" bson:"islocal"`
- IsDualStack *bool `json:"isdualstack" bson:"isdualstack"`
- IsIPv4 string `json:"isipv4" bson:"isipv4"`
- IsIPv6 string `json:"isipv6" bson:"isipv6"`
- IsGRPCHub string `json:"isgrpchub" bson:"isgrpchub"`
- LocalRange string `json:"localrange" bson:"localrange" validate:"omitempty,cidr"`
- //can't have min=1 with omitempty
- DefaultCheckInInterval int32 `json:"checkininterval,omitempty" bson:"checkininterval,omitempty" validate:"omitempty,numeric,min=2,max=100000"`
- }
- //TODO:
- //Not sure if we need the below two functions. Got rid of one of the calls. May want to revisit
- func (network *Network) SetNodesLastModified() {
- network.NodesLastModified = time.Now().Unix()
- }
- func (network *Network) SetNetworkLastModified() {
- network.NetworkLastModified = time.Now().Unix()
- }
- func (network *Network) SetDefaults() {
- if network.DisplayName == "" {
- network.DisplayName = network.NetID
- }
- if network.DefaultInterface == "" {
- network.DefaultInterface = "nm-" + network.NetID
- }
- if network.DefaultListenPort == 0 {
- network.DefaultListenPort = 51821
- }
- if network.DefaultPostDown == "" {
- }
- if network.DefaultSaveConfig == nil {
- defaultsave := true
- network.DefaultSaveConfig = &defaultsave
- }
- if network.DefaultKeepalive == 0 {
- network.DefaultKeepalive = 20
- }
- if network.DefaultPostUp == "" {
- }
- //Check-In Interval for Nodes, In Seconds
- if network.DefaultCheckInInterval == 0 {
- network.DefaultCheckInInterval = 30
- }
- if network.AllowManualSignUp == nil {
- signup := false
- network.AllowManualSignUp = &signup
- }
- if (network.IsDualStack != nil) && *network.IsDualStack {
- network.IsIPv6 = "yes"
- network.IsIPv4 = "yes"
- } else if network.IsGRPCHub != "yes" {
- network.IsIPv6 = "no"
- network.IsIPv4 = "yes"
- }
- }
|