initial: AI-generated jukebox metadata lib (Cursor's Composer 2)
This commit is contained in:
45
schema/playlist_cache.sql
Normal file
45
schema/playlist_cache.sql
Normal file
@@ -0,0 +1,45 @@
|
||||
-- Schema derived from docs/playlists.md only.
|
||||
-- Stores playlists, track list membership, and tracks (artist display name on track row).
|
||||
-- Does not persist album objects or album.artists.
|
||||
|
||||
PRAGMA foreign_keys = ON;
|
||||
|
||||
-- SimplifiedPlaylistObject / PlaylistObject
|
||||
CREATE TABLE playlists (
|
||||
id TEXT PRIMARY KEY,
|
||||
description TEXT,
|
||||
name TEXT NOT NULL,
|
||||
primary_color TEXT,
|
||||
snapshot_id TEXT NOT NULL,
|
||||
tracks_href TEXT,
|
||||
tracks_total INTEGER
|
||||
);
|
||||
|
||||
CREATE TABLE playlist_images (
|
||||
playlist_id TEXT NOT NULL REFERENCES playlists (id) ON DELETE CASCADE,
|
||||
image_index INTEGER NOT NULL,
|
||||
url TEXT NOT NULL,
|
||||
height INTEGER,
|
||||
width INTEGER,
|
||||
PRIMARY KEY (playlist_id, image_index)
|
||||
);
|
||||
|
||||
-- TrackObject + display of track.artists[].name (single column; if the API lists
|
||||
-- multiple artists, join their names e.g. "A, B" in documented order).
|
||||
CREATE TABLE tracks (
|
||||
id TEXT PRIMARY KEY,
|
||||
track_name TEXT NOT NULL,
|
||||
artist_name TEXT NOT NULL,
|
||||
duration_ms INTEGER NOT NULL
|
||||
);
|
||||
|
||||
-- Order of tracks in a playlist (matches playlist.tracks.items[] order).
|
||||
-- track_id NULL when the API returns a removed track (wrapper with track: null).
|
||||
CREATE TABLE playlist_tracks (
|
||||
playlist_id TEXT NOT NULL REFERENCES playlists (id) ON DELETE CASCADE,
|
||||
position INTEGER NOT NULL,
|
||||
track_id TEXT REFERENCES tracks (id) ON DELETE SET NULL,
|
||||
PRIMARY KEY (playlist_id, position)
|
||||
);
|
||||
|
||||
CREATE INDEX idx_playlist_tracks_track ON playlist_tracks (track_id);
|
||||
Reference in New Issue
Block a user