diff options
| author | Fuwn <[email protected]> | 2024-08-24 02:38:40 -0700 |
|---|---|---|
| committer | Fuwn <[email protected]> | 2024-08-24 02:42:01 -0700 |
| commit | 32c7545faae4f33c94a045408789c9b9ef7de53a (patch) | |
| tree | 3ce6632bd710b4453749f0e71186027683415843 /src/lib/Database/SB/User/configuration.ts | |
| parent | feat(SequelCatcher): side stories toggle (diff) | |
| download | due.moe-32c7545faae4f33c94a045408789c9b9ef7de53a.tar.xz due.moe-32c7545faae4f33c94a045408789c9b9ef7de53a.zip | |
refactor(Data): rename database references
Diffstat (limited to 'src/lib/Database/SB/User/configuration.ts')
| -rw-r--r-- | src/lib/Database/SB/User/configuration.ts | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/src/lib/Database/SB/User/configuration.ts b/src/lib/Database/SB/User/configuration.ts new file mode 100644 index 00000000..b889e95c --- /dev/null +++ b/src/lib/Database/SB/User/configuration.ts @@ -0,0 +1,47 @@ +import sb from '../../sb'; + +interface UserConfiguration { + user_id: number; + configuration: object; + created_at: string; + updated_at: string; +} + +interface NewUserConfiguration { + configuration: object; + updated_at?: string; +} + +export const getUserConfiguration = async (userId: number) => { + const { data, error } = await sb.from('user_configuration').select('*').eq('user_id', userId); + + if (error || data.length === 0 || data[0].user_id !== userId) return null; + + return data[0] as UserConfiguration; +}; + +export const setUserConfiguration = async (userId: number, configuration: NewUserConfiguration) => { + const { data, error } = await sb + .from('user_configuration') + .upsert( + { + user_id: userId, + configuration: configuration.configuration, + updated_at: configuration.updated_at || new Date().toISOString() + }, + { onConflict: 'user_id' } + ) + .select(); + + if (error || !data || (data as []).length === 0) return null; + + return data[0].configuration as UserConfiguration; +}; + +export const deleteUserConfiguration = async (userId: number) => { + const { data, error } = await sb.from('user_configuration').delete().eq('user_id', userId); + + if (error || !data) return null; + + return data; +}; |