mirror of
https://github.com/SoPat712/allstarr.git
synced 2026-02-10 07:58:39 -05:00
feat: add 6 new SquidWTF endpoints and optimize Odesli conversion
- Added 6 new monochrome.tf endpoints (eu-central, us-west, arran, api, samidy) - Added https variant of hund.qqdl.site (was only http before) - Total endpoints increased from 10 to 16 for better load distribution - Optimized Odesli/Spotify ID conversion with 2-second timeout - If Odesli is slow, download proceeds without waiting (Spotify ID added in background) - This reduces download time by up to 2 seconds when Odesli is slow - Spotify ID still obtained for lyrics, just doesn't block streaming Performance improvement: Downloads that took 9.7s may now complete in 7.7s
This commit is contained in:
@@ -22,16 +22,22 @@ static List<string> DecodeSquidWtfUrls()
|
|||||||
{
|
{
|
||||||
var encodedUrls = new[]
|
var encodedUrls = new[]
|
||||||
{
|
{
|
||||||
"aHR0cHM6Ly90cml0b24uc3F1aWQud3Rm", // triton
|
"aHR0cHM6Ly90cml0b24uc3F1aWQud3Rm", // triton.squid.wtf
|
||||||
"aHR0cHM6Ly90aWRhbC1hcGkuYmluaW11bS5vcmc=", // binimum
|
"aHR0cHM6Ly90aWRhbC1hcGkuYmluaW11bS5vcmc=", // tidal-api.binimum.org
|
||||||
"aHR0cHM6Ly90aWRhbC5raW5vcGx1cy5vbmxpbmU=", // kinoplus
|
"aHR0cHM6Ly90aWRhbC5raW5vcGx1cy5vbmxpbmU=", // tidal.kinoplus.online
|
||||||
"aHR0cHM6Ly9oaWZpLXR3by5zcG90aXNhdmVyLm5ldA==", // spoti-2
|
"aHR0cHM6Ly9oaWZpLXR3by5zcG90aXNhdmVyLm5ldA==", // hifi-two.spotisaver.net
|
||||||
"aHR0cHM6Ly9oaWZpLW9uZS5zcG90aXNhdmVyLm5ldA==", // spoti-1
|
"aHR0cHM6Ly9oaWZpLW9uZS5zcG90aXNhdmVyLm5ldA==", // hifi-one.spotisaver.net
|
||||||
"aHR0cHM6Ly93b2xmLnFxZGwuc2l0ZQ==", // wolf
|
"aHR0cHM6Ly93b2xmLnFxZGwuc2l0ZQ==", // wolf.qqdl.site
|
||||||
"aHR0cDovL2h1bmQucXFkbC5zaXRl", // hund
|
"aHR0cDovL2h1bmQucXFkbC5zaXRl", // hund.qqdl.site (http)
|
||||||
"aHR0cHM6Ly9rYXR6ZS5xcWRsLnNpdGU=", // katze
|
"aHR0cHM6Ly9rYXR6ZS5xcWRsLnNpdGU=", // katze.qqdl.site
|
||||||
"aHR0cHM6Ly92b2dlbC5xcWRsLnNpdGU=", // vogel
|
"aHR0cHM6Ly92b2dlbC5xcWRsLnNpdGU=", // vogel.qqdl.site
|
||||||
"aHR0cHM6Ly9tYXVzLnFxZGwuc2l0ZQ==" // maus
|
"aHR0cHM6Ly9tYXVzLnFxZGwuc2l0ZQ==", // maus.qqdl.site
|
||||||
|
"aHR0cHM6Ly9ldS1jZW50cmFsLm1vbm9jaHJvbWUudGY=", // eu-central.monochrome.tf
|
||||||
|
"aHR0cHM6Ly91cy13ZXN0Lm1vbm9jaHJvbWUudGY=", // us-west.monochrome.tf
|
||||||
|
"aHR0cHM6Ly9hcnJhbi5tb25vY2hyb21lLnRm", // arran.monochrome.tf
|
||||||
|
"aHR0cHM6Ly9hcGkubW9ub2Nocm9tZS50Zg==", // api.monochrome.tf
|
||||||
|
"aHR0cHM6Ly9tb25vY2hyb21lLWFwaS5zYW1pZHkuY29t", // monochrome-api.samidy.com
|
||||||
|
"aHR0cHM6Ly9odW5kLnFxZGwuc2l0ZQ==" // hund.qqdl.site (https)
|
||||||
};
|
};
|
||||||
|
|
||||||
return encodedUrls
|
return encodedUrls
|
||||||
|
|||||||
@@ -199,11 +199,39 @@ public class SquidWTFDownloadService : BaseDownloadService
|
|||||||
// Close file before writing metadata
|
// Close file before writing metadata
|
||||||
await outputFile.DisposeAsync();
|
await outputFile.DisposeAsync();
|
||||||
|
|
||||||
// Wait for Spotify ID conversion to complete and update song metadata
|
// Wait for Spotify ID conversion to complete (with 2 second timeout)
|
||||||
var spotifyId = await spotifyIdTask;
|
// If Odesli is slow, we'll skip it and add the Spotify ID later in background
|
||||||
|
var spotifyId = await Task.WhenAny(
|
||||||
|
spotifyIdTask,
|
||||||
|
Task.Delay(2000, cancellationToken)
|
||||||
|
) == spotifyIdTask ? await spotifyIdTask : null;
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(spotifyId))
|
if (!string.IsNullOrEmpty(spotifyId))
|
||||||
{
|
{
|
||||||
song.SpotifyId = spotifyId;
|
song.SpotifyId = spotifyId;
|
||||||
|
Logger.LogDebug("Spotify ID obtained: {SpotifyId}", spotifyId);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Logger.LogDebug("Spotify ID not available yet (Odesli timeout), will update in background");
|
||||||
|
|
||||||
|
// Continue Odesli conversion in background (for future lyrics requests)
|
||||||
|
_ = Task.Run(async () =>
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
var bgSpotifyId = await spotifyIdTask;
|
||||||
|
if (!string.IsNullOrEmpty(bgSpotifyId))
|
||||||
|
{
|
||||||
|
Logger.LogDebug("Background Spotify ID obtained: {SpotifyId}", bgSpotifyId);
|
||||||
|
// Note: We don't re-write metadata here, just cache the ID for lyrics
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
Logger.LogDebug(ex, "Background Spotify ID conversion failed");
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// Write metadata and cover art
|
// Write metadata and cover art
|
||||||
|
|||||||
Reference in New Issue
Block a user