diff options
| author | Marie <github@yuugi.dev> | 2024-10-02 19:31:46 +0200 |
|---|---|---|
| committer | Marie <github@yuugi.dev> | 2024-10-02 19:31:46 +0200 |
| commit | 9dd51bc9eb2cf8822b6286d9cd2f29c1cb8808a2 (patch) | |
| tree | b1a6a276bf9749f48687d4717c43c217f7d9740c /packages/backend/src/server | |
| parent | upd: move totalSponsors and donationUrl check (diff) | |
| download | sharkey-9dd51bc9eb2cf8822b6286d9cd2f29c1cb8808a2.tar.gz sharkey-9dd51bc9eb2cf8822b6286d9cd2f29c1cb8808a2.tar.bz2 sharkey-9dd51bc9eb2cf8822b6286d9cd2f29c1cb8808a2.zip | |
upd: fix donationUrl check position
Diffstat (limited to 'packages/backend/src/server')
| -rw-r--r-- | packages/backend/src/server/api/endpoints/sponsors.ts | 29 |
1 files changed, 15 insertions, 14 deletions
diff --git a/packages/backend/src/server/api/endpoints/sponsors.ts b/packages/backend/src/server/api/endpoints/sponsors.ts index 5557e478ee..dadc6eb819 100644 --- a/packages/backend/src/server/api/endpoints/sponsors.ts +++ b/packages/backend/src/server/api/endpoints/sponsors.ts @@ -49,31 +49,32 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint- }; if (ps.instance) { - return { sponsor_data: await maybeCached('instanceSponsors', ps.forceUpdate, async () => { - let totalSponsors; - const meta = await this.metaService.fetch(); - - if (meta.donationUrl && !meta.donationUrl.includes('opencollective.com')) { - return []; - } else if (meta.donationUrl) { + const meta = await this.metaService.fetch(); + if (meta.donationUrl && !meta.donationUrl.includes('opencollective.com')) { + return []; + } else if (meta.donationUrl) { + return { sponsor_data: await maybeCached('instanceSponsors', ps.forceUpdate, async () => { + let totalSponsors; + const meta = await this.metaService.fetch(); + try { const backers = await fetch(`${meta.donationUrl}/members/users.json`).then((response) => response.json()); - + // Merge both together into one array and make sure it only has Active subscriptions const allSponsors = [...backers].filter(sponsor => sponsor.isActive === true && sponsor.role === 'BACKER' && sponsor.tier); - + // Remove possible duplicates totalSponsors = [...new Map(allSponsors.map(v => [v.profile, v])).values()]; - + await this.redisClient.set('instanceSponsors', JSON.stringify(totalSponsors), 'EX', 3600); return totalSponsors; } catch (error) { return []; } - } else { - return []; - } - }) }; + }) }; + } else { + return []; + } } else { return { sponsor_data: await maybeCached('sponsors', ps.forceUpdate, async () => { let totalSponsors; |