diff options
author | xengineering <me@xengineering.eu> | 2022-11-11 19:19:25 +0100 |
---|---|---|
committer | xengineering <me@xengineering.eu> | 2022-11-11 19:19:25 +0100 |
commit | bdefa29fb2395eec79564145186d9ad1ec45dff3 (patch) | |
tree | 85d06816b7ba683d8038aaac6d940c3fb23d76bc /utils | |
parent | e5760e3e1832ddb74885acbc93e39c9659c90d0c (diff) | |
download | ceres-bdefa29fb2395eec79564145186d9ad1ec45dff3.tar ceres-bdefa29fb2395eec79564145186d9ad1ec45dff3.tar.zst ceres-bdefa29fb2395eec79564145186d9ad1ec45dff3.zip |
Restrict configuration to config file
This drops also the -d flag and the database/user config option.
The -d flag used to override specific parts of the config file. This is
just confusing behaviour. Instead a new config/debug.json file is
introduced with useful default values.
Instead of configuring the database user via the database/user entry in
the config file, the user is determined from the Linux user of the
server process. This enforces that a database user with the same name as
the Linux user is configured which is already described in the README.
Diffstat (limited to 'utils')
-rw-r--r-- | utils/database.go | 24 | ||||
-rw-r--r-- | utils/runtime_config.go | 25 |
2 files changed, 9 insertions, 40 deletions
diff --git a/utils/database.go b/utils/database.go index b8a6941..f48af35 100644 --- a/utils/database.go +++ b/utils/database.go @@ -31,7 +31,7 @@ func InitDatabase(config DatabaseConfig) Database { db := NewDatabase(config) db.Connect() db.Ping() - db.Migrate(config.Debug) + db.Migrate(config.Migrations) // allow graceful shutdown var listener = make(chan os.Signal) @@ -53,15 +53,11 @@ func NewDatabase(config DatabaseConfig) Database { db.config = config var username string - if config.Debug { - user_ptr,err := user.Current() - if err != nil { - log.Fatal(err) - } - username = user_ptr.Username - } else { - username = config.User + user_ptr,err := user.Current() + if err != nil { + log.Fatal(err) } + username = user_ptr.Username db.target = fmt.Sprintf("%s@unix(%s)/%s", username, config.Socket, config.Database) return db @@ -85,15 +81,7 @@ func (db *Database) Ping() { } } -func (db *Database) Migrate(debug bool) { - - // get directory with SQL migration scripts - var dir string - if debug { - dir = "./sql" - } else { - dir = "/usr/share/ceres/migrations/" - } +func (db *Database) Migrate(dir string) { const t = databaseSchemaVersion // targeted database schema version diff --git a/utils/runtime_config.go b/utils/runtime_config.go index 42170f6..fb5bd72 100644 --- a/utils/runtime_config.go +++ b/utils/runtime_config.go @@ -12,7 +12,6 @@ import ( type RuntimeConfig struct { Path string - Debug bool Http HttpConfig `json:"http"` Database DatabaseConfig `json:"database"` } @@ -29,7 +28,7 @@ type DatabaseConfig struct { Socket string `json:"socket"` User string `json:"user"` Database string `json:"database"` - Debug bool + Migrations string `json:"migrations"` } func GetRuntimeConfig() RuntimeConfig { @@ -39,7 +38,6 @@ func GetRuntimeConfig() RuntimeConfig { // read command line flags flag.StringVar(&config.Path, "c", "/etc/ceres/config.json", "Path to ceres configuration file") - flag.BoolVar(&config.Debug, "d", false, "Use this flag if you are in a development environment") flag.Parse() // open config file @@ -55,30 +53,13 @@ func GetRuntimeConfig() RuntimeConfig { log.Fatalf("Could not read configuration file %s", config.Path) } + fmt.Print("Used config: " + string(configData) + "\n") + // parse content to config structs err = json.Unmarshal(configData, &config) if err != nil { log.Fatalf("Could not parse configuration file %s", config.Path) } - // override defaults if in debugging mode - if config.Debug { - config.Http.Static = "./data/static" - config.Http.Templates = "./data/templates" - config.Http.Storage = "./data/storage" - } - - // copy debug value - config.Database.Debug = config.Debug - - // print config if in debug mode - if config.Debug { - configuration,err := json.MarshalIndent(config, "", " ") - if err != nil { - log.Fatal(err) - } - fmt.Print("Used config: " + string(configuration) + "\n") - } - return config } |