settings.go 12 KB

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