Files
libredesk/internal/setting/setting.go
Abhinav Raut 6b6549cb03 standardize i18n keys for consistency rename keys
fix: avatar url `null` console warnings.
2025-04-03 01:21:12 +05:30

153 lines
3.7 KiB
Go

// Package setting handles the management of application settings.
package setting
import (
"embed"
"encoding/json"
"strings"
"github.com/abhinavxd/libredesk/internal/dbutil"
"github.com/abhinavxd/libredesk/internal/envelope"
"github.com/abhinavxd/libredesk/internal/setting/models"
"github.com/jmoiron/sqlx"
"github.com/jmoiron/sqlx/types"
"github.com/knadh/go-i18n"
"github.com/zerodha/logf"
)
var (
//go:embed queries.sql
efs embed.FS
)
// Manager handles setting-related operations.
type Manager struct {
q queries
lo *logf.Logger
i18n *i18n.I18n
}
// Opts contains options for initializing the Manager.
type Opts struct {
DB *sqlx.DB
Lo *logf.Logger
I18n *i18n.I18n
}
// queries contains prepared SQL queries.
type queries struct {
Get *sqlx.Stmt `query:"get"`
GetAll *sqlx.Stmt `query:"get-all"`
Update *sqlx.Stmt `query:"update"`
GetByPrefix *sqlx.Stmt `query:"get-by-prefix"`
}
// New creates and returns a new instance of the Manager.
func New(opts Opts) (*Manager, error) {
var q queries
if err := dbutil.ScanSQLFile("queries.sql", &q, opts.DB, efs); err != nil {
return nil, err
}
return &Manager{
q: q,
lo: opts.Lo,
i18n: opts.I18n,
}, nil
}
// GetAll retrieves all settings as a models.Settings struct.
func (m *Manager) GetAll() (models.Settings, error) {
var (
b types.JSONText
out models.Settings
)
if err := m.q.GetAll.Get(&b); err != nil {
return out, err
}
if err := json.Unmarshal([]byte(b), &out); err != nil {
return out, err
}
return out, nil
}
// GetAllJSON retrieves all settings as JSON.
func (m *Manager) GetAllJSON() (types.JSONText, error) {
var b types.JSONText
if err := m.q.GetAll.Get(&b); err != nil {
m.lo.Error("error fetching settings", "error", err)
return b, err
}
return b, nil
}
// Update updates settings.
func (m *Manager) Update(s interface{}) error {
// Marshal settings.
b, err := json.Marshal(s)
if err != nil {
m.lo.Error("error marshalling settings", "error", err)
return envelope.NewError(
envelope.GeneralError,
m.i18n.Ts("globals.messages.errorUpdating", "name", "{globals.terms.setting}"),
nil,
)
}
// Update the settings in the DB.
if _, err := m.q.Update.Exec(b); err != nil {
m.lo.Error("error updating settings", "error", err)
return envelope.NewError(
envelope.GeneralError,
m.i18n.Ts("globals.messages.errorUpdating", "name", "{globals.terms.setting}"),
nil,
)
}
return nil
}
// GetByPrefix retrieves settings by prefix as JSON.
func (m *Manager) GetByPrefix(prefix string) (types.JSONText, error) {
var b types.JSONText
if err := m.q.GetByPrefix.Get(&b, prefix+"%"); err != nil {
m.lo.Error("error fetching settings", "prefix", prefix, "error", err)
return b, envelope.NewError(
envelope.GeneralError,
m.i18n.Ts("globals.messages.errorFetching", "name", "{globals.terms.setting}"),
nil,
)
}
return b, nil
}
// Get retrieves a setting by key as JSON.
func (m *Manager) Get(key string) (types.JSONText, error) {
var b types.JSONText
if err := m.q.Get.Get(&b, key); err != nil {
m.lo.Error("error fetching setting", "key", key, "error", err)
return b, envelope.NewError(
envelope.GeneralError,
m.i18n.Ts("globals.messages.errorFetching", "name", "{globals.terms.setting}"),
nil,
)
}
return b, nil
}
// GetAppRootURL returns the root URL of the app.
func (m *Manager) GetAppRootURL() (string, error) {
rootURL, err := m.Get("app.root_url")
if err != nil {
m.lo.Error("error fetching root URL", "error", err)
return "", envelope.NewError(
envelope.GeneralError,
m.i18n.Ts("globals.messages.errorFetching", "name", "{globals.terms.appRootURL}"),
nil,
)
}
return strings.Trim(string(rootURL), "\""), nil
}