Fixed: Removing from Goodreads shelf when different edition imported

pull/1365/head
ta264 3 years ago
parent fb0128e3be
commit 6cecf23b88

@ -22,8 +22,21 @@ namespace NzbDrone.Core.Notifications.Goodreads
public override void OnReleaseImport(BookDownloadMessage message) public override void OnReleaseImport(BookDownloadMessage message)
{ {
var bookId = message.Book.Editions.Value.Single(x => x.Monitored).ForeignEditionId; var importedBook = message.Book;
RemoveBookFromShelves(bookId, Settings.RemoveIds);
foreach (var shelf in Settings.RemoveIds)
{
// try to find the edition that we need to remove
var listBooks = SearchShelf(shelf, importedBook.AuthorMetadata.Value.Name);
var toRemove = listBooks.Where(x => x.Book.WorkId.ToString() == importedBook.ForeignBookId);
foreach (var listBook in toRemove)
{
RemoveBookFromShelves(listBook.Book.Id, shelf);
}
}
var bookId = importedBook.Editions.Value.Single(x => x.Monitored).ForeignEditionId;
AddToShelves(bookId, Settings.AddIds); AddToShelves(bookId, Settings.AddIds);
} }
@ -104,9 +117,47 @@ namespace NzbDrone.Core.Notifications.Goodreads
} }
} }
private void RemoveBookFromShelves(string bookId, IEnumerable<string> shelves) private IReadOnlyList<ReviewResource> SearchShelf(string shelf, string query)
{
List<ReviewResource> results = new ();
while (true)
{
var page = 1;
try
{
var builder = RequestBuilder()
.SetSegment("route", $"review/list.xml")
.AddQueryParam("v", 2)
.AddQueryParam("id", Settings.UserId)
.AddQueryParam("shelf", shelf)
.AddQueryParam("per_page", 200)
.AddQueryParam("page", page++)
.AddQueryParam("search[query]", query);
var httpResponse = OAuthExecute(builder);
var resource = httpResponse.Deserialize<PaginatedList<ReviewResource>>("reviews");
results.AddRange(resource.List);
if (resource.Pagination.End >= resource.Pagination.TotalItems)
{
break;
}
}
catch (Exception ex)
{ {
foreach (var shelf in shelves) _logger.Warn(ex, "Error fetching bookshelves from Goodreads");
return results;
}
}
return results;
}
private void RemoveBookFromShelves(long bookId, string shelf)
{ {
var req = RequestBuilder() var req = RequestBuilder()
.Post() .Post()
@ -120,7 +171,6 @@ namespace NzbDrone.Core.Notifications.Goodreads
OAuthExecute(req); OAuthExecute(req);
} }
}
private void AddToShelves(string bookId, IEnumerable<string> shelves) private void AddToShelves(string bookId, IEnumerable<string> shelves)
{ {

Loading…
Cancel
Save