netmaker/servercfg/serverconf.go

502 lines
12 KiB
Go
Raw Normal View History

package servercfg
import (
"errors"
"io/ioutil"
"net"
2021-10-14 03:15:20 +08:00
"net/http"
"os"
2021-07-03 11:25:36 +08:00
"strconv"
2021-10-21 02:17:31 +08:00
"strings"
2021-10-14 03:15:20 +08:00
"github.com/gravitl/netmaker/config"
)
2021-05-06 04:42:17 +08:00
2021-10-27 04:12:13 +08:00
// SetHost - sets the host ip
2021-05-06 04:42:17 +08:00
func SetHost() error {
remoteip, err := GetPublicIP()
if err != nil {
return err
}
os.Setenv("SERVER_HOST", remoteip)
return nil
}
2021-10-27 04:12:13 +08:00
// GetServerConfig - gets the server config into memory from file or env
2021-06-02 10:32:20 +08:00
func GetServerConfig() config.ServerConfig {
var cfg config.ServerConfig
cfg.APIConnString = GetAPIConnString()
2021-07-16 03:14:48 +08:00
cfg.CoreDNSAddr = GetCoreDNSAddr()
cfg.APIHost = GetAPIHost()
cfg.APIPort = GetAPIPort()
cfg.GRPCConnString = GetGRPCConnString()
cfg.GRPCHost = GetGRPCHost()
cfg.GRPCPort = GetGRPCPort()
cfg.MasterKey = "(hidden)"
cfg.AllowedOrigin = GetAllowedOrigin()
cfg.RestBackend = "off"
cfg.Verbosity = GetVerbose()
cfg.NodeID = GetNodeID()
cfg.CheckinInterval = GetCheckinInterval()
cfg.ServerCheckinInterval = GetServerCheckinInterval()
if IsRestBackend() {
cfg.RestBackend = "on"
}
cfg.AgentBackend = "off"
if IsAgentBackend() {
cfg.AgentBackend = "on"
}
cfg.ClientMode = "off"
if IsClientMode() != "off" {
cfg.ClientMode = IsClientMode()
}
cfg.DNSMode = "off"
if IsDNSMode() {
cfg.DNSMode = "on"
}
cfg.GRPCSSL = "off"
if IsGRPCSSL() {
cfg.GRPCSSL = "on"
}
cfg.DisableRemoteIPCheck = "off"
if DisableRemoteIPCheck() {
cfg.DisableRemoteIPCheck = "on"
}
cfg.DisableDefaultNet = "off"
if DisableDefaultNet() {
cfg.DisableRemoteIPCheck = "on"
}
2021-08-20 05:35:14 +08:00
cfg.Database = GetDB()
2021-08-20 01:41:04 +08:00
cfg.Platform = GetPlatform()
cfg.Version = GetVersion()
2021-10-21 02:17:31 +08:00
// == auth config ==
var authInfo = GetAuthProviderInfo()
cfg.AuthProvider = authInfo[0]
cfg.ClientID = authInfo[1]
cfg.ClientSecret = authInfo[2]
2021-10-22 03:28:58 +08:00
cfg.FrontendURL = GetFrontendURL()
return cfg
2021-05-06 04:42:17 +08:00
}
2021-10-27 04:12:13 +08:00
// GetFrontendURL - gets the frontend url
2021-10-22 03:28:58 +08:00
func GetFrontendURL() string {
var frontend = ""
if os.Getenv("FRONTEND_URL") != "" {
frontend = os.Getenv("FRONTEND_URL")
} else if config.Config.Server.FrontendURL != "" {
frontend = config.Config.Server.FrontendURL
}
return frontend
}
2021-10-27 04:12:13 +08:00
// GetAPIConnString - gets the api connections string
func GetAPIConnString() string {
conn := ""
if os.Getenv("SERVER_API_CONN_STRING") != "" {
conn = os.Getenv("SERVER_API_CONN_STRING")
} else if config.Config.Server.APIConnString != "" {
conn = config.Config.Server.APIConnString
}
return conn
}
2021-10-27 04:12:13 +08:00
// GetVersion - version of netmaker
func GetVersion() string {
2021-10-22 03:28:58 +08:00
version := "0.8.5"
if config.Config.Server.Version != "" {
version = config.Config.Server.Version
}
return version
}
2021-10-27 04:12:13 +08:00
// GetDB - gets the database type
func GetDB() string {
database := "sqlite"
2021-10-09 01:11:31 +08:00
if os.Getenv("DATABASE") != "" {
database = os.Getenv("DATABASE")
2021-10-09 01:11:31 +08:00
} else if config.Config.Server.Database != "" {
database = config.Config.Server.Database
}
return database
}
2021-10-27 04:12:13 +08:00
// GetAPIHost - gets the api host
2021-05-06 04:42:17 +08:00
func GetAPIHost() string {
serverhost := "127.0.0.1"
2021-07-28 21:31:18 +08:00
remoteip, _ := GetPublicIP()
if os.Getenv("SERVER_HTTP_HOST") != "" {
serverhost = os.Getenv("SERVER_HTTP_HOST")
} else if config.Config.Server.APIHost != "" {
2021-05-06 04:42:17 +08:00
serverhost = config.Config.Server.APIHost
} else if os.Getenv("SERVER_HOST") != "" {
serverhost = os.Getenv("SERVER_HOST")
} else {
if remoteip != "" {
serverhost = remoteip
}
}
2021-05-06 04:42:17 +08:00
return serverhost
}
2021-10-27 04:12:13 +08:00
// GetPodIP - get the pod's ip
2021-08-20 01:41:04 +08:00
func GetPodIP() string {
podip := "127.0.0.1"
if os.Getenv("POD_IP") != "" {
podip = os.Getenv("POD_IP")
}
return podip
}
2021-10-27 04:12:13 +08:00
// GetAPIPort - gets the api port
2021-05-06 04:42:17 +08:00
func GetAPIPort() string {
apiport := "8081"
if os.Getenv("API_PORT") != "" {
apiport = os.Getenv("API_PORT")
} else if config.Config.Server.APIPort != "" {
2021-05-06 04:42:17 +08:00
apiport = config.Config.Server.APIPort
}
return apiport
}
2021-05-26 00:48:04 +08:00
2021-10-27 04:12:13 +08:00
// GetCheckinInterval - get check in interval for nodes
func GetCheckinInterval() string {
seconds := "15"
if os.Getenv("CHECKIN_INTERVAL") != "" {
seconds = os.Getenv("CHECKIN_INTERVAL")
} else if config.Config.Server.CheckinInterval != "" {
seconds = config.Config.Server.CheckinInterval
}
return seconds
}
2021-10-27 04:12:13 +08:00
// GetDefaultNodeLimit - get node limit if one is set
2021-07-03 11:25:36 +08:00
func GetDefaultNodeLimit() int32 {
var limit int32
2021-07-03 11:25:36 +08:00
limit = 999999999
envlimit, err := strconv.Atoi(os.Getenv("DEFAULT_NODE_LIMIT"))
if err == nil && envlimit != 0 {
limit = int32(envlimit)
} else if config.Config.Server.DefaultNodeLimit != 0 {
limit = config.Config.Server.DefaultNodeLimit
}
return limit
2021-07-03 11:25:36 +08:00
}
2021-10-27 04:12:13 +08:00
// GetGRPCConnString - get grpc conn string
func GetGRPCConnString() string {
conn := ""
if os.Getenv("SERVER_GRPC_CONN_STRING") != "" {
conn = os.Getenv("SERVER_GRPC_CONN_STRING")
} else if config.Config.Server.GRPCConnString != "" {
conn = config.Config.Server.GRPCConnString
}
return conn
}
2021-07-03 11:25:36 +08:00
2021-10-27 04:12:13 +08:00
// GetCoreDNSAddr - gets the core dns address
2021-07-16 03:14:48 +08:00
func GetCoreDNSAddr() string {
addr, _ := GetPublicIP()
if os.Getenv("COREDNS_ADDR") != "" {
addr = os.Getenv("COREDNS_ADDR")
} else if config.Config.Server.CoreDNSAddr != "" {
addr = config.Config.Server.GRPCConnString
}
return addr
2021-07-16 03:14:48 +08:00
}
2021-10-27 04:12:13 +08:00
// GetGRPCHost - get the grpc host url
2021-05-06 04:42:17 +08:00
func GetGRPCHost() string {
2021-05-26 00:48:04 +08:00
serverhost := "127.0.0.1"
2021-07-28 21:31:18 +08:00
remoteip, _ := GetPublicIP()
2021-08-10 05:34:13 +08:00
if os.Getenv("SERVER_GRPC_HOST") != "" {
serverhost = os.Getenv("SERVER_GRPC_HOST")
} else if config.Config.Server.GRPCHost != "" {
serverhost = config.Config.Server.GRPCHost
} else if os.Getenv("SERVER_HOST") != "" {
serverhost = os.Getenv("SERVER_HOST")
} else {
2021-08-10 05:34:13 +08:00
if remoteip != "" {
serverhost = remoteip
}
2021-05-26 00:48:04 +08:00
}
return serverhost
2021-05-06 04:42:17 +08:00
}
2021-10-27 04:12:13 +08:00
// GetGRPCPort - gets the grpc port
2021-05-06 04:42:17 +08:00
func GetGRPCPort() string {
grpcport := "50051"
2021-06-02 03:33:36 +08:00
if os.Getenv("GRPC_PORT") != "" {
grpcport = os.Getenv("GRPC_PORT")
} else if config.Config.Server.GRPCPort != "" {
grpcport = config.Config.Server.GRPCPort
2021-05-30 03:06:35 +08:00
}
return grpcport
2021-05-06 04:42:17 +08:00
}
2021-10-27 04:12:13 +08:00
// GetMasterKey - gets the configured master key of server
2021-05-06 04:42:17 +08:00
func GetMasterKey() string {
key := "secretkey"
if os.Getenv("MASTER_KEY") != "" {
key = os.Getenv("MASTER_KEY")
} else if config.Config.Server.MasterKey != "" {
key = config.Config.Server.MasterKey
}
return key
2021-05-06 04:42:17 +08:00
}
2021-10-27 04:12:13 +08:00
// GetAllowedOrigin - get the allowed origin
2021-05-06 04:42:17 +08:00
func GetAllowedOrigin() string {
allowedorigin := "*"
if os.Getenv("CORS_ALLOWED_ORIGIN") != "" {
allowedorigin = os.Getenv("CORS_ALLOWED_ORIGIN")
} else if config.Config.Server.AllowedOrigin != "" {
allowedorigin = config.Config.Server.AllowedOrigin
}
return allowedorigin
2021-05-06 04:42:17 +08:00
}
2021-10-27 04:12:13 +08:00
// IsRestBackend - checks if rest is on or off
2021-05-06 04:42:17 +08:00
func IsRestBackend() bool {
isrest := true
if os.Getenv("REST_BACKEND") != "" {
if os.Getenv("REST_BACKEND") == "off" {
2021-05-06 04:42:17 +08:00
isrest = false
}
} else if config.Config.Server.RestBackend != "" {
if config.Config.Server.RestBackend == "off" {
isrest = false
}
}
return isrest
2021-05-06 04:42:17 +08:00
}
2021-10-27 04:12:13 +08:00
// IsAgentBackend - checks if agent backed is on or off
2021-05-06 04:42:17 +08:00
func IsAgentBackend() bool {
isagent := true
if os.Getenv("AGENT_BACKEND") != "" {
if os.Getenv("AGENT_BACKEND") == "off" {
isagent = false
}
} else if config.Config.Server.AgentBackend != "" {
if config.Config.Server.AgentBackend == "off" {
isagent = false
}
}
return isagent
2021-05-06 04:42:17 +08:00
}
2021-10-27 04:12:13 +08:00
// IsClientMode - checks if it should run in client mode
func IsClientMode() string {
isclient := "on"
if os.Getenv("CLIENT_MODE") != "" {
if os.Getenv("CLIENT_MODE") == "off" {
isclient = "off"
}
if os.Getenv("CLIENT_MODE") == "contained" {
isclient = "contained"
}
} else if config.Config.Server.ClientMode != "" {
if config.Config.Server.ClientMode == "off" {
isclient = "off"
}
if config.Config.Server.ClientMode == "contained" {
isclient = "contained"
}
}
return isclient
2021-05-06 04:42:17 +08:00
}
2021-10-27 04:12:13 +08:00
// IsDNSMode - should it run with DNS
2021-05-06 04:42:17 +08:00
func IsDNSMode() bool {
isdns := true
if os.Getenv("DNS_MODE") != "" {
if os.Getenv("DNS_MODE") == "off" {
isdns = false
}
} else if config.Config.Server.DNSMode != "" {
if config.Config.Server.DNSMode == "off" {
isdns = false
}
}
return isdns
2021-05-06 04:42:17 +08:00
}
2021-10-27 04:12:13 +08:00
// IsGRPCSSL - ssl grpc on or off
func IsGRPCSSL() bool {
isssl := false
if os.Getenv("GRPC_SSL") != "" {
if os.Getenv("GRPC_SSL") == "on" {
isssl = true
}
} else if config.Config.Server.DNSMode != "" {
if config.Config.Server.DNSMode == "on" {
isssl = true
}
}
return isssl
}
2021-10-27 04:12:13 +08:00
// DisableRemoteIPCheck - disable the remote ip check
2021-05-06 04:42:17 +08:00
func DisableRemoteIPCheck() bool {
disabled := false
if os.Getenv("DISABLE_REMOTE_IP_CHECK") != "" {
if os.Getenv("DISABLE_REMOTE_IP_CHECK") == "on" {
disabled = true
}
} else if config.Config.Server.DisableRemoteIPCheck != "" {
if config.Config.Server.DisableRemoteIPCheck == "on" {
disabled = true
}
}
return disabled
2021-05-06 04:42:17 +08:00
}
2021-10-27 04:12:13 +08:00
// DisableDefaultNet - disable default net
func DisableDefaultNet() bool {
disabled := false
if os.Getenv("DISABLE_DEFAULT_NET") != "" {
if os.Getenv("DISABLE_DEFAULT_NET") == "on" {
disabled = true
}
} else if config.Config.Server.DisableDefaultNet != "" {
if config.Config.Server.DisableDefaultNet == "on" {
disabled = true
}
}
return disabled
}
2021-10-27 04:12:13 +08:00
// GetPublicIP - gets public ip
2021-05-06 04:42:17 +08:00
func GetPublicIP() (string, error) {
endpoint := ""
var err error
2021-05-06 04:42:17 +08:00
iplist := []string{"http://ip.server.gravitl.com", "https://ifconfig.me", "http://api.ipify.org", "http://ipinfo.io/ip"}
for _, ipserver := range iplist {
resp, err := http.Get(ipserver)
if err != nil {
continue
}
defer resp.Body.Close()
if resp.StatusCode == http.StatusOK {
bodyBytes, err := ioutil.ReadAll(resp.Body)
if err != nil {
continue
}
endpoint = string(bodyBytes)
break
}
}
if err == nil && endpoint == "" {
err = errors.New("Public Address Not Found.")
}
return endpoint, err
}
2021-10-27 04:12:13 +08:00
// GetVerbose - get the verbosity of server
func GetVerbose() int32 {
level, err := strconv.Atoi(os.Getenv("VERBOSITY"))
if err != nil || level < 0 {
level = 0
}
if level > 3 {
level = 3
}
return int32(level)
2021-05-06 04:42:17 +08:00
}
2021-08-19 02:55:41 +08:00
2021-10-27 04:12:13 +08:00
// GetPlatform - get the system type of server
2021-08-20 01:41:04 +08:00
func GetPlatform() string {
platform := "linux"
if os.Getenv("PLATFORM") != "" {
platform = os.Getenv("PLATFORM")
2021-08-26 01:09:23 +08:00
} else if config.Config.Server.Platform != "" {
2021-08-20 01:41:04 +08:00
platform = config.Config.Server.SQLConn
}
return platform
}
2021-10-27 04:12:13 +08:00
// GetSQLConn - get the sql connection string
2021-08-19 02:55:41 +08:00
func GetSQLConn() string {
sqlconn := "http://"
if os.Getenv("SQL_CONN") != "" {
sqlconn = os.Getenv("SQL_CONN")
} else if config.Config.Server.SQLConn != "" {
2021-08-19 02:55:41 +08:00
sqlconn = config.Config.Server.SQLConn
}
return sqlconn
}
2021-09-29 01:16:41 +08:00
2021-10-27 04:12:13 +08:00
// IsSplitDNS - checks if split dns is on
2021-09-29 01:16:41 +08:00
func IsSplitDNS() bool {
issplit := false
if os.Getenv("IS_SPLIT_DNS") == "yes" {
issplit = true
} else if config.Config.Server.SplitDNS == "yes" {
issplit = true
}
return issplit
}
2021-10-27 04:12:13 +08:00
// GetNodeID - gets the node id
func GetNodeID() string {
var id string
id = getMacAddr()
if os.Getenv("NODE_ID") != "" {
id = os.Getenv("NODE_ID")
} else if config.Config.Server.NodeID != "" {
id = config.Config.Server.NodeID
}
return id
}
2021-10-27 04:12:13 +08:00
// GetServerCheckinInterval - gets the server check-in time
func GetServerCheckinInterval() int64 {
var t = int64(5)
var envt, _ = strconv.Atoi(os.Getenv("SERVER_CHECKIN_INTERVAL"))
if envt > 0 {
t = int64(envt)
} else if config.Config.Server.ServerCheckinInterval > 0 {
t = config.Config.Server.ServerCheckinInterval
}
return t
}
2021-10-21 02:17:31 +08:00
// GetAuthProviderInfo = gets the oauth provider info
func GetAuthProviderInfo() []string {
var authProvider = ""
if os.Getenv("AUTH_PROVIDER") != "" && os.Getenv("CLIENT_ID") != "" && os.Getenv("CLIENT_SECRET") != "" {
authProvider = strings.ToLower(os.Getenv("AUTH_PROVIDER"))
if authProvider == "google" || authProvider == "azure-ad" || authProvider == "github" {
return []string{authProvider, os.Getenv("CLIENT_ID"), os.Getenv("CLIENT_SECRET")}
} else {
authProvider = ""
}
} else if config.Config.Server.AuthProvider != "" && config.Config.Server.ClientID != "" && config.Config.Server.ClientSecret != "" {
authProvider = strings.ToLower(config.Config.Server.AuthProvider)
if authProvider == "google" || authProvider == "azure-ad" || authProvider == "github" {
return []string{authProvider, config.Config.Server.ClientID, config.Config.Server.ClientSecret}
}
}
return []string{"", "", ""}
}
// GetMacAddr - get's mac address
func getMacAddr() string {
ifas, err := net.Interfaces()
if err != nil {
return ""
}
var as []string
for _, ifa := range ifas {
a := ifa.HardwareAddr.String()
if a != "" {
as = append(as, a)
}
}
return as[0]
2021-10-14 03:15:20 +08:00
}