-
Notifications
You must be signed in to change notification settings - Fork 1
Add lidarr as downloader #21
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: dev
Are you sure you want to change the base?
Conversation
4333afb
to
c98d43c
Compare
I'll try running it in my test environment when I have the time. the code looks really good at the moment. It would be nice to get a function to check the download progress of the album, and if it hasn't progressed at all, let's say in 15 minutes, then the album download will stop (and removed from Lidarr). That would allow for the track to be downloaded from another downloader. |
sounds good! i've got the actual logic written up. how would you envision something like that running? i've added it as a goroutine for now, but if there's a different architecture you'd prefer, just name it! |
Yeah, goroutine is what I was thinking too I looked through and ran the code and I'm a bit confused about findArtist() and addArtistIfNeeded(), previously when I investigated Lidarr, I did a manual flow of API requests to download the album and I only used This is the request I used for adding and sending the search to indexers: POST http://URL:PORT/api/v1/album {
"foreignAlbumId": "70bdc19f-66fb-4adf-9124-925ace531101",
"monitored": true,
"qualityProfileId": 1,
"rootFolderPath": "/music",
"monitored": true,
"artist": {
"foreignArtistId": "89ea85c2-c90a-46ea-93db-9bed95d5c8f8",
"qualityProfileId": 1, // Artist's Quality Profile ID
"metadataProfileId": 2, // Artist's Metadata Profile ID
"monitored": true,
"rootFolderPath": "/music"
},
"addOptions": {
"searchForNewAlbum": true
}
} AlbumID and artistID came from album lookup and the ProfileID's could probably be config parameters if the SDK supports it. And i fixed a small issue with track.MainArtist in the dev branch, when searching for albums it's best to use that field, track.Artist could contain all the artists on the track (i.e Justice feat. Tame Impala) |
Add helper funcs; implement hour cooldown for search Check for rejected releases Add cleanup func and worker Add check to artist adding Mark track as present
4582a13
to
3f855d8
Compare
Yeah! so the whole flow was a little confusing for me as well and the sdk doesn't seem to map 1:1 onto the api endpoints which is... frustrating. my understanding is we've got the foreign (read musicbrainz) ids for everything and the internal (lidarr) ids. Lidarr ids for artist/album don't get set if the artist isn't in lidarr already, so i'll dig into the sdk a little further to see if i can bypass a lot of the lookups and just use the mbids to create the album in lidarr |
just for complete context, between these changes, and those in #22, i've now got a new playlist in jellyfin with 33/50 tracks! as far as the flow using sdk is concerned, i think we're roughly stuck at:
|
Wouldn't it be more straightforward to do it without the SDK? It would reduce the amount of flows needed and would give us greater control of the request payloads. Especially when we don't need most of the API functionality (most likely 4-5 endpoints for a full workflow). The flow would look pretty much like this:
Feel free to debate me on this, maybe i just don't get the point of the SDK when Lidarr's API documentation is pretty good. |
Add download monitor
aa1e25b
to
c1be6c0
Compare
This is the first time I've used an SDK, so I'm happy to do it either way! I just pushed up a couple squashed commits that should do all of this a little more cleanly (storing the MBIDs) in the track struct for ease. I also updated the goroutine to both clear stale downloads and mark present newly available tracks Looking forward to your thoughts! |
Made a few changes in the dev branch, main changes include:
I'm also pretty much finished with implementing slskd, you can check how I implemented download monitoring there Also, the linter fails, but that is expected atm. |
Implements an MVP version of a Lidarr downloader using the lidarr-go sdk. Currently, can't seem to automatically download using slskd, but the general workflow is functional. Would probably close #16