mirror of
https://git.joinsharkey.org/Sharkey/Sharkey.git
synced 2024-11-23 15:43:09 +02:00
More puny
This commit is contained in:
parent
72a5f7b1e2
commit
236d72685d
14 changed files with 52 additions and 55 deletions
|
@ -3,6 +3,7 @@ import { DriveFile } from '../entities/drive-file';
|
||||||
import { Users, DriveFolders } from '..';
|
import { Users, DriveFolders } from '..';
|
||||||
import rap from '@prezzemolo/rap';
|
import rap from '@prezzemolo/rap';
|
||||||
import { User } from '../entities/user';
|
import { User } from '../entities/user';
|
||||||
|
import { toPuny } from '../../misc/convert-host';
|
||||||
|
|
||||||
@EntityRepository(DriveFile)
|
@EntityRepository(DriveFile)
|
||||||
export class DriveFileRepository extends Repository<DriveFile> {
|
export class DriveFileRepository extends Repository<DriveFile> {
|
||||||
|
@ -39,7 +40,7 @@ export class DriveFileRepository extends Repository<DriveFile> {
|
||||||
public async clacDriveUsageOfHost(host: string): Promise<number> {
|
public async clacDriveUsageOfHost(host: string): Promise<number> {
|
||||||
const { sum } = await this
|
const { sum } = await this
|
||||||
.createQueryBuilder('file')
|
.createQueryBuilder('file')
|
||||||
.where('file.userHost = :host', { host: host })
|
.where('file.userHost = :host', { host: toPuny(host) })
|
||||||
.select('SUM(file.size)', 'sum')
|
.select('SUM(file.size)', 'sum')
|
||||||
.getRawOne();
|
.getRawOne();
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,6 @@ import parseAcct from '../../misc/acct/parse';
|
||||||
import { IRemoteUser } from '../../models/entities/user';
|
import { IRemoteUser } from '../../models/entities/user';
|
||||||
import perform from '../../remote/activitypub/perform';
|
import perform from '../../remote/activitypub/perform';
|
||||||
import { resolvePerson, updatePerson } from '../../remote/activitypub/models/person';
|
import { resolvePerson, updatePerson } from '../../remote/activitypub/models/person';
|
||||||
import { toUnicode } from 'punycode';
|
|
||||||
import { URL } from 'url';
|
import { URL } from 'url';
|
||||||
import { publishApLogStream } from '../../services/stream';
|
import { publishApLogStream } from '../../services/stream';
|
||||||
import Logger from '../../services/logger';
|
import Logger from '../../services/logger';
|
||||||
|
@ -13,6 +12,7 @@ import { Instances, Users, UserPublickeys } from '../../models';
|
||||||
import { instanceChart } from '../../services/chart';
|
import { instanceChart } from '../../services/chart';
|
||||||
import { UserPublickey } from '../../models/entities/user-publickey';
|
import { UserPublickey } from '../../models/entities/user-publickey';
|
||||||
import fetchMeta from '../../misc/fetch-meta';
|
import fetchMeta from '../../misc/fetch-meta';
|
||||||
|
import { toPuny } from '../../misc/convert-host';
|
||||||
|
|
||||||
const logger = new Logger('inbox');
|
const logger = new Logger('inbox');
|
||||||
|
|
||||||
|
@ -33,7 +33,10 @@ export default async (job: Bull.Job): Promise<void> => {
|
||||||
let key: UserPublickey;
|
let key: UserPublickey;
|
||||||
|
|
||||||
if (keyIdLower.startsWith('acct:')) {
|
if (keyIdLower.startsWith('acct:')) {
|
||||||
const { username, host } = parseAcct(keyIdLower.slice('acct:'.length));
|
const acct = parseAcct(keyIdLower.slice('acct:'.length));
|
||||||
|
const host = toPuny(acct.host);
|
||||||
|
const username = toPuny(acct.username);
|
||||||
|
|
||||||
if (host === null) {
|
if (host === null) {
|
||||||
logger.warn(`request was made by local user: @${username}`);
|
logger.warn(`request was made by local user: @${username}`);
|
||||||
return;
|
return;
|
||||||
|
@ -50,19 +53,22 @@ export default async (job: Bull.Job): Promise<void> => {
|
||||||
// ブロックしてたら中断
|
// ブロックしてたら中断
|
||||||
// TODO: いちいちデータベースにアクセスするのはコスト高そうなのでどっかにキャッシュしておく
|
// TODO: いちいちデータベースにアクセスするのはコスト高そうなのでどっかにキャッシュしておく
|
||||||
const meta = await fetchMeta();
|
const meta = await fetchMeta();
|
||||||
if (meta.blockedHosts.includes(host.toLowerCase())) {
|
if (meta.blockedHosts.includes(host)) {
|
||||||
logger.info(`Blocked request: ${host}`);
|
logger.info(`Blocked request: ${host}`);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
user = await Users.findOne({ usernameLower: username, host: host.toLowerCase() }) as IRemoteUser;
|
user = await Users.findOne({
|
||||||
|
usernameLower: username.toLowerCase(),
|
||||||
|
host: host
|
||||||
|
}) as IRemoteUser;
|
||||||
|
|
||||||
key = await UserPublickeys.findOne({
|
key = await UserPublickeys.findOne({
|
||||||
userId: user.id
|
userId: user.id
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
// アクティビティ内のホストの検証
|
// アクティビティ内のホストの検証
|
||||||
const host = toUnicode(new URL(signature.keyId).hostname.toLowerCase());
|
const host = toPuny(new URL(signature.keyId).hostname);
|
||||||
try {
|
try {
|
||||||
ValidateActivity(activity, host);
|
ValidateActivity(activity, host);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
|
@ -73,7 +79,7 @@ export default async (job: Bull.Job): Promise<void> => {
|
||||||
// ブロックしてたら中断
|
// ブロックしてたら中断
|
||||||
// TODO: いちいちデータベースにアクセスするのはコスト高そうなのでどっかにキャッシュしておく
|
// TODO: いちいちデータベースにアクセスするのはコスト高そうなのでどっかにキャッシュしておく
|
||||||
const meta = await fetchMeta();
|
const meta = await fetchMeta();
|
||||||
if (meta.blockedHosts.includes(host.toLowerCase())) {
|
if (meta.blockedHosts.includes(host)) {
|
||||||
logger.info(`Blocked request: ${host}`);
|
logger.info(`Blocked request: ${host}`);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -145,7 +151,7 @@ export default async (job: Bull.Job): Promise<void> => {
|
||||||
function ValidateActivity(activity: any, host: string) {
|
function ValidateActivity(activity: any, host: string) {
|
||||||
// id (if exists)
|
// id (if exists)
|
||||||
if (typeof activity.id === 'string') {
|
if (typeof activity.id === 'string') {
|
||||||
const uriHost = toUnicode(new URL(activity.id).hostname.toLowerCase());
|
const uriHost = toPuny(new URL(activity.id).hostname);
|
||||||
if (host !== uriHost) {
|
if (host !== uriHost) {
|
||||||
const diag = activity.signature ? '. Has LD-Signature. Forwarded?' : '';
|
const diag = activity.signature ? '. Has LD-Signature. Forwarded?' : '';
|
||||||
throw new Error(`activity.id(${activity.id}) has different host(${host})${diag}`);
|
throw new Error(`activity.id(${activity.id}) has different host(${host})${diag}`);
|
||||||
|
@ -154,7 +160,7 @@ function ValidateActivity(activity: any, host: string) {
|
||||||
|
|
||||||
// actor (if exists)
|
// actor (if exists)
|
||||||
if (typeof activity.actor === 'string') {
|
if (typeof activity.actor === 'string') {
|
||||||
const uriHost = toUnicode(new URL(activity.actor).hostname.toLowerCase());
|
const uriHost = toPuny(new URL(activity.actor).hostname);
|
||||||
if (host !== uriHost) throw new Error('activity.actor has different host');
|
if (host !== uriHost) throw new Error('activity.actor has different host');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,13 +168,13 @@ function ValidateActivity(activity: any, host: string) {
|
||||||
if (activity.type === 'Create' && activity.object) {
|
if (activity.type === 'Create' && activity.object) {
|
||||||
// object.id (if exists)
|
// object.id (if exists)
|
||||||
if (typeof activity.object.id === 'string') {
|
if (typeof activity.object.id === 'string') {
|
||||||
const uriHost = toUnicode(new URL(activity.object.id).hostname.toLowerCase());
|
const uriHost = toPuny(new URL(activity.object.id).hostname);
|
||||||
if (host !== uriHost) throw new Error('activity.object.id has different host');
|
if (host !== uriHost) throw new Error('activity.object.id has different host');
|
||||||
}
|
}
|
||||||
|
|
||||||
// object.attributedTo (if exists)
|
// object.attributedTo (if exists)
|
||||||
if (typeof activity.object.attributedTo === 'string') {
|
if (typeof activity.object.attributedTo === 'string') {
|
||||||
const uriHost = toUnicode(new URL(activity.object.attributedTo).hostname.toLowerCase());
|
const uriHost = toPuny(new URL(activity.object.attributedTo).hostname);
|
||||||
if (host !== uriHost) throw new Error('activity.object.attributedTo has different host');
|
if (host !== uriHost) throw new Error('activity.object.attributedTo has different host');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,14 +8,13 @@ import { resolveImage } from './image';
|
||||||
import { IRemoteUser, User } from '../../../models/entities/user';
|
import { IRemoteUser, User } from '../../../models/entities/user';
|
||||||
import { fromHtml } from '../../../mfm/fromHtml';
|
import { fromHtml } from '../../../mfm/fromHtml';
|
||||||
import { ITag, extractHashtags } from './tag';
|
import { ITag, extractHashtags } from './tag';
|
||||||
import { toUnicode } from 'punycode';
|
|
||||||
import { unique, concat, difference } from '../../../prelude/array';
|
import { unique, concat, difference } from '../../../prelude/array';
|
||||||
import { extractPollFromQuestion } from './question';
|
import { extractPollFromQuestion } from './question';
|
||||||
import vote from '../../../services/note/polls/vote';
|
import vote from '../../../services/note/polls/vote';
|
||||||
import { apLogger } from '../logger';
|
import { apLogger } from '../logger';
|
||||||
import { DriveFile } from '../../../models/entities/drive-file';
|
import { DriveFile } from '../../../models/entities/drive-file';
|
||||||
import { deliverQuestionUpdate } from '../../../services/note/polls/update';
|
import { deliverQuestionUpdate } from '../../../services/note/polls/update';
|
||||||
import { extractDbHost } from '../../../misc/convert-host';
|
import { extractDbHost, toPuny } from '../../../misc/convert-host';
|
||||||
import { Notes, Emojis, Polls } from '../../../models';
|
import { Notes, Emojis, Polls } from '../../../models';
|
||||||
import { Note } from '../../../models/entities/note';
|
import { Note } from '../../../models/entities/note';
|
||||||
import { IObject, INote } from '../type';
|
import { IObject, INote } from '../type';
|
||||||
|
@ -246,8 +245,8 @@ export async function resolveNote(value: string | IObject, resolver?: Resolver):
|
||||||
return await createNote(uri, resolver);
|
return await createNote(uri, resolver);
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function extractEmojis(tags: ITag[], host_: string) {
|
export async function extractEmojis(tags: ITag[], host: string) {
|
||||||
const host = toUnicode(host_.toLowerCase());
|
host = toPuny(host);
|
||||||
|
|
||||||
if (!tags) return [];
|
if (!tags) return [];
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import * as promiseLimit from 'promise-limit';
|
import * as promiseLimit from 'promise-limit';
|
||||||
import { toUnicode } from 'punycode';
|
|
||||||
|
|
||||||
import config from '../../../config';
|
import config from '../../../config';
|
||||||
import Resolver from '../resolver';
|
import Resolver from '../resolver';
|
||||||
|
@ -33,7 +32,7 @@ const logger = apLogger;
|
||||||
* @param uri Fetch target URI
|
* @param uri Fetch target URI
|
||||||
*/
|
*/
|
||||||
function validatePerson(x: any, uri: string) {
|
function validatePerson(x: any, uri: string) {
|
||||||
const expectHost = toUnicode(new URL(uri).hostname.toLowerCase());
|
const expectHost = toPuny(new URL(uri).hostname);
|
||||||
|
|
||||||
if (x == null) {
|
if (x == null) {
|
||||||
return new Error('invalid person: object is null');
|
return new Error('invalid person: object is null');
|
||||||
|
@ -63,7 +62,7 @@ function validatePerson(x: any, uri: string) {
|
||||||
return new Error('invalid person: id is not a string');
|
return new Error('invalid person: id is not a string');
|
||||||
}
|
}
|
||||||
|
|
||||||
const idHost = toUnicode(new URL(x.id).hostname.toLowerCase());
|
const idHost = toPuny(new URL(x.id).hostname);
|
||||||
if (idHost !== expectHost) {
|
if (idHost !== expectHost) {
|
||||||
return new Error('invalid person: id has different host');
|
return new Error('invalid person: id has different host');
|
||||||
}
|
}
|
||||||
|
@ -72,7 +71,7 @@ function validatePerson(x: any, uri: string) {
|
||||||
return new Error('invalid person: publicKey.id is not a string');
|
return new Error('invalid person: publicKey.id is not a string');
|
||||||
}
|
}
|
||||||
|
|
||||||
const publicKeyIdHost = toUnicode(new URL(x.publicKey.id).hostname.toLowerCase());
|
const publicKeyIdHost = toPuny(new URL(x.publicKey.id).hostname);
|
||||||
if (publicKeyIdHost !== expectHost) {
|
if (publicKeyIdHost !== expectHost) {
|
||||||
return new Error('invalid person: publicKey.id has different host');
|
return new Error('invalid person: publicKey.id has different host');
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,6 @@ import { URL } from 'url';
|
||||||
import * as crypto from 'crypto';
|
import * as crypto from 'crypto';
|
||||||
import { lookup, IRunOptions } from 'lookup-dns-cache';
|
import { lookup, IRunOptions } from 'lookup-dns-cache';
|
||||||
import * as promiseAny from 'promise-any';
|
import * as promiseAny from 'promise-any';
|
||||||
import { toUnicode } from 'punycode';
|
|
||||||
|
|
||||||
import config from '../../config';
|
import config from '../../config';
|
||||||
import { ILocalUser } from '../../models/entities/user';
|
import { ILocalUser } from '../../models/entities/user';
|
||||||
|
@ -12,6 +11,7 @@ import { publishApLogStream } from '../../services/stream';
|
||||||
import { apLogger } from './logger';
|
import { apLogger } from './logger';
|
||||||
import { UserKeypairs } from '../../models';
|
import { UserKeypairs } from '../../models';
|
||||||
import fetchMeta from '../../misc/fetch-meta';
|
import fetchMeta from '../../misc/fetch-meta';
|
||||||
|
import { toPuny } from '../../misc/convert-host';
|
||||||
|
|
||||||
export const logger = apLogger.createSubLogger('deliver');
|
export const logger = apLogger.createSubLogger('deliver');
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ export default async (user: ILocalUser, url: string, object: any) => {
|
||||||
// ブロックしてたら中断
|
// ブロックしてたら中断
|
||||||
// TODO: いちいちデータベースにアクセスするのはコスト高そうなのでどっかにキャッシュしておく
|
// TODO: いちいちデータベースにアクセスするのはコスト高そうなのでどっかにキャッシュしておく
|
||||||
const meta = await fetchMeta();
|
const meta = await fetchMeta();
|
||||||
if (meta.blockedHosts.includes(toUnicode(host))) return;
|
if (meta.blockedHosts.includes(toPuny(host))) return;
|
||||||
|
|
||||||
const data = JSON.stringify(object);
|
const data = JSON.stringify(object);
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
import { toUnicode, toASCII } from 'punycode';
|
|
||||||
import webFinger from './webfinger';
|
import webFinger from './webfinger';
|
||||||
import config from '../config';
|
import config from '../config';
|
||||||
import { createPerson, updatePerson } from './activitypub/models/person';
|
import { createPerson, updatePerson } from './activitypub/models/person';
|
||||||
|
@ -7,31 +6,27 @@ import { remoteLogger } from './logger';
|
||||||
import chalk from 'chalk';
|
import chalk from 'chalk';
|
||||||
import { User, IRemoteUser } from '../models/entities/user';
|
import { User, IRemoteUser } from '../models/entities/user';
|
||||||
import { Users } from '../models';
|
import { Users } from '../models';
|
||||||
|
import { toPuny } from '../misc/convert-host';
|
||||||
|
|
||||||
const logger = remoteLogger.createSubLogger('resolve-user');
|
const logger = remoteLogger.createSubLogger('resolve-user');
|
||||||
|
|
||||||
export async function resolveUser(username: string, _host: string, option?: any, resync = false): Promise<User> {
|
export async function resolveUser(username: string, host: string, option?: any, resync = false): Promise<User> {
|
||||||
const usernameLower = username.toLowerCase();
|
const usernameLower = username.toLowerCase();
|
||||||
|
host = toPuny(host);
|
||||||
|
|
||||||
if (_host == null) {
|
if (host == null) {
|
||||||
logger.info(`return local user: ${usernameLower}`);
|
logger.info(`return local user: ${usernameLower}`);
|
||||||
return await Users.findOne({ usernameLower, host: null });
|
return await Users.findOne({ usernameLower, host: null });
|
||||||
}
|
}
|
||||||
|
|
||||||
const configHostAscii = toASCII(config.host).toLowerCase();
|
if (config.host == host) {
|
||||||
const configHost = toUnicode(configHostAscii);
|
|
||||||
|
|
||||||
const hostAscii = toASCII(_host).toLowerCase();
|
|
||||||
const host = toUnicode(hostAscii);
|
|
||||||
|
|
||||||
if (configHost == host) {
|
|
||||||
logger.info(`return local user: ${usernameLower}`);
|
logger.info(`return local user: ${usernameLower}`);
|
||||||
return await Users.findOne({ usernameLower, host: null });
|
return await Users.findOne({ usernameLower, host: null });
|
||||||
}
|
}
|
||||||
|
|
||||||
const user = await Users.findOne({ usernameLower, host }, option);
|
const user = await Users.findOne({ usernameLower, host }, option);
|
||||||
|
|
||||||
const acctLower = `${usernameLower}@${hostAscii}`;
|
const acctLower = `${usernameLower}@${host}`;
|
||||||
|
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
const self = await resolveSelf(acctLower);
|
const self = await resolveSelf(acctLower);
|
||||||
|
@ -51,7 +46,7 @@ export async function resolveUser(username: string, _host: string, option?: any,
|
||||||
|
|
||||||
// validate uri
|
// validate uri
|
||||||
const uri = new URL(self.href);
|
const uri = new URL(self.href);
|
||||||
if (uri.hostname !== hostAscii) {
|
if (uri.hostname !== host) {
|
||||||
throw new Error(`Invalied uri`);
|
throw new Error(`Invalied uri`);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
import { toUnicode } from 'punycode';
|
|
||||||
|
|
||||||
export default (host: string) => {
|
|
||||||
if (host == null) return null;
|
|
||||||
return toUnicode(host).toLowerCase();
|
|
||||||
};
|
|
|
@ -1,6 +1,7 @@
|
||||||
import $ from 'cafy';
|
import $ from 'cafy';
|
||||||
import define from '../../../define';
|
import define from '../../../define';
|
||||||
import { Emojis } from '../../../../../models';
|
import { Emojis } from '../../../../../models';
|
||||||
|
import { toPuny } from '../../../../../misc/convert-host';
|
||||||
|
|
||||||
export const meta = {
|
export const meta = {
|
||||||
desc: {
|
desc: {
|
||||||
|
@ -22,7 +23,7 @@ export const meta = {
|
||||||
|
|
||||||
export default define(meta, async (ps) => {
|
export default define(meta, async (ps) => {
|
||||||
const emojis = await Emojis.find({
|
const emojis = await Emojis.find({
|
||||||
host: ps.host
|
host: toPuny(ps.host)
|
||||||
});
|
});
|
||||||
|
|
||||||
return emojis.map(e => ({
|
return emojis.map(e => ({
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import $ from 'cafy';
|
import $ from 'cafy';
|
||||||
import define from '../../../define';
|
import define from '../../../define';
|
||||||
import { Instances } from '../../../../../models';
|
import { Instances } from '../../../../../models';
|
||||||
|
import { toPuny } from '../../../../../misc/convert-host';
|
||||||
|
|
||||||
export const meta = {
|
export const meta = {
|
||||||
tags: ['admin'],
|
tags: ['admin'],
|
||||||
|
@ -20,13 +21,13 @@ export const meta = {
|
||||||
};
|
};
|
||||||
|
|
||||||
export default define(meta, async (ps, me) => {
|
export default define(meta, async (ps, me) => {
|
||||||
const instance = await Instances.findOne({ host: ps.host });
|
const instance = await Instances.findOne({ host: toPuny(ps.host) });
|
||||||
|
|
||||||
if (instance == null) {
|
if (instance == null) {
|
||||||
throw new Error('instance not found');
|
throw new Error('instance not found');
|
||||||
}
|
}
|
||||||
|
|
||||||
Instances.update({ host: ps.host }, {
|
Instances.update({ host: toPuny(ps.host) }, {
|
||||||
isMarkedAsClosed: ps.isClosed
|
isMarkedAsClosed: ps.isClosed
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import $ from 'cafy';
|
import $ from 'cafy';
|
||||||
import define from '../../define';
|
import define from '../../define';
|
||||||
import { Instances } from '../../../../models';
|
import { Instances } from '../../../../models';
|
||||||
|
import { toPuny } from '../../../../misc/convert-host';
|
||||||
|
|
||||||
export const meta = {
|
export const meta = {
|
||||||
tags: ['federation'],
|
tags: ['federation'],
|
||||||
|
@ -16,7 +17,7 @@ export const meta = {
|
||||||
|
|
||||||
export default define(meta, async (ps, me) => {
|
export default define(meta, async (ps, me) => {
|
||||||
const instance = await Instances
|
const instance = await Instances
|
||||||
.findOne({ host: ps.host });
|
.findOne({ host: toPuny(ps.host) });
|
||||||
|
|
||||||
return instance;
|
return instance;
|
||||||
});
|
});
|
||||||
|
|
|
@ -4,6 +4,7 @@ import define from '../../define';
|
||||||
import { ApiError } from '../../error';
|
import { ApiError } from '../../error';
|
||||||
import { Users, Followings } from '../../../../models';
|
import { Users, Followings } from '../../../../models';
|
||||||
import { makePaginationQuery } from '../../common/make-pagination-query';
|
import { makePaginationQuery } from '../../common/make-pagination-query';
|
||||||
|
import { toPuny } from '../../../../misc/convert-host';
|
||||||
|
|
||||||
export const meta = {
|
export const meta = {
|
||||||
desc: {
|
desc: {
|
||||||
|
@ -65,7 +66,7 @@ export const meta = {
|
||||||
export default define(meta, async (ps, me) => {
|
export default define(meta, async (ps, me) => {
|
||||||
const user = await Users.findOne(ps.userId != null
|
const user = await Users.findOne(ps.userId != null
|
||||||
? { id: ps.userId }
|
? { id: ps.userId }
|
||||||
: { usernameLower: ps.username.toLowerCase(), host: ps.host });
|
: { usernameLower: ps.username.toLowerCase(), host: toPuny(ps.host) });
|
||||||
|
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
throw new ApiError(meta.errors.noSuchUser);
|
throw new ApiError(meta.errors.noSuchUser);
|
||||||
|
|
|
@ -4,6 +4,7 @@ import define from '../../define';
|
||||||
import { ApiError } from '../../error';
|
import { ApiError } from '../../error';
|
||||||
import { Users, Followings } from '../../../../models';
|
import { Users, Followings } from '../../../../models';
|
||||||
import { makePaginationQuery } from '../../common/make-pagination-query';
|
import { makePaginationQuery } from '../../common/make-pagination-query';
|
||||||
|
import { toPuny } from '../../../../misc/convert-host';
|
||||||
|
|
||||||
export const meta = {
|
export const meta = {
|
||||||
desc: {
|
desc: {
|
||||||
|
@ -65,7 +66,7 @@ export const meta = {
|
||||||
export default define(meta, async (ps, me) => {
|
export default define(meta, async (ps, me) => {
|
||||||
const user = await Users.findOne(ps.userId != null
|
const user = await Users.findOne(ps.userId != null
|
||||||
? { id: ps.userId }
|
? { id: ps.userId }
|
||||||
: { usernameLower: ps.username.toLowerCase(), host: ps.host });
|
: { usernameLower: ps.username.toLowerCase(), host: toPuny(ps.host) });
|
||||||
|
|
||||||
if (user == null) {
|
if (user == null) {
|
||||||
throw new ApiError(meta.errors.noSuchUser);
|
throw new ApiError(meta.errors.noSuchUser);
|
||||||
|
|
|
@ -15,7 +15,6 @@ import signin from './private/signin';
|
||||||
import discord from './service/discord';
|
import discord from './service/discord';
|
||||||
import github from './service/github';
|
import github from './service/github';
|
||||||
import twitter from './service/twitter';
|
import twitter from './service/twitter';
|
||||||
import { toASCII } from 'punycode';
|
|
||||||
import { Instances } from '../../models';
|
import { Instances } from '../../models';
|
||||||
|
|
||||||
// Init app
|
// Init app
|
||||||
|
@ -71,9 +70,7 @@ router.get('/v1/instance/peers', async ctx => {
|
||||||
select: ['host']
|
select: ['host']
|
||||||
});
|
});
|
||||||
|
|
||||||
const punyCodes = instances.map(instance => toASCII(instance.host));
|
ctx.body = instances.map(instance => instance.host);
|
||||||
|
|
||||||
ctx.body = punyCodes;
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// Return 404 for unknown API
|
// Return 404 for unknown API
|
||||||
|
|
|
@ -5,6 +5,7 @@ import { DriveFiles, Followings, Users, Notes } from '../../../../models';
|
||||||
import { DriveFile } from '../../../../models/entities/drive-file';
|
import { DriveFile } from '../../../../models/entities/drive-file';
|
||||||
import { name, schema } from '../schemas/instance';
|
import { name, schema } from '../schemas/instance';
|
||||||
import { Note } from '../../../../models/entities/note';
|
import { Note } from '../../../../models/entities/note';
|
||||||
|
import { toPuny } from '../../../../misc/convert-host';
|
||||||
|
|
||||||
type InstanceLog = SchemaType<typeof schema>;
|
type InstanceLog = SchemaType<typeof schema>;
|
||||||
|
|
||||||
|
@ -79,7 +80,7 @@ export default class InstanceChart extends Chart<InstanceLog> {
|
||||||
requests: {
|
requests: {
|
||||||
received: 1
|
received: 1
|
||||||
}
|
}
|
||||||
}, host);
|
}, toPuny(host));
|
||||||
}
|
}
|
||||||
|
|
||||||
@autobind
|
@autobind
|
||||||
|
@ -94,7 +95,7 @@ export default class InstanceChart extends Chart<InstanceLog> {
|
||||||
|
|
||||||
await this.inc({
|
await this.inc({
|
||||||
requests: update
|
requests: update
|
||||||
}, host);
|
}, toPuny(host));
|
||||||
}
|
}
|
||||||
|
|
||||||
@autobind
|
@autobind
|
||||||
|
@ -104,7 +105,7 @@ export default class InstanceChart extends Chart<InstanceLog> {
|
||||||
total: 1,
|
total: 1,
|
||||||
inc: 1
|
inc: 1
|
||||||
}
|
}
|
||||||
}, host);
|
}, toPuny(host));
|
||||||
}
|
}
|
||||||
|
|
||||||
@autobind
|
@autobind
|
||||||
|
@ -126,7 +127,7 @@ export default class InstanceChart extends Chart<InstanceLog> {
|
||||||
dec: isAdditional ? 0 : 1,
|
dec: isAdditional ? 0 : 1,
|
||||||
diffs: diffs
|
diffs: diffs
|
||||||
}
|
}
|
||||||
}, host);
|
}, toPuny(host));
|
||||||
}
|
}
|
||||||
|
|
||||||
@autobind
|
@autobind
|
||||||
|
@ -137,7 +138,7 @@ export default class InstanceChart extends Chart<InstanceLog> {
|
||||||
inc: isAdditional ? 1 : 0,
|
inc: isAdditional ? 1 : 0,
|
||||||
dec: isAdditional ? 0 : 1,
|
dec: isAdditional ? 0 : 1,
|
||||||
}
|
}
|
||||||
}, host);
|
}, toPuny(host));
|
||||||
}
|
}
|
||||||
|
|
||||||
@autobind
|
@autobind
|
||||||
|
@ -148,7 +149,7 @@ export default class InstanceChart extends Chart<InstanceLog> {
|
||||||
inc: isAdditional ? 1 : 0,
|
inc: isAdditional ? 1 : 0,
|
||||||
dec: isAdditional ? 0 : 1,
|
dec: isAdditional ? 0 : 1,
|
||||||
}
|
}
|
||||||
}, host);
|
}, toPuny(host));
|
||||||
}
|
}
|
||||||
|
|
||||||
@autobind
|
@autobind
|
||||||
|
|
Loading…
Reference in a new issue