fix(backend/URLPreviewService): エラーでHTTP 422を出すように (#10339)
* fix(backend/URLPreviewService): エラーでHTTP 402を出すように * fix import
This commit is contained in:
parent
2e051c5871
commit
e542a030e4
|
@ -1,7 +1,6 @@
|
||||||
import { Inject, Injectable } from '@nestjs/common';
|
import { Inject, Injectable } from '@nestjs/common';
|
||||||
import { summaly } from 'summaly';
|
import { summaly } from 'summaly';
|
||||||
import { DI } from '@/di-symbols.js';
|
import { DI } from '@/di-symbols.js';
|
||||||
import type { UsersRepository } from '@/models/index.js';
|
|
||||||
import type { Config } from '@/config.js';
|
import type { Config } from '@/config.js';
|
||||||
import { MetaService } from '@/core/MetaService.js';
|
import { MetaService } from '@/core/MetaService.js';
|
||||||
import { HttpRequestService } from '@/core/HttpRequestService.js';
|
import { HttpRequestService } from '@/core/HttpRequestService.js';
|
||||||
|
@ -9,6 +8,7 @@ import type Logger from '@/logger.js';
|
||||||
import { query } from '@/misc/prelude/url.js';
|
import { query } from '@/misc/prelude/url.js';
|
||||||
import { LoggerService } from '@/core/LoggerService.js';
|
import { LoggerService } from '@/core/LoggerService.js';
|
||||||
import { bindThis } from '@/decorators.js';
|
import { bindThis } from '@/decorators.js';
|
||||||
|
import { ApiError } from '@/server/api/error.js';
|
||||||
import type { FastifyRequest, FastifyReply } from 'fastify';
|
import type { FastifyRequest, FastifyReply } from 'fastify';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
|
@ -40,9 +40,9 @@ export class UrlPreviewService {
|
||||||
|
|
||||||
@bindThis
|
@bindThis
|
||||||
public async handle(
|
public async handle(
|
||||||
request: FastifyRequest<{ Querystring: { url: string; lang: string; } }>,
|
request: FastifyRequest<{ Querystring: { url: string; lang?: string; } }>,
|
||||||
reply: FastifyReply,
|
reply: FastifyReply,
|
||||||
) {
|
): Promise<object | undefined> {
|
||||||
const url = request.query.url;
|
const url = request.query.url;
|
||||||
if (typeof url !== 'string') {
|
if (typeof url !== 'string') {
|
||||||
reply.code(400);
|
reply.code(400);
|
||||||
|
@ -78,7 +78,7 @@ export class UrlPreviewService {
|
||||||
|
|
||||||
this.logger.succ(`Got preview of ${url}: ${summary.title}`);
|
this.logger.succ(`Got preview of ${url}: ${summary.title}`);
|
||||||
|
|
||||||
if (summary.url && !(summary.url.startsWith('http://') || summary.url.startsWith('https://'))) {
|
if (!(summary.url.startsWith('http://') || summary.url.startsWith('https://'))) {
|
||||||
throw new Error('unsupported schema included');
|
throw new Error('unsupported schema included');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,9 +95,15 @@ export class UrlPreviewService {
|
||||||
return summary;
|
return summary;
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
this.logger.warn(`Failed to get preview of ${url}: ${err}`);
|
this.logger.warn(`Failed to get preview of ${url}: ${err}`);
|
||||||
reply.code(200);
|
reply.code(422);
|
||||||
reply.header('Cache-Control', 'max-age=86400, immutable');
|
reply.header('Cache-Control', 'max-age=86400, immutable');
|
||||||
return {};
|
return {
|
||||||
|
error: new ApiError({
|
||||||
|
message: 'Failed to get preview',
|
||||||
|
code: 'URL_PREVIEW_FAILED',
|
||||||
|
id: '09d01cb5-53b9-4856-82e5-38a50c290a3b',
|
||||||
|
}),
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -841,4 +841,12 @@ describe('Endpoints', () => {
|
||||||
assert.strictEqual(res.body[0].id, carolPost.id);
|
assert.strictEqual(res.body[0].id, carolPost.id);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('URL preview', () => {
|
||||||
|
test('Error from summaly becomes HTTP 422', async () => {
|
||||||
|
const res = await simpleGet('/url?url=https://e:xample.com');
|
||||||
|
assert.strictEqual(res.status, 422);
|
||||||
|
assert.strictEqual(res.body.error.code, 'URL_PREVIEW_FAILED');
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue