settings.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362
  1. package logic
  2. import (
  3. "encoding/json"
  4. "os"
  5. "regexp"
  6. "strconv"
  7. "strings"
  8. "sync"
  9. "time"
  10. "github.com/gravitl/netmaker/config"
  11. "github.com/gravitl/netmaker/database"
  12. "github.com/gravitl/netmaker/models"
  13. "github.com/gravitl/netmaker/servercfg"
  14. )
  15. var serverSettingsDBKey = "server_cfg"
  16. var SettingsMutex = &sync.RWMutex{}
  17. func GetServerSettings() (s models.ServerSettings) {
  18. data, err := database.FetchRecord(database.SERVER_SETTINGS, serverSettingsDBKey)
  19. if err != nil {
  20. return
  21. }
  22. json.Unmarshal([]byte(data), &s)
  23. return
  24. }
  25. func UpsertServerSettings(s models.ServerSettings) error {
  26. // get curr settings
  27. currSettings := GetServerSettings()
  28. if s.ClientSecret == Mask() {
  29. s.ClientSecret = currSettings.ClientSecret
  30. }
  31. if servercfg.DeployedByOperator() {
  32. s.BasicAuth = true
  33. }
  34. data, err := json.Marshal(s)
  35. if err != nil {
  36. return err
  37. }
  38. err = database.Insert(serverSettingsDBKey, string(data), database.SERVER_SETTINGS)
  39. if err != nil {
  40. return err
  41. }
  42. return nil
  43. }
  44. func ValidateNewSettings(req models.ServerSettings) bool {
  45. // TODO: add checks for different fields
  46. return true
  47. }
  48. func GetServerSettingsFromEnv() (s models.ServerSettings) {
  49. s = models.ServerSettings{
  50. NetclientAutoUpdate: servercfg.AutoUpdateEnabled(),
  51. Verbosity: servercfg.GetVerbosity(),
  52. AuthProvider: os.Getenv("AUTH_PROVIDER"),
  53. OIDCIssuer: os.Getenv("OIDC_ISSUER"),
  54. ClientID: os.Getenv("CLIENT_ID"),
  55. ClientSecret: os.Getenv("CLIENT_SECRET"),
  56. AzureTenant: servercfg.GetAzureTenant(),
  57. Telemetry: servercfg.Telemetry(),
  58. BasicAuth: servercfg.IsBasicAuthEnabled(),
  59. JwtValidityDuration: servercfg.GetJwtValidityDurationFromEnv() / 60,
  60. RacRestrictToSingleNetwork: servercfg.GetRacRestrictToSingleNetwork(),
  61. EndpointDetection: servercfg.IsEndpointDetectionEnabled(),
  62. AllowedEmailDomains: servercfg.GetAllowedEmailDomains(),
  63. EmailSenderAddr: servercfg.GetSenderEmail(),
  64. EmailSenderUser: servercfg.GetSenderUser(),
  65. EmailSenderPassword: servercfg.GetEmaiSenderPassword(),
  66. SmtpHost: servercfg.GetSmtpHost(),
  67. SmtpPort: servercfg.GetSmtpPort(),
  68. MetricInterval: servercfg.GetMetricInterval(),
  69. MetricsPort: servercfg.GetMetricsPort(),
  70. ManageDNS: servercfg.GetManageDNS(),
  71. DefaultDomain: servercfg.GetDefaultDomain(),
  72. Stun: servercfg.IsStunEnabled(),
  73. StunServers: servercfg.GetStunServers(),
  74. TextSize: "16",
  75. Theme: models.Dark,
  76. ReducedMotion: false,
  77. }
  78. return
  79. }
  80. // GetServerConfig - gets the server config into memory from file or env
  81. func GetServerConfig() config.ServerConfig {
  82. var cfg config.ServerConfig
  83. settings := GetServerSettings()
  84. cfg.APIConnString = servercfg.GetAPIConnString()
  85. cfg.CoreDNSAddr = servercfg.GetCoreDNSAddr()
  86. cfg.APIHost = servercfg.GetAPIHost()
  87. cfg.APIPort = servercfg.GetAPIPort()
  88. cfg.MasterKey = "(hidden)"
  89. cfg.DNSKey = "(hidden)"
  90. cfg.AllowedOrigin = servercfg.GetAllowedOrigin()
  91. cfg.RestBackend = "off"
  92. cfg.NodeID = servercfg.GetNodeID()
  93. cfg.BrokerType = servercfg.GetBrokerType()
  94. cfg.EmqxRestEndpoint = servercfg.GetEmqxRestEndpoint()
  95. if settings.NetclientAutoUpdate {
  96. cfg.NetclientAutoUpdate = "enabled"
  97. } else {
  98. cfg.NetclientAutoUpdate = "disabled"
  99. }
  100. if servercfg.IsRestBackend() {
  101. cfg.RestBackend = "on"
  102. }
  103. cfg.DNSMode = "off"
  104. if servercfg.IsDNSMode() {
  105. cfg.DNSMode = "on"
  106. }
  107. cfg.DisplayKeys = "off"
  108. if servercfg.IsDisplayKeys() {
  109. cfg.DisplayKeys = "on"
  110. }
  111. cfg.DisableRemoteIPCheck = "off"
  112. if servercfg.DisableRemoteIPCheck() {
  113. cfg.DisableRemoteIPCheck = "on"
  114. }
  115. cfg.Database = servercfg.GetDB()
  116. cfg.Platform = servercfg.GetPlatform()
  117. cfg.Version = servercfg.GetVersion()
  118. cfg.PublicIp = servercfg.GetServerHostIP()
  119. // == auth config ==
  120. var authInfo = GetAuthProviderInfo(settings)
  121. cfg.AuthProvider = authInfo[0]
  122. cfg.ClientID = authInfo[1]
  123. cfg.ClientSecret = authInfo[2]
  124. cfg.FrontendURL = servercfg.GetFrontendURL()
  125. cfg.AzureTenant = settings.AzureTenant
  126. cfg.Telemetry = settings.Telemetry
  127. cfg.Server = servercfg.GetServer()
  128. cfg.Verbosity = settings.Verbosity
  129. cfg.IsPro = "no"
  130. if servercfg.IsPro {
  131. cfg.IsPro = "yes"
  132. }
  133. cfg.JwtValidityDuration = time.Duration(settings.JwtValidityDuration) * time.Minute
  134. cfg.RacRestrictToSingleNetwork = settings.RacRestrictToSingleNetwork
  135. cfg.MetricInterval = settings.MetricInterval
  136. cfg.ManageDNS = settings.ManageDNS
  137. cfg.Stun = settings.Stun
  138. cfg.StunServers = settings.StunServers
  139. cfg.DefaultDomain = settings.DefaultDomain
  140. return cfg
  141. }
  142. // GetServerInfo - gets the server config into memory from file or env
  143. func GetServerInfo() models.ServerConfig {
  144. var cfg models.ServerConfig
  145. serverSettings := GetServerSettings()
  146. cfg.Server = servercfg.GetServer()
  147. if servercfg.GetBrokerType() == servercfg.EmqxBrokerType {
  148. cfg.MQUserName = "HOST_ID"
  149. cfg.MQPassword = "HOST_PASS"
  150. } else {
  151. cfg.MQUserName = servercfg.GetMqUserName()
  152. cfg.MQPassword = servercfg.GetMqPassword()
  153. }
  154. cfg.API = servercfg.GetAPIConnString()
  155. cfg.CoreDNSAddr = servercfg.GetCoreDNSAddr()
  156. cfg.APIPort = servercfg.GetAPIPort()
  157. cfg.DNSMode = "off"
  158. cfg.Broker = servercfg.GetPublicBrokerEndpoint()
  159. cfg.BrokerType = servercfg.GetBrokerType()
  160. if servercfg.IsDNSMode() {
  161. cfg.DNSMode = "on"
  162. }
  163. cfg.Version = servercfg.GetVersion()
  164. cfg.IsPro = servercfg.IsPro
  165. cfg.MetricInterval = serverSettings.MetricInterval
  166. cfg.MetricsPort = serverSettings.MetricsPort
  167. cfg.ManageDNS = serverSettings.ManageDNS
  168. cfg.Stun = serverSettings.Stun
  169. cfg.StunServers = serverSettings.StunServers
  170. cfg.DefaultDomain = serverSettings.DefaultDomain
  171. cfg.EndpointDetection = serverSettings.EndpointDetection
  172. return cfg
  173. }
  174. // GetDefaultDomain - get the default domain
  175. func GetDefaultDomain() string {
  176. return GetServerSettings().DefaultDomain
  177. }
  178. func ValidateDomain(domain string) bool {
  179. domainPattern := `[a-zA-Z0-9][a-zA-Z0-9_-]{0,62}(\.[a-zA-Z0-9][a-zA-Z0-9_-]{0,62})*(\.[a-zA-Z][a-zA-Z0-9]{0,10}){1}`
  180. exp := regexp.MustCompile("^" + domainPattern + "$")
  181. return exp.MatchString(domain)
  182. }
  183. // Telemetry - checks if telemetry data should be sent
  184. func Telemetry() string {
  185. return GetServerSettings().Telemetry
  186. }
  187. // GetJwtValidityDuration - returns the JWT validity duration in minutes
  188. func GetJwtValidityDuration() time.Duration {
  189. return GetServerConfig().JwtValidityDuration
  190. }
  191. // GetRacRestrictToSingleNetwork - returns whether the feature to allow simultaneous network connections via RAC is enabled
  192. func GetRacRestrictToSingleNetwork() bool {
  193. return GetServerSettings().RacRestrictToSingleNetwork
  194. }
  195. func GetSmtpHost() string {
  196. return GetServerSettings().SmtpHost
  197. }
  198. func GetSmtpPort() int {
  199. return GetServerSettings().SmtpPort
  200. }
  201. func GetSenderEmail() string {
  202. return GetServerSettings().EmailSenderAddr
  203. }
  204. func GetSenderUser() string {
  205. return GetServerSettings().EmailSenderUser
  206. }
  207. func GetEmaiSenderPassword() string {
  208. return GetServerSettings().EmailSenderPassword
  209. }
  210. // AutoUpdateEnabled returns a boolean indicating whether netclient auto update is enabled or disabled
  211. // default is enabled
  212. func AutoUpdateEnabled() bool {
  213. return GetServerSettings().NetclientAutoUpdate
  214. }
  215. // GetAuthProviderInfo = gets the oauth provider info
  216. func GetAuthProviderInfo(settings models.ServerSettings) (pi []string) {
  217. var authProvider = ""
  218. defer func() {
  219. if authProvider == "okta" || authProvider == "oidc" {
  220. if settings.OIDCIssuer != "" {
  221. pi = append(pi, settings.OIDCIssuer)
  222. } else {
  223. pi = []string{"", "", ""}
  224. }
  225. }
  226. }()
  227. if settings.AuthProvider != "" && settings.ClientID != "" && settings.ClientSecret != "" {
  228. authProvider = strings.ToLower(settings.AuthProvider)
  229. if authProvider == "google" || authProvider == "azure-ad" || authProvider == "github" || authProvider == "oidc" || authProvider == "okta" {
  230. return []string{authProvider, settings.ClientID, settings.ClientSecret}
  231. } else {
  232. authProvider = ""
  233. }
  234. }
  235. return []string{"", "", ""}
  236. }
  237. // GetAzureTenant - retrieve the azure tenant ID from env variable or config file
  238. func GetAzureTenant() string {
  239. return GetServerSettings().AzureTenant
  240. }
  241. // IsSyncEnabled returns whether auth provider sync is enabled.
  242. func IsSyncEnabled() bool {
  243. return GetServerSettings().SyncEnabled
  244. }
  245. // GetIDPSyncInterval returns the interval at which the netmaker should sync
  246. // data from IDP.
  247. func GetIDPSyncInterval() time.Duration {
  248. syncInterval, err := time.ParseDuration(GetServerSettings().IDPSyncInterval)
  249. if err != nil {
  250. return 24 * time.Hour
  251. }
  252. if syncInterval == 0 {
  253. return 24 * time.Hour
  254. }
  255. return syncInterval
  256. }
  257. // GetMetricsPort - get metrics port
  258. func GetMetricsPort() int {
  259. return GetServerSettings().MetricsPort
  260. }
  261. // GetMetricInterval - get the publish metric interval
  262. func GetMetricIntervalInMinutes() time.Duration {
  263. //default 15 minutes
  264. mi := "15"
  265. if os.Getenv("PUBLISH_METRIC_INTERVAL") != "" {
  266. mi = os.Getenv("PUBLISH_METRIC_INTERVAL")
  267. }
  268. interval, err := strconv.Atoi(mi)
  269. if err != nil {
  270. interval = 15
  271. }
  272. return time.Duration(interval) * time.Minute
  273. }
  274. // GetMetricInterval - get the publish metric interval
  275. func GetMetricInterval() string {
  276. return GetServerSettings().MetricInterval
  277. }
  278. // GetManageDNS - if manage DNS enabled or not
  279. func GetManageDNS() bool {
  280. return GetServerSettings().ManageDNS
  281. }
  282. // IsBasicAuthEnabled - checks if basic auth has been configured to be turned off
  283. func IsBasicAuthEnabled() bool {
  284. if servercfg.DeployedByOperator() {
  285. return true
  286. }
  287. return GetServerSettings().BasicAuth
  288. }
  289. // IsMFAEnforced returns whether MFA has been enforced.
  290. func IsMFAEnforced() bool {
  291. return GetServerSettings().MFAEnforced
  292. }
  293. // IsEndpointDetectionEnabled - returns true if endpoint detection enabled
  294. func IsEndpointDetectionEnabled() bool {
  295. return GetServerSettings().EndpointDetection
  296. }
  297. // IsStunEnabled - returns true if STUN set to on
  298. func IsStunEnabled() bool {
  299. return GetServerSettings().Stun
  300. }
  301. func GetStunServers() string {
  302. return GetServerSettings().StunServers
  303. }
  304. // GetAllowedEmailDomains - gets the allowed email domains for oauth signup
  305. func GetAllowedEmailDomains() string {
  306. return GetServerSettings().AllowedEmailDomains
  307. }
  308. func GetVerbosity() int32 {
  309. return GetServerSettings().Verbosity
  310. }
  311. func Mask() string {
  312. return ("..................")
  313. }