GoScrobble/internal/goscrobble/config.go
2022-06-27 16:10:01 +12:00

95 lines
1.9 KiB
Go

package goscrobble
import (
"database/sql"
"errors"
"fmt"
"log"
)
type Config struct {
Setting map[string]string `json:"configs"`
}
type ServerInfo struct {
Version string `json:"version"`
RegistrationEnabled string `json:"registration_enabled"`
}
func getAllConfigs() (Config, error) {
config := Config{}
configs := make(map[string]string)
rows, err := db.Query(`SELECT key, value FROM config`)
if err != nil {
log.Printf("Failed to fetch config: %+v", err)
return config, errors.New("Failed to fetch configs")
}
defer rows.Close()
for rows.Next() {
var key string
var value string
err := rows.Scan(&key, &value)
if err != nil {
log.Printf("Failed to fetch config: %+v", err)
return config, errors.New("Failed to fetch configs")
}
// Append
configs[key] = value
}
// Assign the data to the parent
config.Setting = configs
err = rows.Err()
if err != nil {
log.Printf("Failed to fetch config: %+v", err)
return config, errors.New("Failed to fetch configs")
}
return config, nil
}
func updateConfigValue(key string, value string) error {
_, err := db.Exec(`UPDATE config SET value = $1 WHERE key = $2`, value, key)
if err != nil {
fmt.Printf("Failed to update config: %+v", err)
return errors.New("Failed to update config value.")
}
// Set cached config
redisKey := "config:" + key
setRedisVal(redisKey, value)
return nil
}
func getConfigValue(key string) (string, error) {
var value string
// Check if cached first
redisKey := "config:" + key
// TODO: Handle unset vals in DB to prevent excess calls if not using spotify/etc.
configKey := getRedisVal(redisKey)
if configKey == "" {
err := db.QueryRow("SELECT value FROM config "+
"WHERE key = ?",
key).Scan(&value)
if err == sql.ErrNoRows {
return value, errors.New("Config key doesn't exist")
}
if value != "" {
setRedisVal(redisKey, value)
}
return value, nil
}
return configKey, nil
}