summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api
diff options
context:
space:
mode:
Diffstat (limited to 'packages/backend/src/server/api')
-rw-r--r--packages/backend/src/server/api/EndpointsModule.ts4
-rw-r--r--packages/backend/src/server/api/endpoints.ts2
-rw-r--r--packages/backend/src/server/api/endpoints/sponsors.ts46
3 files changed, 52 insertions, 0 deletions
diff --git a/packages/backend/src/server/api/EndpointsModule.ts b/packages/backend/src/server/api/EndpointsModule.ts
index e5c6c310f6..9aa75b0af8 100644
--- a/packages/backend/src/server/api/EndpointsModule.ts
+++ b/packages/backend/src/server/api/EndpointsModule.ts
@@ -354,6 +354,7 @@ import * as ep___users_achievements from './endpoints/users/achievements.js';
import * as ep___users_updateMemo from './endpoints/users/update-memo.js';
import * as ep___fetchRss from './endpoints/fetch-rss.js';
import * as ep___retention from './endpoints/retention.js';
+import * as ep___sponsors from './endpoints/sponsors.js';
import { GetterService } from './GetterService.js';
import { ApiLoggerService } from './ApiLoggerService.js';
import type { Provider } from '@nestjs/common';
@@ -706,6 +707,7 @@ const $users_achievements: Provider = { provide: 'ep:users/achievements', useCla
const $users_updateMemo: Provider = { provide: 'ep:users/update-memo', useClass: ep___users_updateMemo.default };
const $fetchRss: Provider = { provide: 'ep:fetch-rss', useClass: ep___fetchRss.default };
const $retention: Provider = { provide: 'ep:retention', useClass: ep___retention.default };
+const $sponsors: Provider = { provide: 'ep:sponsors', useClass: ep___sponsors.default };
@Module({
imports: [
@@ -1062,6 +1064,7 @@ const $retention: Provider = { provide: 'ep:retention', useClass: ep___retention
$users_updateMemo,
$fetchRss,
$retention,
+ $sponsors,
],
exports: [
$admin_meta,
@@ -1409,6 +1412,7 @@ const $retention: Provider = { provide: 'ep:retention', useClass: ep___retention
$users_updateMemo,
$fetchRss,
$retention,
+ $sponsors,
],
})
export class EndpointsModule {}
diff --git a/packages/backend/src/server/api/endpoints.ts b/packages/backend/src/server/api/endpoints.ts
index 548367d124..d7f5611f55 100644
--- a/packages/backend/src/server/api/endpoints.ts
+++ b/packages/backend/src/server/api/endpoints.ts
@@ -354,6 +354,7 @@ import * as ep___users_achievements from './endpoints/users/achievements.js';
import * as ep___users_updateMemo from './endpoints/users/update-memo.js';
import * as ep___fetchRss from './endpoints/fetch-rss.js';
import * as ep___retention from './endpoints/retention.js';
+import * as ep___sponsors from './endpoints/sponsors.js';
const eps = [
['admin/meta', ep___admin_meta],
@@ -704,6 +705,7 @@ const eps = [
['users/update-memo', ep___users_updateMemo],
['fetch-rss', ep___fetchRss],
['retention', ep___retention],
+ ['sponsors', ep___sponsors],
];
export interface IEndpointMeta {
diff --git a/packages/backend/src/server/api/endpoints/sponsors.ts b/packages/backend/src/server/api/endpoints/sponsors.ts
new file mode 100644
index 0000000000..6923fdb418
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/sponsors.ts
@@ -0,0 +1,46 @@
+import { Inject, Injectable } from '@nestjs/common';
+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",
+
+ requireCredential: false,
+ requireCredentialPrivateMode: false,
+} as const;
+
+export const paramDef = {
+ type: "object",
+ properties: {
+ forceUpdate: { type: "boolean", default: false },
+ },
+ required: [],
+} as const;
+
+@Injectable()
+export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-disable-line import/no-default-export
+ constructor(
+ @Inject(DI.redis) private redisClient: Redis.Redis,
+ ) {
+ super(meta, paramDef, async (ps, me) => {
+ let sponsors;
+ const cachedSponsors = await this.redisClient.get("sponsors");
+ if (!ps.forceUpdate && cachedSponsors) {
+ sponsors = JSON.parse(cachedSponsors);
+ } else {
+ AbortSignal.timeout ??= function timeout(ms) {
+ const ctrl = new AbortController();
+ setTimeout(() => ctrl.abort(), ms);
+ return ctrl.signal;
+ };
+
+ 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);
+ }
+ return { sponsor_data: sponsors['sponsors'] };
+ })
+ }
+}