summaryrefslogtreecommitdiff
path: root/packages/backend/src/server
diff options
context:
space:
mode:
authorMarie <github@yuugi.dev>2024-10-02 19:31:46 +0200
committerMarie <github@yuugi.dev>2024-10-02 19:31:46 +0200
commit9dd51bc9eb2cf8822b6286d9cd2f29c1cb8808a2 (patch)
treeb1a6a276bf9749f48687d4717c43c217f7d9740c /packages/backend/src/server
parentupd: move totalSponsors and donationUrl check (diff)
downloadsharkey-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.ts29
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;