Fix check if exists trackNumber field

This commit is contained in:
Fabio Scotto di Santolo
2024-11-19 16:34:30 +01:00
parent ce12891a9a
commit 18713004b0

View File

@@ -34,11 +34,13 @@ async def __extract_data(data: dict[str, Any]) -> dict[str, Any]:
def sanitize(s: str) -> str: def sanitize(s: str) -> str:
rules = ( rules = (
lambda x: re.sub(f'{os.path.sep}', repl='-', string=x), lambda x: re.sub(f"{os.path.sep}", repl="-", string=x),
lambda x: re.sub(f':', repl='_', string=x), lambda x: re.sub(":", repl="_", string=x),
lambda x: re.sub(f'\\?', repl='', string=x), lambda x: re.sub("\\?", repl="", string=x),
lambda x: re.sub(f'"', repl='', string=x), lambda x: re.sub('"', repl="", string=x),
lambda x: re.sub(f"'", repl='', string=x), lambda x: re.sub("'", repl="", string=x),
lambda x: re.sub("\\*", repl="0", string=x),
lambda x: re.sub("!", repl="", string=x),
) )
for rule in rules: for rule in rules:
s = rule(s) s = rule(s)
@@ -46,34 +48,34 @@ async def __extract_data(data: dict[str, Any]) -> dict[str, Any]:
logger.debug(json.dumps(data, indent=2)) logger.debug(json.dumps(data, indent=2))
track_data = data["track"] track_data = data["track"]
track_attrs = list(itertools.chain(*[x["metadata"] for x in track_data["sections"] if "metadata" in x])) track_attrs = list(
album_id = track_data.get('albumadamid') itertools.chain(
*[x["metadata"] for x in track_data["sections"] if "metadata" in x]
)
)
album_id = track_data.get("albumadamid")
if album_id: if album_id:
album_attrs = seek_track( album_attrs = seek_track(
x=track_data["title"], x=track_data["title"],
metadata=await __SHAZAM_CLIENT.album(album_id=int(album_id)) metadata=await __SHAZAM_CLIENT.album(album_id=int(album_id)),
) )
return { return {
"title": sanitize(track_data["title"]), "title": sanitize(track_data["title"]),
"artist": sanitize(track_data["subtitle"]), "artist": sanitize(track_data["subtitle"]),
"track_number": album_attrs["trackNumber"], "track_number": album_attrs["trackNumber"] if "trackNumber" in album_attrs else 0,
"album": { "album": {
"id": int(album_id), "id": int(album_id),
"name": sanitize(album_field("Album", track_attrs)), "name": sanitize(album_field("Album", track_attrs)),
"released": album_field("Released", track_attrs) "released": album_field("Released", track_attrs),
} },
} }
else: else:
return { return {
"title": sanitize(track_data["title"]), "title": sanitize(track_data["title"]),
"artist": sanitize(track_data["subtitle"]), "artist": sanitize(track_data["subtitle"]),
"track_number": 0, "track_number": 0,
"album": { "album": {"id": 0, "name": "Unknown", "released": 0},
"id": 0,
"name": "Unknown",
"released": 0
}
} }
@@ -91,6 +93,6 @@ async def search_song(song_file: str) -> TrackInfo:
album=Album( album=Album(
album_id=album_data["id"], album_id=album_data["id"],
name=album_data["name"], name=album_data["name"],
released=album_data["released"] released=album_data["released"],
) ),
) )