summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/FileServerService.ts
diff options
context:
space:
mode:
authorJulia <julia@insertdomain.name>2024-11-21 00:23:26 +0000
committerJulia <julia@insertdomain.name>2024-11-21 00:23:26 +0000
commit2234fbcb116d20b5f26b60e091221c70d24b67af (patch)
tree40d4b26a4c6f83a612673ec47dca7cd70e01b358 /packages/backend/src/server/FileServerService.ts
parentmerge: Coordinated Security Release (!761) (diff)
parentBump version (diff)
downloadsharkey-2234fbcb116d20b5f26b60e091221c70d24b67af.tar.gz
sharkey-2234fbcb116d20b5f26b60e091221c70d24b67af.tar.bz2
sharkey-2234fbcb116d20b5f26b60e091221c70d24b67af.zip
merge: Bump version (!762)
View MR for information: https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/762
Diffstat (limited to 'packages/backend/src/server/FileServerService.ts')
-rw-r--r--packages/backend/src/server/FileServerService.ts89
1 files changed, 0 insertions, 89 deletions
diff --git a/packages/backend/src/server/FileServerService.ts b/packages/backend/src/server/FileServerService.ts
index be196373c4..1a4d0cb48f 100644
--- a/packages/backend/src/server/FileServerService.ts
+++ b/packages/backend/src/server/FileServerService.ts
@@ -28,11 +28,7 @@ import { bindThis } from '@/decorators.js';
import { isMimeImage } from '@/misc/is-mime-image.js';
import { correctFilename } from '@/misc/correct-filename.js';
import { handleRequestRedirectToOmitSearch } from '@/misc/fastify-hook-handlers.js';
-import { RateLimiterService } from '@/server/api/RateLimiterService.js';
-import { getIpHash } from '@/misc/get-ip-hash.js';
-import { AuthenticateService } from '@/server/api/AuthenticateService.js';
import type { FastifyInstance, FastifyRequest, FastifyReply, FastifyPluginOptions } from 'fastify';
-import type Limiter from 'ratelimiter';
const _filename = fileURLToPath(import.meta.url);
const _dirname = dirname(_filename);
@@ -56,8 +52,6 @@ export class FileServerService {
private videoProcessingService: VideoProcessingService,
private internalStorageService: InternalStorageService,
private loggerService: LoggerService,
- private authenticateService: AuthenticateService,
- private rateLimiterService: RateLimiterService,
) {
this.logger = this.loggerService.getLogger('server', 'gray');
@@ -82,8 +76,6 @@ export class FileServerService {
});
fastify.get<{ Params: { key: string; } }>('/files/:key', async (request, reply) => {
- if (!await this.checkRateLimit(request, reply, `/files/${request.params.key}`)) return;
-
return await this.sendDriveFile(request, reply)
.catch(err => this.errorHandler(request, reply, err));
});
@@ -97,20 +89,6 @@ export class FileServerService {
Params: { url: string; };
Querystring: { url?: string; };
}>('/proxy/:url*', async (request, reply) => {
- const url = 'url' in request.query ? request.query.url : 'https://' + request.params.url;
- if (!url || !URL.canParse(url)) {
- reply.code(400);
- return;
- }
-
- const keyUrl = new URL(url);
- keyUrl.searchParams.forEach(k => keyUrl.searchParams.delete(k));
- keyUrl.hash = '';
- keyUrl.username = '';
- keyUrl.password = '';
-
- if (!await this.checkRateLimit(request, reply, `/proxy/${keyUrl}`)) return;
-
return await this.proxyHandler(request, reply)
.catch(err => this.errorHandler(request, reply, err));
});
@@ -594,71 +572,4 @@ export class FileServerService {
path,
};
}
-
- // Based on ApiCallService
- private async checkRateLimit(
- request: FastifyRequest<{
- Body?: Record<string, unknown> | undefined,
- Querystring?: Record<string, unknown> | undefined,
- Params?: Record<string, unknown> | unknown,
- }>,
- reply: FastifyReply,
- rateLimitKey: string,
- ): Promise<boolean> {
- const body = request.method === 'GET'
- ? request.query
- : request.body;
-
- // https://datatracker.ietf.org/doc/html/rfc6750.html#section-2.1 (case sensitive)
- const token = request.headers.authorization?.startsWith('Bearer ')
- ? request.headers.authorization.slice(7)
- : body?.['i'];
- if (token != null && typeof token !== 'string') {
- reply.code(400);
- return false;
- }
-
- // koa will automatically load the `X-Forwarded-For` header if `proxy: true` is configured in the app.
- const [user] = await this.authenticateService.authenticate(token);
- const actor = user?.id ?? getIpHash(request.ip);
-
- const limit = {
- // Group by resource
- key: rateLimitKey,
-
- // Maximum of 10 requests / 10 minutes
- max: 10,
- duration: 1000 * 60 * 10,
-
- // Minimum of 250 ms between each request
- minInterval: 250,
- };
-
- // Rate limit proxy requests
- try {
- await this.rateLimiterService.limit(limit, actor);
- return true;
- } catch (err) {
- // errはLimiter.LimiterInfoであることが期待される
- reply.code(429);
-
- if (hasRateLimitInfo(err)) {
- const cooldownInSeconds = Math.ceil((err.info.resetMs - Date.now()) / 1000);
- // もしかするとマイナスになる可能性がなくはないのでマイナスだったら0にしておく
- reply.header('Retry-After', Math.max(cooldownInSeconds, 0).toString(10));
- }
-
- reply.send({
- message: 'Rate limit exceeded. Please try again later.',
- code: 'RATE_LIMIT_EXCEEDED',
- id: 'd5826d14-3982-4d2e-8011-b9e9f02499ef',
- });
-
- return false;
- }
- }
-}
-
-function hasRateLimitInfo(err: unknown): err is { info: Limiter.LimiterInfo } {
- return err != null && typeof(err) === 'object' && 'info' in err;
}