diff --git a/supysonic/db.py b/supysonic/db.py index 0c745cd..022990b 100644 --- a/supysonic/db.py +++ b/supysonic/db.py @@ -318,8 +318,8 @@ def prune(cls): class Track(PathMixin, _Model): id = PrimaryKeyField() - disc = IntegerField() - number = IntegerField() + disc = IntegerField(null=True) + number = IntegerField(null=True) title = CharField() year = IntegerField(null=True) genre = CharField(null=True) @@ -350,7 +350,7 @@ def as_subsonic_child(self, user, prefs): "title": self.title, "album": self.album.name, "artist": self.artist.name, - "track": self.number, + "track": self.number or "", "size": os.path.getsize(self.path) if os.path.isfile(self.path) else -1, "contentType": self.mimetype, "suffix": self.suffix(), @@ -358,7 +358,7 @@ def as_subsonic_child(self, user, prefs): "bitRate": self.bitrate, "path": self.path[len(self.root_folder.path) + 1 :], "isVideo": False, - "discNumber": self.disc, + "discNumber": self.disc or "", "created": self.created.isoformat(), "albumId": str(self.album.id), "artistId": str(self.artist.id), @@ -421,7 +421,7 @@ def suffix(self): return os.path.splitext(self.path)[1][1:].lower() def sort_key(self): - return f"{self.album.artist.name}{self.album.name}{self.disc:02}{self.number:02}{self.title}".lower() + return f"{self.album.artist.name}{self.album.name}{self.disc:02 or ''}{self.number:02 or ''}{self.title}".lower() class User(_Model): diff --git a/supysonic/schema/mysql.sql b/supysonic/schema/mysql.sql index 4c85bba..6394e5c 100644 --- a/supysonic/schema/mysql.sql +++ b/supysonic/schema/mysql.sql @@ -25,8 +25,8 @@ CREATE INDEX index_album_artist_id_fk ON album(artist_id); CREATE TABLE IF NOT EXISTS track ( id CHAR(32) PRIMARY KEY, - disc INTEGER NOT NULL, - number INTEGER NOT NULL, + disc INTEGER, + number INTEGER, title VARCHAR(256) NOT NULL, year INTEGER, genre VARCHAR(256), diff --git a/supysonic/schema/postgres.sql b/supysonic/schema/postgres.sql index 1984266..591ec39 100644 --- a/supysonic/schema/postgres.sql +++ b/supysonic/schema/postgres.sql @@ -25,8 +25,8 @@ CREATE INDEX IF NOT EXISTS index_album_artist_id_fk ON album(artist_id); CREATE TABLE IF NOT EXISTS track ( id UUID PRIMARY KEY, - disc INTEGER NOT NULL, - number INTEGER NOT NULL, + disc INTEGER, + number INTEGER, title CITEXT NOT NULL, year INTEGER, genre VARCHAR(256), diff --git a/supysonic/schema/sqlite.sql b/supysonic/schema/sqlite.sql index ae39a87..eb3960a 100644 --- a/supysonic/schema/sqlite.sql +++ b/supysonic/schema/sqlite.sql @@ -26,8 +26,8 @@ CREATE INDEX IF NOT EXISTS index_album_artist_id_fk ON album(artist_id); CREATE TABLE IF NOT EXISTS track ( id CHAR(36) PRIMARY KEY, - disc INTEGER NOT NULL, - number INTEGER NOT NULL, + disc INTEGER, + number INTEGER, title VARCHAR(256) NOT NULL COLLATE NOCASE, year INTEGER, genre VARCHAR(256),