2019-02-05 03:48:08 +01:00
|
|
|
import $ from 'cafy';
|
2019-04-07 16:06:07 +02:00
|
|
|
import { resolveUser } from '../../../../remote/resolve-user';
|
2018-11-02 05:47:44 +01:00
|
|
|
import define from '../../define';
|
2019-02-03 10:16:57 +01:00
|
|
|
import { apiLogger } from '../../logger';
|
2019-02-22 03:46:58 +01:00
|
|
|
import { ApiError } from '../../error';
|
2021-03-23 09:43:07 +01:00
|
|
|
import { ID } from '@/misc/cafy-id';
|
2019-04-07 14:50:36 +02:00
|
|
|
import { Users } from '../../../../models';
|
|
|
|
import { In } from 'typeorm';
|
2021-03-24 03:05:37 +01:00
|
|
|
import { User } from '@/models/entities/user';
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2018-11-01 19:32:24 +01:00
|
|
|
export const meta = {
|
|
|
|
desc: {
|
|
|
|
'ja-JP': '指定したユーザーの情報を取得します。'
|
|
|
|
},
|
|
|
|
|
2019-02-23 03:20:58 +01:00
|
|
|
tags: ['users'],
|
|
|
|
|
2020-02-15 13:33:32 +01:00
|
|
|
requireCredential: false as const,
|
2018-03-27 09:51:12 +02:00
|
|
|
|
2018-11-01 19:32:24 +01:00
|
|
|
params: {
|
|
|
|
userId: {
|
2019-02-13 08:33:07 +01:00
|
|
|
validator: $.optional.type(ID),
|
2018-11-01 19:32:24 +01:00
|
|
|
desc: {
|
2018-11-03 14:49:36 +01:00
|
|
|
'ja-JP': '対象のユーザーのID',
|
|
|
|
'en-US': 'Target user ID'
|
2018-11-01 19:32:24 +01:00
|
|
|
}
|
|
|
|
},
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2018-11-01 19:32:24 +01:00
|
|
|
userIds: {
|
2019-02-13 08:33:07 +01:00
|
|
|
validator: $.optional.arr($.type(ID)).unique(),
|
2018-11-01 19:32:24 +01:00
|
|
|
desc: {
|
|
|
|
'ja-JP': 'ユーザーID (配列)'
|
|
|
|
}
|
|
|
|
},
|
2018-04-25 15:37:08 +02:00
|
|
|
|
2018-11-01 19:32:24 +01:00
|
|
|
username: {
|
2019-02-13 08:33:07 +01:00
|
|
|
validator: $.optional.str
|
2018-11-01 19:32:24 +01:00
|
|
|
},
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2018-11-01 19:32:24 +01:00
|
|
|
host: {
|
2019-02-13 08:33:07 +01:00
|
|
|
validator: $.optional.nullable.str
|
2018-11-01 19:32:24 +01:00
|
|
|
}
|
2019-02-22 03:46:58 +01:00
|
|
|
},
|
|
|
|
|
2019-02-23 03:20:58 +01:00
|
|
|
res: {
|
2019-06-27 11:04:09 +02:00
|
|
|
type: 'object' as const,
|
|
|
|
optional: false as const, nullable: false as const,
|
2019-04-23 15:35:26 +02:00
|
|
|
ref: 'User',
|
2019-02-23 03:20:58 +01:00
|
|
|
},
|
|
|
|
|
2019-02-22 03:46:58 +01:00
|
|
|
errors: {
|
|
|
|
failedToResolveRemoteUser: {
|
|
|
|
message: 'Failed to resolve remote user.',
|
|
|
|
code: 'FAILED_TO_RESOLVE_REMOTE_USER',
|
|
|
|
id: 'ef7b9be4-9cba-4e6f-ab41-90ed171c7d3c',
|
2019-06-28 09:38:48 +02:00
|
|
|
kind: 'server' as const
|
2019-02-22 03:46:58 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
noSuchUser: {
|
|
|
|
message: 'No such user.',
|
|
|
|
code: 'NO_SUCH_USER',
|
|
|
|
id: '4362f8dc-731f-4ad8-a694-be5a88922a24'
|
|
|
|
},
|
2018-11-01 19:32:24 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2019-02-22 03:46:58 +01:00
|
|
|
export default define(meta, async (ps, me) => {
|
2018-11-01 19:32:24 +01:00
|
|
|
let user;
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2020-01-01 18:47:20 +01:00
|
|
|
const isAdminOrModerator = me && (me.isAdmin || me.isModerator);
|
|
|
|
|
2018-11-01 19:32:24 +01:00
|
|
|
if (ps.userIds) {
|
2019-04-15 05:54:42 +02:00
|
|
|
if (ps.userIds.length === 0) {
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
|
2020-01-01 18:47:20 +01:00
|
|
|
const users = await Users.find(isAdminOrModerator ? {
|
2019-04-07 14:50:36 +02:00
|
|
|
id: In(ps.userIds)
|
2020-01-01 18:47:20 +01:00
|
|
|
} : {
|
|
|
|
id: In(ps.userIds),
|
|
|
|
isSuspended: false
|
2018-04-25 15:37:08 +02:00
|
|
|
});
|
2017-02-22 05:08:33 +01:00
|
|
|
|
2020-11-08 04:40:31 +01:00
|
|
|
// リクエストされた通りに並べ替え
|
2021-03-24 03:05:37 +01:00
|
|
|
const _users: User[] = [];
|
2020-11-08 04:40:31 +01:00
|
|
|
for (const id of ps.userIds) {
|
2021-03-24 03:05:37 +01:00
|
|
|
_users.push(users.find(x => x.id === id)!);
|
2020-11-08 04:40:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return await Promise.all(_users.map(u => Users.pack(u, me, {
|
2018-04-25 15:37:08 +02:00
|
|
|
detail: true
|
2019-02-22 03:46:58 +01:00
|
|
|
})));
|
2018-03-27 09:51:12 +02:00
|
|
|
} else {
|
2018-04-25 15:37:08 +02:00
|
|
|
// Lookup user
|
2019-04-12 18:43:22 +02:00
|
|
|
if (typeof ps.host === 'string' && typeof ps.username === 'string') {
|
2019-04-07 16:06:07 +02:00
|
|
|
user = await resolveUser(ps.username, ps.host).catch(e => {
|
2019-02-03 10:16:57 +01:00
|
|
|
apiLogger.warn(`failed to resolve remote user: ${e}`);
|
2019-02-22 03:46:58 +01:00
|
|
|
throw new ApiError(meta.errors.failedToResolveRemoteUser);
|
|
|
|
});
|
2018-04-25 15:37:08 +02:00
|
|
|
} else {
|
2018-11-01 19:32:24 +01:00
|
|
|
const q: any = ps.userId != null
|
2019-04-07 14:50:36 +02:00
|
|
|
? { id: ps.userId }
|
2019-04-12 18:43:22 +02:00
|
|
|
: { usernameLower: ps.username!.toLowerCase(), host: null };
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2019-04-07 14:50:36 +02:00
|
|
|
user = await Users.findOne(q);
|
2019-02-15 15:43:49 +01:00
|
|
|
}
|
2018-03-27 09:51:12 +02:00
|
|
|
|
2020-01-01 18:47:20 +01:00
|
|
|
if (user == null || (!isAdminOrModerator && user.isSuspended)) {
|
2019-02-22 03:46:58 +01:00
|
|
|
throw new ApiError(meta.errors.noSuchUser);
|
2018-03-27 09:51:12 +02:00
|
|
|
}
|
2016-12-28 23:49:51 +01:00
|
|
|
|
2019-04-07 14:50:36 +02:00
|
|
|
return await Users.pack(user, me, {
|
2019-02-22 03:46:58 +01:00
|
|
|
detail: true
|
|
|
|
});
|
2018-04-25 15:37:08 +02:00
|
|
|
}
|
2019-02-22 03:46:58 +01:00
|
|
|
});
|