mirror of
https://github.com/stashapp/stash.git
synced 2025-12-16 20:07:05 +03:00
Fix inconsistency when scraping performer with multiple stash ids from same endpoint (#6260)
This commit is contained in:
@@ -146,6 +146,22 @@ export const PerformerScrapeDialog: React.FC<IPerformerScrapeDialogProps> = (
|
||||
return;
|
||||
}
|
||||
|
||||
// #6257 - it is possible (though unsupported) to have multiple stash IDs for the same
|
||||
// endpoint; in that case, we should prefer the one matching the scraped remote site ID
|
||||
// if it exists
|
||||
const stashIDs = (props.performer.stash_ids ?? []).filter(
|
||||
(s) => s.endpoint === endpoint
|
||||
);
|
||||
if (stashIDs.length > 1 && props.scraped.remote_site_id) {
|
||||
const matchingID = stashIDs.find(
|
||||
(s) => s.stash_id === props.scraped.remote_site_id
|
||||
);
|
||||
if (matchingID) {
|
||||
return matchingID.stash_id;
|
||||
}
|
||||
}
|
||||
|
||||
// otherwise, return the first stash ID for the endpoint
|
||||
return props.performer.stash_ids?.find((s) => s.endpoint === endpoint)
|
||||
?.stash_id;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user