feat: initial setting items

This commit is contained in:
Noah Hsu
2022-06-27 15:51:02 +08:00
parent e4c3ef0262
commit 1a148eee7c
11 changed files with 136 additions and 17 deletions

View File

@ -10,7 +10,7 @@ var db gorm.DB
func Init(d *gorm.DB) {
db = *d
err := db.AutoMigrate(new(model.Account), new(model.User), new(model.Meta))
err := db.AutoMigrate(new(model.Account), new(model.User), new(model.Meta), new(model.SettingItem))
if err != nil {
log.Fatalf("failed migrate database: %s", err.Error())
}

View File

@ -6,12 +6,28 @@ import (
"github.com/pkg/errors"
)
func SaveSettings(items []model.SettingItem) error {
return errors.WithStack(db.Save(items).Error)
func GetSettings() ([]model.SettingItem, error) {
var items []model.SettingItem
if err := db.Find(&items).Error; err != nil {
return nil, errors.WithStack(err)
}
return items, nil
}
func SaveSetting(item model.SettingItem) error {
return errors.WithStack(db.Save(item).Error)
func GetSettingByKey(key string) (*model.SettingItem, error) {
var item model.SettingItem
if err := db.Where(fmt.Sprintf("%s = ?", columnName("key")), key).First(&item).Error; err != nil {
return nil, errors.WithStack(err)
}
return &item, nil
}
func GetPublicSettings() ([]model.SettingItem, error) {
var items []model.SettingItem
if err := db.Where(fmt.Sprintf("%s in ?", columnName("flag")), []int{0, 2}).Find(&items).Error; err != nil {
return nil, err
}
return items, nil
}
func GetSettingsByGroup(group int) ([]model.SettingItem, error) {
@ -22,6 +38,14 @@ func GetSettingsByGroup(group int) ([]model.SettingItem, error) {
return items, nil
}
func SaveSettings(items []model.SettingItem) error {
return errors.WithStack(db.Save(items).Error)
}
func SaveSetting(item model.SettingItem) error {
return errors.WithStack(db.Save(item).Error)
}
func DeleteSettingByKey(key string) error {
setting := model.SettingItem{
Key: key,