summaryrefslogtreecommitdiff
path: root/packages/backend/src/server
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2023-02-04 14:20:07 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2023-02-04 14:20:07 +0900
commit38f9d1e76428bea47c5944c440eab25428c7d99e (patch)
tree1be8cb88a5ee77f2770df402e9023b59ef33e5bf /packages/backend/src/server
parentperf(server): improvement of external mediaProxy (#9787) (diff)
downloadmisskey-38f9d1e76428bea47c5944c440eab25428c7d99e.tar.gz
misskey-38f9d1e76428bea47c5944c440eab25428c7d99e.tar.bz2
misskey-38f9d1e76428bea47c5944c440eab25428c7d99e.zip
fix(client): validate urls to improve security
Diffstat (limited to 'packages/backend/src/server')
-rw-r--r--packages/backend/src/server/web/UrlPreviewService.ts8
1 files changed, 8 insertions, 0 deletions
diff --git a/packages/backend/src/server/web/UrlPreviewService.ts b/packages/backend/src/server/web/UrlPreviewService.ts
index 1bf88fe434..57461b7a33 100644
--- a/packages/backend/src/server/web/UrlPreviewService.ts
+++ b/packages/backend/src/server/web/UrlPreviewService.ts
@@ -73,6 +73,14 @@ export class UrlPreviewService {
});
this.logger.succ(`Got preview of ${url}: ${summary.title}`);
+
+ if (summary.url && !(summary.url.startsWith('http://') || summary.url.startsWith('https://'))) {
+ throw new Error('unsupported schema included');
+ }
+
+ if (summary.player?.url && !(summary.player.url.startsWith('http://') || summary.player.url.startsWith('https://'))) {
+ throw new Error('unsupported schema included');
+ }
summary.icon = this.wrap(summary.icon);
summary.thumbnail = this.wrap(summary.thumbnail);