summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/fetch-rss.ts
diff options
context:
space:
mode:
authortamaina <tamaina@hotmail.co.jp>2022-11-17 23:35:55 +0900
committertamaina <tamaina@hotmail.co.jp>2022-11-17 23:35:55 +0900
commit764da890b6ad3d53808ec592099a93d9d39d7b08 (patch)
treeb3e9b08bfafa2bbbb5f657af3adb60bcc9510b67 /packages/backend/src/server/api/endpoints/fetch-rss.ts
parentfix (diff)
parentMerge branch 'develop' of https://github.com/misskey-dev/misskey into develop (diff)
downloadmisskey-764da890b6ad3d53808ec592099a93d9d39d7b08.tar.gz
misskey-764da890b6ad3d53808ec592099a93d9d39d7b08.tar.bz2
misskey-764da890b6ad3d53808ec592099a93d9d39d7b08.zip
Merge branch 'develop' into pizzax-indexeddb
Diffstat (limited to 'packages/backend/src/server/api/endpoints/fetch-rss.ts')
-rw-r--r--packages/backend/src/server/api/endpoints/fetch-rss.ts51
1 files changed, 51 insertions, 0 deletions
diff --git a/packages/backend/src/server/api/endpoints/fetch-rss.ts b/packages/backend/src/server/api/endpoints/fetch-rss.ts
new file mode 100644
index 0000000000..58fa01ac48
--- /dev/null
+++ b/packages/backend/src/server/api/endpoints/fetch-rss.ts
@@ -0,0 +1,51 @@
+import Parser from 'rss-parser';
+import { Inject, Injectable } from '@nestjs/common';
+import { Endpoint } from '@/server/api/endpoint-base.js';
+import type { Config } from '@/config.js';
+import { DI } from '@/di-symbols.js';
+import { HttpRequestService } from '@/core/HttpRequestService.js';
+
+const rssParser = new Parser();
+
+export const meta = {
+ tags: ['meta'],
+
+ requireCredential: false,
+ allowGet: true,
+ cacheSec: 60 * 3,
+} as const;
+
+export const paramDef = {
+ type: 'object',
+ properties: {
+ url: { type: 'string' },
+ },
+ required: ['url'],
+} as const;
+
+// eslint-disable-next-line import/no-default-export
+@Injectable()
+export default class extends Endpoint<typeof meta, typeof paramDef> {
+ constructor(
+ @Inject(DI.config)
+ private config: Config,
+
+ private httpRequestService: HttpRequestService,
+ ) {
+ super(meta, paramDef, async (ps, me) => {
+ const res = await this.httpRequestService.getResponse({
+ url: ps.url,
+ method: 'GET',
+ headers: Object.assign({
+ 'User-Agent': config.userAgent,
+ Accept: 'application/rss+xml, */*',
+ }),
+ timeout: 5000,
+ });
+
+ const text = await res.text();
+
+ return rssParser.parseString(text);
+ });
+ }
+}