165 lines
4.9 KiB
Go
165 lines
4.9 KiB
Go
package database
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"github.com/fastenhealth/fasten-onprem/backend/pkg/models"
|
|
"github.com/google/uuid"
|
|
)
|
|
|
|
// LoadSystemSettings will retrieve settings from the database, and return a SystemSettings struct
|
|
func (gr *GormRepository) LoadSystemSettings(ctx context.Context) (*models.SystemSettings, error) {
|
|
|
|
settingsEntries := []models.SystemSettingEntry{}
|
|
if err := gr.GormClient.
|
|
WithContext(ctx).
|
|
Find(&settingsEntries).Error; err != nil {
|
|
return nil, fmt.Errorf("Could not get settings from DB: %v", err)
|
|
}
|
|
|
|
settings := models.SystemSettings{}
|
|
for _, settingsEntry := range settingsEntries {
|
|
err := settings.FromSystemSettingsEntry(&settingsEntry)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("Could not get settings from DB: %v", err)
|
|
}
|
|
}
|
|
|
|
return &settings, nil
|
|
}
|
|
|
|
// testing
|
|
// SaveSystemSettings will update save the settings to the database.
|
|
func (gr *GormRepository) SaveSystemSettings(ctx context.Context, newSettings *models.SystemSettings) error {
|
|
|
|
//retrieve current settings from the database
|
|
currentSettingsEntries := []models.SystemSettingEntry{}
|
|
|
|
if err := gr.GormClient.
|
|
WithContext(ctx).
|
|
Find(¤tSettingsEntries).Error; err != nil {
|
|
return fmt.Errorf("Could not get settings from DB: %v", err)
|
|
}
|
|
|
|
//update settingsEntries
|
|
|
|
newSettingsEntries, err := newSettings.ToSystemSettingsEntry(currentSettingsEntries)
|
|
if err != nil {
|
|
return fmt.Errorf("merge new settings with DB: %v", err)
|
|
}
|
|
|
|
for ndx, settingsEntry := range newSettingsEntries {
|
|
|
|
var upsertErr error
|
|
if settingsEntry.ID == uuid.Nil {
|
|
//create new entry
|
|
upsertErr = gr.GormClient.
|
|
WithContext(ctx).
|
|
Model(&models.SystemSettingEntry{}).
|
|
Create(&settingsEntry).Error
|
|
} else {
|
|
// store in database.
|
|
upsertErr = gr.GormClient.
|
|
WithContext(ctx).
|
|
Model(&models.SystemSettingEntry{}).
|
|
Where([]uuid.UUID{settingsEntry.ID}).
|
|
Select("setting_value_numeric", "setting_value_string", "setting_value_bool", "setting_value_array").
|
|
Updates(newSettingsEntries[ndx]).Error
|
|
}
|
|
|
|
if upsertErr != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// LoadSettings will retrieve settings from the database, store them in the AppConfig object, and return a Settings struct
|
|
func (gr *GormRepository) LoadUserSettings(ctx context.Context) (*models.UserSettings, error) {
|
|
currentUser, currentUserErr := gr.GetCurrentUser(ctx)
|
|
if currentUserErr != nil {
|
|
return nil, currentUserErr
|
|
}
|
|
|
|
settingsEntries := []models.UserSettingEntry{}
|
|
if err := gr.GormClient.
|
|
WithContext(ctx).
|
|
Where(models.UserSettingEntry{
|
|
UserID: currentUser.ID,
|
|
}).
|
|
Find(&settingsEntries).Error; err != nil {
|
|
return nil, fmt.Errorf("Could not get settings from DB: %v", err)
|
|
}
|
|
|
|
settings := models.UserSettings{}
|
|
for _, settingsEntry := range settingsEntries {
|
|
err := settings.FromUserSettingsEntry(&settingsEntry)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("Could not get settings from DB: %v", err)
|
|
}
|
|
}
|
|
|
|
return &settings, nil
|
|
}
|
|
|
|
// testing
|
|
// curl -d '{"metrics": { "notify_level": 5, "status_filter_attributes": 5, "status_threshold": 5 }}' -H "Content-Type: application/json" -X POST http://localhost:9090/api/settings
|
|
// SaveSettings will update settings in AppConfig object, then save the settings to the database.
|
|
func (gr *GormRepository) SaveUserSettings(ctx context.Context, newSettings *models.UserSettings) error {
|
|
currentUser, currentUserErr := gr.GetCurrentUser(ctx)
|
|
if currentUserErr != nil {
|
|
return currentUserErr
|
|
}
|
|
|
|
//retrieve current settings from the database
|
|
currentSettingsEntries := []models.UserSettingEntry{}
|
|
|
|
if err := gr.GormClient.
|
|
WithContext(ctx).
|
|
Where(models.UserSettingEntry{
|
|
UserID: currentUser.ID,
|
|
}).
|
|
Find(¤tSettingsEntries).Error; err != nil {
|
|
return fmt.Errorf("Could not get settings from DB: %v", err)
|
|
}
|
|
|
|
//update settingsEntries
|
|
|
|
newSettingsEntries, err := newSettings.ToUserSettingsEntry(currentSettingsEntries)
|
|
if err != nil {
|
|
return fmt.Errorf("merge new settings with DB: %v", err)
|
|
}
|
|
|
|
for ndx, settingsEntry := range newSettingsEntries {
|
|
|
|
// store in database.
|
|
//TODO: this should be `gr.gormClient.Updates(&settingsEntries).Error`
|
|
err := gr.GormClient.
|
|
WithContext(ctx).
|
|
Model(&models.UserSettingEntry{}).
|
|
Where([]uuid.UUID{settingsEntry.ID}).
|
|
Select("setting_value_numeric", "setting_value_string", "setting_value_bool", "setting_value_array").
|
|
Updates(newSettingsEntries[ndx]).Error
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (gr *GormRepository) PopulateDefaultUserSettings(ctx context.Context, userId uuid.UUID) error {
|
|
|
|
//retrieve current settings from the database
|
|
settingsEntries := []models.UserSettingEntry{}
|
|
settingsEntries = append(settingsEntries, models.UserSettingEntry{
|
|
UserID: userId,
|
|
SettingKeyName: "dashboard_locations",
|
|
SettingKeyDescription: "remote dashboard locations (github gists)",
|
|
SettingDataType: "array",
|
|
SettingValueArray: []string{},
|
|
})
|
|
|
|
return gr.GormClient.WithContext(ctx).Create(settingsEntries).Error
|
|
|
|
}
|