From 4db972318fe1ed3b0a9ca25ac51baa15b63e6ee3 Mon Sep 17 00:00:00 2001 From: MeiMei <30769358+mei23@users.noreply.github.com> Date: Fri, 12 Apr 2019 20:54:50 +0900 Subject: [PATCH] =?UTF-8?q?=E3=82=A4=E3=83=B3=E3=82=B9=E3=82=BF=E3=83=B3?= =?UTF-8?q?=E3=82=B9=E3=83=96=E3=83=AD=E3=83=83=E3=82=AF=E3=83=81=E3=82=A7?= =?UTF-8?q?=E3=83=83=E3=82=AF=E6=99=82=E3=81=AEhost=E3=81=AEnormalize?= =?UTF-8?q?=E3=82=92=E7=B5=B1=E4=B8=80=20(#4669)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/queue/processors/inbox.ts | 5 +++-- src/remote/activitypub/request.ts | 4 ++-- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/src/queue/processors/inbox.ts b/src/queue/processors/inbox.ts index 1ef31ea64..6447d318e 100644 --- a/src/queue/processors/inbox.ts +++ b/src/queue/processors/inbox.ts @@ -12,6 +12,7 @@ import { registerOrFetchInstanceDoc } from '../../services/register-or-fetch-ins import Instance from '../../models/instance'; import instanceChart from '../../services/chart/instance'; import { validActor } from '../../remote/activitypub/type'; +import { toDbHost } from '../../misc/convert-host'; const logger = new Logger('inbox'); @@ -47,7 +48,7 @@ export default async (job: Bull.Job): Promise => { // ブロックしてたら中断 // TODO: いちいちデータベースにアクセスするのはコスト高そうなのでどっかにキャッシュしておく - const instance = await Instance.findOne({ host: host.toLowerCase() }); + const instance = await Instance.findOne({ host: toDbHost(host) }); if (instance && instance.isBlocked) { logger.info(`Blocked request: ${host}`); return; @@ -66,7 +67,7 @@ export default async (job: Bull.Job): Promise => { // ブロックしてたら中断 // TODO: いちいちデータベースにアクセスするのはコスト高そうなのでどっかにキャッシュしておく - const instance = await Instance.findOne({ host: host.toLowerCase() }); + const instance = await Instance.findOne({ host: toDbHost(host) }); if (instance && instance.isBlocked) { logger.warn(`Blocked request: ${host}`); return; diff --git a/src/remote/activitypub/request.ts b/src/remote/activitypub/request.ts index 08dd7a6ba..7fd05f776 100644 --- a/src/remote/activitypub/request.ts +++ b/src/remote/activitypub/request.ts @@ -4,13 +4,13 @@ import { URL } from 'url'; import * as crypto from 'crypto'; import { lookup, IRunOptions } from 'lookup-dns-cache'; import * as promiseAny from 'promise-any'; -import { toUnicode } from 'punycode'; import config from '../../config'; import { ILocalUser } from '../../models/user'; import { publishApLogStream } from '../../services/stream'; import { apLogger } from './logger'; import Instance from '../../models/instance'; +import { toDbHost } from '../../misc/convert-host'; export const logger = apLogger.createSubLogger('deliver'); @@ -23,7 +23,7 @@ export default async (user: ILocalUser, url: string, object: any) => { // ブロックしてたら中断 // TODO: いちいちデータベースにアクセスするのはコスト高そうなのでどっかにキャッシュしておく - const instance = await Instance.findOne({ host: toUnicode(host) }); + const instance = await Instance.findOne({ host: toDbHost(host) }); if (instance && instance.isBlocked) return; const data = JSON.stringify(object);