From da59faf8ebb7ecad96c78422bc6fc4d4ecdb454b Mon Sep 17 00:00:00 2001 From: Ayman Bagabas Date: Wed, 13 Sep 2023 09:49:17 -0400 Subject: [PATCH] fix(db): quote postgres keywords The keyword "key" is a reserved word in Postgres and must be quoted if used as a column name. Fixes: https://github.com/charmbracelet/soft-serve/issues/380 --- server/store/database/settings.go | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/server/store/database/settings.go b/server/store/database/settings.go index ec63eae01..ace96f717 100644 --- a/server/store/database/settings.go +++ b/server/store/database/settings.go @@ -15,7 +15,7 @@ var _ store.SettingStore = (*settingsStore)(nil) // GetAllowKeylessAccess implements store.SettingStore. func (*settingsStore) GetAllowKeylessAccess(ctx context.Context, tx db.Handler) (bool, error) { var allow bool - query := tx.Rebind(`SELECT value FROM settings WHERE key = "allow_keyless"`) + query := tx.Rebind(`SELECT value FROM settings WHERE "key" = 'allow_keyless'`) if err := tx.GetContext(ctx, &allow, query); err != nil { return false, db.WrapError(err) } @@ -25,7 +25,7 @@ func (*settingsStore) GetAllowKeylessAccess(ctx context.Context, tx db.Handler) // GetAnonAccess implements store.SettingStore. func (*settingsStore) GetAnonAccess(ctx context.Context, tx db.Handler) (access.AccessLevel, error) { var level string - query := tx.Rebind(`SELECT value FROM settings WHERE key = "anon_access"`) + query := tx.Rebind(`SELECT value FROM settings WHERE "key" = 'anon_access'`) if err := tx.GetContext(ctx, &level, query); err != nil { return access.NoAccess, db.WrapError(err) } @@ -34,14 +34,14 @@ func (*settingsStore) GetAnonAccess(ctx context.Context, tx db.Handler) (access. // SetAllowKeylessAccess implements store.SettingStore. func (*settingsStore) SetAllowKeylessAccess(ctx context.Context, tx db.Handler, allow bool) error { - query := tx.Rebind(`UPDATE settings SET value = ?, updated_at = CURRENT_TIMESTAMP WHERE key = "allow_keyless"`) + query := tx.Rebind(`UPDATE settings SET value = ?, updated_at = CURRENT_TIMESTAMP WHERE "key" = 'allow_keyless'`) _, err := tx.ExecContext(ctx, query, allow) return db.WrapError(err) } // SetAnonAccess implements store.SettingStore. func (*settingsStore) SetAnonAccess(ctx context.Context, tx db.Handler, level access.AccessLevel) error { - query := tx.Rebind(`UPDATE settings SET value = ?, updated_at = CURRENT_TIMESTAMP WHERE key = "anon_access"`) + query := tx.Rebind(`UPDATE settings SET value = ?, updated_at = CURRENT_TIMESTAMP WHERE "key" = 'anon_access'`) _, err := tx.ExecContext(ctx, query, level.String()) return db.WrapError(err) }