feat: use env to override settings

This commit is contained in:
Jacky 2024-05-06 21:24:53 +08:00
parent a82ad2aea4
commit cb0fb47e1c
No known key found for this signature in database
GPG key ID: 215C21B10DF38B4D
6 changed files with 159 additions and 28 deletions

View file

@ -4,6 +4,8 @@ ARG TARGETARCH
ARG TARGETVARIANT ARG TARGETVARIANT
EXPOSE 80 443 EXPOSE 80 443
ENV NGINX_UI_OFFICIAL_DOCKER=true
# register nginx-ui service # register nginx-ui service
COPY resources/docker/nginx-ui.run /etc/s6-overlay/s6-rc.d/nginx-ui/run COPY resources/docker/nginx-ui.run /etc/s6-overlay/s6-rc.d/nginx-ui/run
RUN echo 'longrun' > /etc/s6-overlay/s6-rc.d/nginx-ui/type && \ RUN echo 'longrun' > /etc/s6-overlay/s6-rc.d/nginx-ui/type && \

View file

@ -1,43 +1,43 @@
[server] [server]
HttpPort = 9000 HttpPort = 9000
RunMode = debug RunMode = debug
JwtSecret = JwtSecret =
Email = Email =
HTTPChallengePort = 9180 HTTPChallengePort = 9180
StartCmd = bash StartCmd = bash
Database = database Database = database
CADir = CADir =
GithubProxy = GithubProxy =
NodeSecret = NodeSecret =
Demo = false Demo = false
PageSize = 10 PageSize = 10
HttpHost = 0.0.0.0 HttpHost = 0.0.0.0
CertRenewalInterval = 7 CertRenewalInterval = 7
RecursiveNameservers = RecursiveNameservers =
[nginx] [nginx]
AccessLogPath = /var/log/nginx/access.log AccessLogPath = /var/log/nginx/access.log
ErrorLogPath = /var/log/nginx/error.log ErrorLogPath = /var/log/nginx/error.log
ConfigDir = ConfigDir =
PIDPath = PIDPath =
TestConfigCmd = TestConfigCmd =
ReloadCmd = ReloadCmd =
RestartCmd = RestartCmd =
[openai] [openai]
Model = Model =
BaseUrl = BaseUrl =
Proxy = Proxy =
Token = Token =
[casdoor] [casdoor]
Endpoint = Endpoint =
ClientId = ClientId =
ClientSecret = ClientSecret =
Certificate = Certificate =
Organization = Organization =
Application = Application =
RedirectUri = RedirectUri =
[logrotate] [logrotate]
Enabled = false Enabled = false

1
go.mod
View file

@ -92,6 +92,7 @@ require (
github.com/boombuler/barcode v1.0.1 // indirect github.com/boombuler/barcode v1.0.1 // indirect
github.com/bytedance/sonic v1.11.6 // indirect github.com/bytedance/sonic v1.11.6 // indirect
github.com/bytedance/sonic/loader v0.1.1 // indirect github.com/bytedance/sonic/loader v0.1.1 // indirect
github.com/caarlos0/env/v11 v11.0.0 // indirect
github.com/cenkalti/backoff/v4 v4.3.0 // indirect github.com/cenkalti/backoff/v4 v4.3.0 // indirect
github.com/chenzhuoyu/base64x v0.0.0-20230717121745-296ad89f973d // indirect github.com/chenzhuoyu/base64x v0.0.0-20230717121745-296ad89f973d // indirect
github.com/chenzhuoyu/iasm v0.9.1 // indirect github.com/chenzhuoyu/iasm v0.9.1 // indirect

2
go.sum
View file

@ -811,6 +811,8 @@ github.com/bytedance/sonic/loader v0.1.1/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4
github.com/c-bata/go-prompt v0.2.5/go.mod h1:vFnjEGDIIA/Lib7giyE4E9c50Lvl8j0S+7FVlAwDAVw= github.com/c-bata/go-prompt v0.2.5/go.mod h1:vFnjEGDIIA/Lib7giyE4E9c50Lvl8j0S+7FVlAwDAVw=
github.com/c-bata/go-prompt v0.2.6/go.mod h1:/LMAke8wD2FsNu9EXNdHxNLbd9MedkPnCdfpU9wwHfY= github.com/c-bata/go-prompt v0.2.6/go.mod h1:/LMAke8wD2FsNu9EXNdHxNLbd9MedkPnCdfpU9wwHfY=
github.com/c2h5oh/datasize v0.0.0-20200112174442-28bbd4740fee/go.mod h1:S/7n9copUssQ56c7aAgHqftWO4LTf4xY6CGWt8Bc+3M= github.com/c2h5oh/datasize v0.0.0-20200112174442-28bbd4740fee/go.mod h1:S/7n9copUssQ56c7aAgHqftWO4LTf4xY6CGWt8Bc+3M=
github.com/caarlos0/env/v11 v11.0.0 h1:ZIlkOjuL3xoZS0kmUJlF74j2Qj8GMOq3CDLX/Viak8Q=
github.com/caarlos0/env/v11 v11.0.0/go.mod h1:2RC3HQu8BQqtEK3V4iHPxj0jOdWdbPpWJ6pOueeU1xM=
github.com/casdoor/casdoor-go-sdk v0.35.1 h1:vOGBjHQPw7U5BbnkJgX6/ZUf+PEix1wv4greuNzDCUY= github.com/casdoor/casdoor-go-sdk v0.35.1 h1:vOGBjHQPw7U5BbnkJgX6/ZUf+PEix1wv4greuNzDCUY=
github.com/casdoor/casdoor-go-sdk v0.35.1/go.mod h1:hVSgmSdwTCsBEJNt9r2K5aLVsoeMc37/N4Zzescy5SA= github.com/casdoor/casdoor-go-sdk v0.35.1/go.mod h1:hVSgmSdwTCsBEJNt9r2K5aLVsoeMc37/N4Zzescy5SA=
github.com/casdoor/casdoor-go-sdk v0.43.0 h1:iKDEJlHYwFNY70iWhdVrTTIKqdoqthv3Rxv4x1+rWko= github.com/casdoor/casdoor-go-sdk v0.43.0 h1:iKDEJlHYwFNY70iWhdVrTTIKqdoqthv3Rxv4x1+rWko=

View file

@ -1,21 +1,23 @@
package settings package settings
import ( import (
"github.com/caarlos0/env/v11"
"github.com/spf13/cast" "github.com/spf13/cast"
"gopkg.in/ini.v1" "gopkg.in/ini.v1"
"log" "log"
"os"
"strings" "strings"
"time" "time"
) )
var Conf *ini.File
var ( var (
buildTime string buildTime string
LastModified string LastModified string
)
var ConfPath string Conf *ini.File
ConfPath string
EnvPrefix = "NGINX_UI_"
)
var sections = map[string]interface{}{ var sections = map[string]interface{}{
"server": &ServerSettings, "server": &ServerSettings,
@ -39,9 +41,26 @@ func Setup() {
var err error var err error
Conf, err = ini.LooseLoad(ConfPath) Conf, err = ini.LooseLoad(ConfPath)
if err != nil { if err != nil {
log.Fatalf("setting.Setup: %v\n", err) log.Fatalf("settings.Setup: %v\n", err)
} }
MapTo() MapTo()
parseEnv(&ServerSettings, "SERVER_")
parseEnv(&NginxSettings, "NGINX_")
parseEnv(&OpenAISettings, "OPENAI_")
parseEnv(&CasdoorSettings, "CASDOOR_")
parseEnv(&LogrotateSettings, "LOGROTATE_")
// if in official docker, set the restart cmd of nginx to "nginx -s stop",
// then the supervisor of s6-overlay will start the nginx again.
if cast.ToBool(os.Getenv("NGINX_UI_OFFICIAL_DOCKER")) {
NginxSettings.RestartCmd = "nginx -s stop"
}
err = Save()
if err != nil {
log.Fatalf("settings.Setup: %v\n", err)
}
} }
func MapTo() { func MapTo() {
@ -75,6 +94,16 @@ func Save() (err error) {
if err != nil { if err != nil {
return return
} }
Setup()
return return
} }
func parseEnv(ptr interface{}, prefix string) {
err := env.ParseWithOptions(ptr, env.Options{
Prefix: EnvPrefix + prefix,
UseFieldNameByDefault: true,
})
if err != nil {
log.Fatalf("settings.parseEnv: %v\n", err)
}
}

97
settings/settings_test.go Normal file
View file

@ -0,0 +1,97 @@
package settings
import (
"github.com/stretchr/testify/assert"
"os"
"testing"
)
func TestSetup(t *testing.T) {
Init("../app.example.ini")
_ = os.Setenv("NGINX_UI_OFFICIAL_DOCKER", "true")
_ = os.Setenv("NGINX_UI_SERVER_HTTP_PORT", "8080")
_ = os.Setenv("NGINX_UI_SERVER_RUN_MODE", "test")
_ = os.Setenv("NGINX_UI_SERVER_JWT_SECRET", "newSecret123")
_ = os.Setenv("NGINX_UI_SERVER_HTTP_CHALLENGE_PORT", "9181")
_ = os.Setenv("NGINX_UI_SERVER_START_CMD", "start")
_ = os.Setenv("NGINX_UI_SERVER_DATABASE", "testDB")
_ = os.Setenv("NGINX_UI_SERVER_CA_DIR", "/test/ca")
_ = os.Setenv("NGINX_UI_SERVER_GITHUB_PROXY", "http://proxy.example.com")
_ = os.Setenv("NGINX_UI_SERVER_NODE_SECRET", "nodeSecret")
_ = os.Setenv("NGINX_UI_SERVER_DEMO", "true")
_ = os.Setenv("NGINX_UI_SERVER_PAGE_SIZE", "20")
_ = os.Setenv("NGINX_UI_SERVER_HTTP_HOST", "127.0.0.1")
_ = os.Setenv("NGINX_UI_SERVER_CERT_RENEWAL_INTERVAL", "14")
_ = os.Setenv("NGINX_UI_SERVER_RECURSIVE_NAMESERVERS", "8.8.8.8")
_ = os.Setenv("NGINX_UI_NGINX_ACCESS_LOG_PATH", "/tmp/nginx/access.log")
_ = os.Setenv("NGINX_UI_NGINX_ERROR_LOG_PATH", "/tmp/nginx/error.log")
_ = os.Setenv("NGINX_UI_NGINX_CONFIG_DIR", "/etc/nginx/conf")
_ = os.Setenv("NGINX_UI_NGINX_PID_PATH", "/var/run/nginx.pid")
_ = os.Setenv("NGINX_UI_NGINX_TEST_CONFIG_CMD", "nginx -t")
_ = os.Setenv("NGINX_UI_NGINX_RELOAD_CMD", "nginx -s reload")
_ = os.Setenv("NGINX_UI_NGINX_RESTART_CMD", "nginx -s restart")
_ = os.Setenv("NGINX_UI_OPENAI_MODEL", "davinci")
_ = os.Setenv("NGINX_UI_OPENAI_BASE_URL", "https://api.openai.com")
_ = os.Setenv("NGINX_UI_OPENAI_PROXY", "https://proxy.openai.com")
_ = os.Setenv("NGINX_UI_OPENAI_TOKEN", "token123")
_ = os.Setenv("NGINX_UI_CASDOOR_ENDPOINT", "https://casdoor.example.com")
_ = os.Setenv("NGINX_UI_CASDOOR_CLIENT_ID", "clientId")
_ = os.Setenv("NGINX_UI_CASDOOR_CLIENT_SECRET", "clientSecret")
_ = os.Setenv("NGINX_UI_CASDOOR_CERTIFICATE", "cert.pem")
_ = os.Setenv("NGINX_UI_CASDOOR_ORGANIZATION", "org1")
_ = os.Setenv("NGINX_UI_CASDOOR_APPLICATION", "app1")
_ = os.Setenv("NGINX_UI_CASDOOR_REDIRECT_URI", "https://redirect.example.com")
_ = os.Setenv("NGINX_UI_LOGROTATE_ENABLED", "true")
_ = os.Setenv("NGINX_UI_LOGROTATE_CMD", "logrotate /custom/logrotate.conf")
_ = os.Setenv("NGINX_UI_LOGROTATE_INTERVAL", "60")
Setup()
assert.Equal(t, "8080", ServerSettings.HttpPort)
assert.Equal(t, "test", ServerSettings.RunMode)
assert.Equal(t, "newSecret123", ServerSettings.JwtSecret)
assert.Equal(t, "9181", ServerSettings.HTTPChallengePort)
assert.Equal(t, "start", ServerSettings.StartCmd)
assert.Equal(t, "testDB", ServerSettings.Database)
assert.Equal(t, "/test/ca", ServerSettings.CADir)
assert.Equal(t, "http://proxy.example.com", ServerSettings.GithubProxy)
assert.Equal(t, "nodeSecret", ServerSettings.NodeSecret)
assert.Equal(t, true, ServerSettings.Demo)
assert.Equal(t, 20, ServerSettings.PageSize)
assert.Equal(t, "127.0.0.1", ServerSettings.HttpHost)
assert.Equal(t, 14, ServerSettings.CertRenewalInterval)
assert.Equal(t, []string{"8.8.8.8"}, ServerSettings.RecursiveNameservers)
assert.Equal(t, "/tmp/nginx/access.log", NginxSettings.AccessLogPath)
assert.Equal(t, "/tmp/nginx/error.log", NginxSettings.ErrorLogPath)
assert.Equal(t, "/etc/nginx/conf", NginxSettings.ConfigDir)
assert.Equal(t, "/var/run/nginx.pid", NginxSettings.PIDPath)
assert.Equal(t, "nginx -t", NginxSettings.TestConfigCmd)
assert.Equal(t, "nginx -s reload", NginxSettings.ReloadCmd)
assert.Equal(t, "nginx -s stop", NginxSettings.RestartCmd)
assert.Equal(t, "davinci", OpenAISettings.Model)
assert.Equal(t, "https://api.openai.com", OpenAISettings.BaseUrl)
assert.Equal(t, "https://proxy.openai.com", OpenAISettings.Proxy)
assert.Equal(t, "token123", OpenAISettings.Token)
assert.Equal(t, "https://casdoor.example.com", CasdoorSettings.Endpoint)
assert.Equal(t, "clientId", CasdoorSettings.ClientId)
assert.Equal(t, "clientSecret", CasdoorSettings.ClientSecret)
assert.Equal(t, "cert.pem", CasdoorSettings.Certificate)
assert.Equal(t, "org1", CasdoorSettings.Organization)
assert.Equal(t, "app1", CasdoorSettings.Application)
assert.Equal(t, "https://redirect.example.com", CasdoorSettings.RedirectUri)
assert.Equal(t, true, LogrotateSettings.Enabled)
assert.Equal(t, "logrotate /custom/logrotate.conf", LogrotateSettings.CMD)
assert.Equal(t, 60, LogrotateSettings.Interval)
os.Clearenv()
}