merge: Add fail safe for sponsors endpoint in case of not being able to connect (!436)

View MR for information: https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/436

Closes #428

Approved-by: Amelia Yukii <amelia.yukii@shourai.de>
Approved-by: dakkar <dakkar@thenautilus.net>
This commit is contained in:
Amelia Yukii 2024-02-21 18:59:31 +00:00
commit 8197148209
2 changed files with 30 additions and 23 deletions

View file

@ -1,20 +1,20 @@
import { Inject, Injectable } from '@nestjs/common';
import * as Redis from 'ioredis';
import { Endpoint } from '@/server/api/endpoint-base.js';
import { DI } from '@/di-symbols.js';
import * as Redis from 'ioredis';
export const meta = {
tags: ["meta"],
description: "Get Sharkey GH Sponsors",
tags: ['meta'],
description: 'Get Sharkey GH Sponsors',
requireCredential: false,
requireCredentialPrivateMode: false,
} as const;
export const paramDef = {
type: "object",
type: 'object',
properties: {
forceUpdate: { type: "boolean", default: false },
forceUpdate: { type: 'boolean', default: false },
},
required: [],
} as const;
@ -26,7 +26,7 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
) {
super(meta, paramDef, async (ps, me) => {
let sponsors;
const cachedSponsors = await this.redisClient.get("sponsors");
const cachedSponsors = await this.redisClient.get('sponsors');
if (!ps.forceUpdate && cachedSponsors) {
sponsors = JSON.parse(cachedSponsors);
} else {
@ -36,9 +36,16 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
return ctrl.signal;
};
sponsors = await fetch("https://kaifa.ch/transfem-sponsors.json", { signal: AbortSignal.timeout(2000) })
try {
sponsors = await fetch('https://kaifa.ch/transfem-sponsors.json', { signal: AbortSignal.timeout(2000) })
.then((response) => response.json());
await this.redisClient.set("sponsors", JSON.stringify(sponsors), "EX", 3600);
await this.redisClient.set('sponsors', JSON.stringify(sponsors), 'EX', 3600);
} catch (error) {
sponsors = {
sponsors: [],
};
}
}
return { sponsor_data: sponsors['sponsors'] };
});

View file

@ -121,7 +121,7 @@ SPDX-License-Identifier: AGPL-3.0-only
</a>
</div>
</FormSection>
<FormSection>
<FormSection v-if="sponsors[0].length > 0">
<template #label>Our lovely Sponsors</template>
<div :class="$style.contributors">
<span