From 7c5d31086276ea416928e1753158d13900038bf4 Mon Sep 17 00:00:00 2001 From: synan798 Date: Sat, 30 Nov 2024 00:23:50 +0100 Subject: [PATCH 1/5] added categories to get requests --- server/api/v1/playlist/[uid].get.ts | 10 +++++++--- server/api/v1/playlist/index.get.ts | 14 +++++++++++--- 2 files changed, 18 insertions(+), 6 deletions(-) diff --git a/server/api/v1/playlist/[uid].get.ts b/server/api/v1/playlist/[uid].get.ts index b9be938..ace864b 100644 --- a/server/api/v1/playlist/[uid].get.ts +++ b/server/api/v1/playlist/[uid].get.ts @@ -25,12 +25,16 @@ export default defineEventHandler(async (event) => { } const client = serverSupabaseServiceRole(event); - const {data, error} = await client.from('playlists').select('*').eq('id', playlistId).single(); + const {data, error} = await client.from('playlists').select('*, categories (name)').eq('id', playlistId).single(); if (error) { setResponseStatus(event, 500); return {error: error.message}; + } else { + const transformedData = { + ...data, + categories: data.categories.map(category => category.name) + }; + return transformedData; } - - return data; }) \ No newline at end of file diff --git a/server/api/v1/playlist/index.get.ts b/server/api/v1/playlist/index.get.ts index 1a23cb1..c1e3d9b 100644 --- a/server/api/v1/playlist/index.get.ts +++ b/server/api/v1/playlist/index.get.ts @@ -16,12 +16,20 @@ export default defineEventHandler(async (event) => { } const client = serverSupabaseServiceRole(event); - const {data, error} = await client.from('playlists').select(); + const {data, error} = await client.from('playlists') + .select(` + *, + categories (name) + `); if (error) { setResponseStatus(event, 500); return {error: error.message}; + } else { + const transformedData = data.map(playlist => ({ + ...playlist, + categories: playlist.categories.map(category => category.name), + })); + return transformedData; } - - return data; }) \ No newline at end of file From 3d511f30c5e151d889922d6302b107f8320ba8f5 Mon Sep 17 00:00:00 2001 From: synan798 Date: Sat, 30 Nov 2024 12:37:31 +0100 Subject: [PATCH 2/5] added categories to post request (getPlaylistCover doesn't work) --- server/api/v1/playlist/index.post.ts | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/server/api/v1/playlist/index.post.ts b/server/api/v1/playlist/index.post.ts index 7fa2412..d53e039 100644 --- a/server/api/v1/playlist/index.post.ts +++ b/server/api/v1/playlist/index.post.ts @@ -21,6 +21,7 @@ const schema = z.object({ * @returns {Object} - Created playlist */ export default defineEventHandler(async (event) => { + // fix coverUrl and delete test.vue const result = await readValidatedBody(event, body => schema.safeParse(body)) if (!result.success) { @@ -36,11 +37,18 @@ export default defineEventHandler(async (event) => { name: result.data.name, spotifyId: result.data.spotifyId, cover: coverUrl + //cover: "https://i.scdn.co/image/ab67706f000000024d183558628c25f8cb314eea" } - const client = serverSupabaseServiceRole(event) + const categoriesInsert = result.data.categories.map((category) => ({ + playlistId: result.data.id, + name: category, + })); + + const client = serverSupabaseServiceRole(event); const {data, error} = await client.from('playlists').insert(playlistInsert as never).select().single(); //todo: fix type error! + if (error) { setResponseStatus(event, 400); if (error.code === UNIQUE_VIOLATION) @@ -49,6 +57,15 @@ export default defineEventHandler(async (event) => { return {error: error.message}; } + const { data: categoriesData, error: categoriesError } = await client + .from('categories') + .insert(categoriesInsert as never); + + if (categoriesError) { + setResponseStatus(event, 500); + return { error: `Error inserting categories: ${categoriesError.message}` }; + } + setResponseStatus(event, 201); return data; From a8a731d0daae502c127af6a2e0b753b3377d1be1 Mon Sep 17 00:00:00 2001 From: Lukas Lanzner Date: Sat, 30 Nov 2024 12:53:38 +0100 Subject: [PATCH 3/5] fix(playlist): Fix playlist cover not loading --- server/api/v1/playlist/index.post.ts | 2 -- server/utils/spotify.ts | 5 +++-- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/server/api/v1/playlist/index.post.ts b/server/api/v1/playlist/index.post.ts index d53e039..d22a410 100644 --- a/server/api/v1/playlist/index.post.ts +++ b/server/api/v1/playlist/index.post.ts @@ -21,7 +21,6 @@ const schema = z.object({ * @returns {Object} - Created playlist */ export default defineEventHandler(async (event) => { - // fix coverUrl and delete test.vue const result = await readValidatedBody(event, body => schema.safeParse(body)) if (!result.success) { @@ -37,7 +36,6 @@ export default defineEventHandler(async (event) => { name: result.data.name, spotifyId: result.data.spotifyId, cover: coverUrl - //cover: "https://i.scdn.co/image/ab67706f000000024d183558628c25f8cb314eea" } const categoriesInsert = result.data.categories.map((category) => ({ diff --git a/server/utils/spotify.ts b/server/utils/spotify.ts index 3639c9f..1f07a71 100644 --- a/server/utils/spotify.ts +++ b/server/utils/spotify.ts @@ -38,9 +38,10 @@ export async function getSpotifyToken() { export async function getPlaylistCover(token: string | null, playlistId: string): Promise { if (!token) return undefined; - const res = await fetch(`https://api.spotify.com/v1/playlists/${playlistId}?fields=images`, { + const res = await fetch(`https://api.spotify.com/v1/playlists/${playlistId}/images`, { headers: {'Authorization': `Bearer ${token}`} }) const data = await res.json() - return data.images[0].url; + // console.log(data) + return data[0].url; } \ No newline at end of file From d6f80fa424b910881bed29840409f32283f1da4d Mon Sep 17 00:00:00 2001 From: Lukas Lanzner Date: Sat, 30 Nov 2024 13:05:24 +0100 Subject: [PATCH 4/5] feat(playlist): Add DDL for playlist database schema --- DB/playlists.sql | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 DB/playlists.sql diff --git a/DB/playlists.sql b/DB/playlists.sql new file mode 100644 index 0000000..9c39e60 --- /dev/null +++ b/DB/playlists.sql @@ -0,0 +1,17 @@ +create table playlists +( + id text not null primary key, + "spotifyId" text not null, + name text not null, + cover text, + enabled boolean default false not null +); + +CREATE UNIQUE INDEX enabled_playlist_unique_name ON playlists (name) WHERE enabled = true; + +create table categories +( + name text not null, + "playlistId" text not null references playlists, + primary key (name, "playlistId") +); From 90aaf2d3f9f65fa94447e516c1141974ac5898b2 Mon Sep 17 00:00:00 2001 From: synan798 Date: Sat, 30 Nov 2024 16:15:27 +0100 Subject: [PATCH 5/5] added correct return statement --- server/api/v1/playlist/index.post.ts | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/server/api/v1/playlist/index.post.ts b/server/api/v1/playlist/index.post.ts index d22a410..7131877 100644 --- a/server/api/v1/playlist/index.post.ts +++ b/server/api/v1/playlist/index.post.ts @@ -44,15 +44,15 @@ export default defineEventHandler(async (event) => { })); const client = serverSupabaseServiceRole(event); - const {data, error} = await client.from('playlists').insert(playlistInsert as never).select().single(); //todo: fix type error! + const {data: playlistData, error: playlistError} = await client.from('playlists').insert(playlistInsert as never).select().single(); //todo: fix type error! - if (error) { + if (playlistError) { setResponseStatus(event, 400); - if (error.code === UNIQUE_VIOLATION) + if (playlistError.code === UNIQUE_VIOLATION) return {error: 'Playlist with this ID already exists'}; setResponseStatus(event, 500); - return {error: error.message}; + return {error: playlistError.message}; } const { data: categoriesData, error: categoriesError } = await client @@ -66,5 +66,5 @@ export default defineEventHandler(async (event) => { setResponseStatus(event, 201); - return data; + return { playlist: playlistData, categories: categoriesData }; }) \ No newline at end of file