summaryrefslogtreecommitdiff
path: root/utils/database.go
diff options
context:
space:
mode:
authorxengineering <me@xengineering.eu>2022-11-11 19:19:25 +0100
committerxengineering <me@xengineering.eu>2022-11-11 19:19:25 +0100
commitbdefa29fb2395eec79564145186d9ad1ec45dff3 (patch)
tree85d06816b7ba683d8038aaac6d940c3fb23d76bc /utils/database.go
parente5760e3e1832ddb74885acbc93e39c9659c90d0c (diff)
downloadceres-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/database.go')
-rw-r--r--utils/database.go24
1 files changed, 6 insertions, 18 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