Auth: Remove types from SSOSettings struct in SSO service (#79459)
* replace SSOSettings with SSOSettingsDTO * fix database tests * fix oauth strategy * fix sso settings service tests * add secrets encryption on update * rename SSOSettingsDTO to SSOSettings * remove extraKeys from strategy * change back settings type from createOAuthConnector to OAuthInfo * do not parse multi-value fields in oauth strategy
This commit is contained in:
@@ -32,7 +32,7 @@ func ProvideStore(sqlStore db.DB) *SSOSettingsStore {
|
||||
var _ ssosettings.Store = (*SSOSettingsStore)(nil)
|
||||
|
||||
func (s *SSOSettingsStore) Get(ctx context.Context, provider string) (*models.SSOSettings, error) {
|
||||
result := models.SSOSettingsDTO{Provider: provider}
|
||||
result := models.SSOSettings{Provider: provider}
|
||||
err := s.sqlStore.WithDbSession(ctx, func(sess *db.Session) error {
|
||||
var err error
|
||||
sess.Table("sso_setting")
|
||||
@@ -53,19 +53,14 @@ func (s *SSOSettingsStore) Get(ctx context.Context, provider string) (*models.SS
|
||||
return nil, err
|
||||
}
|
||||
|
||||
dto, err := result.ToSSOSettings()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return dto, nil
|
||||
return &result, nil
|
||||
}
|
||||
|
||||
func (s *SSOSettingsStore) List(ctx context.Context) ([]*models.SSOSettings, error) {
|
||||
dtos := make([]*models.SSOSettingsDTO, 0)
|
||||
result := make([]*models.SSOSettings, 0)
|
||||
err := s.sqlStore.WithDbSession(ctx, func(sess *db.Session) error {
|
||||
sess.Table("sso_setting")
|
||||
err := sess.Where("is_deleted = ?", s.sqlStore.GetDialect().BooleanStr(false)).Find(&dtos)
|
||||
err := sess.Where("is_deleted = ?", s.sqlStore.GetDialect().BooleanStr(false)).Find(&result)
|
||||
|
||||
if err != nil {
|
||||
return err
|
||||
@@ -78,29 +73,13 @@ func (s *SSOSettingsStore) List(ctx context.Context) ([]*models.SSOSettings, err
|
||||
return nil, err
|
||||
}
|
||||
|
||||
settings := make([]*models.SSOSettings, 0)
|
||||
for _, dto := range dtos {
|
||||
item, err := dto.ToSSOSettings()
|
||||
if err != nil {
|
||||
s.log.Warn("Failed to convert DB settings to SSOSettings for provider " + dto.Provider)
|
||||
continue
|
||||
}
|
||||
|
||||
settings = append(settings, item)
|
||||
}
|
||||
|
||||
return settings, nil
|
||||
return result, nil
|
||||
}
|
||||
|
||||
func (s *SSOSettingsStore) Upsert(ctx context.Context, settings models.SSOSettings) error {
|
||||
dto, err := settings.ToSSOSettingsDTO()
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return s.sqlStore.WithDbSession(ctx, func(sess *db.Session) error {
|
||||
existing := &models.SSOSettingsDTO{
|
||||
Provider: dto.Provider,
|
||||
existing := &models.SSOSettings{
|
||||
Provider: settings.Provider,
|
||||
IsDeleted: false,
|
||||
}
|
||||
found, err := sess.UseBool("is_deleted").Exist(existing)
|
||||
@@ -111,17 +90,17 @@ func (s *SSOSettingsStore) Upsert(ctx context.Context, settings models.SSOSettin
|
||||
now := timeNow().UTC()
|
||||
|
||||
if found {
|
||||
updated := &models.SSOSettingsDTO{
|
||||
Settings: dto.Settings,
|
||||
updated := &models.SSOSettings{
|
||||
Settings: settings.Settings,
|
||||
Updated: now,
|
||||
IsDeleted: false,
|
||||
}
|
||||
_, err = sess.UseBool("is_deleted").Update(updated, existing)
|
||||
} else {
|
||||
_, err = sess.Insert(&models.SSOSettingsDTO{
|
||||
_, err = sess.Insert(&models.SSOSettings{
|
||||
ID: uuid.New().String(),
|
||||
Provider: dto.Provider,
|
||||
Settings: dto.Settings,
|
||||
Provider: settings.Provider,
|
||||
Settings: settings.Settings,
|
||||
Created: now,
|
||||
Updated: now,
|
||||
})
|
||||
@@ -137,7 +116,7 @@ func (s *SSOSettingsStore) Patch(ctx context.Context, provider string, data map[
|
||||
|
||||
func (s *SSOSettingsStore) Delete(ctx context.Context, provider string) error {
|
||||
return s.sqlStore.WithDbSession(ctx, func(sess *db.Session) error {
|
||||
existing := &models.SSOSettingsDTO{
|
||||
existing := &models.SSOSettings{
|
||||
Provider: provider,
|
||||
IsDeleted: false,
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user