2756f553c6
* wip
* wip
* wip
* Update attached_notes.ts
* wip
* Refactor
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* Update call.ts
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* ✌️
* Fix
97 lines
1.9 KiB
TypeScript
97 lines
1.9 KiB
TypeScript
import $ from 'cafy';
|
|
import ID, { transform } from '../../../../misc/cafy-id';
|
|
import * as ms from 'ms';
|
|
import User, { pack } from '../../../../models/user';
|
|
import Blocking from '../../../../models/blocking';
|
|
import create from '../../../../services/blocking/create';
|
|
import define from '../../define';
|
|
import { ApiError } from '../../error';
|
|
|
|
export const meta = {
|
|
stability: 'stable',
|
|
|
|
desc: {
|
|
'ja-JP': '指定したユーザーをブロックします。',
|
|
'en-US': 'Block a user.'
|
|
},
|
|
|
|
limit: {
|
|
duration: ms('1hour'),
|
|
max: 100
|
|
},
|
|
|
|
requireCredential: true,
|
|
|
|
kind: 'following-write',
|
|
|
|
params: {
|
|
userId: {
|
|
validator: $.type(ID),
|
|
transform: transform,
|
|
desc: {
|
|
'ja-JP': '対象のユーザーのID',
|
|
'en-US': 'Target user ID'
|
|
}
|
|
}
|
|
},
|
|
|
|
errors: {
|
|
noSuchUser: {
|
|
message: 'No such user.',
|
|
code: 'NO_SUCH_USER',
|
|
id: '7cc4f851-e2f1-4621-9633-ec9e1d00c01e'
|
|
},
|
|
|
|
blockeeIsYourself: {
|
|
message: 'Blockee is yourself.',
|
|
code: 'BLOCKEE_IS_YOURSELF',
|
|
id: '88b19138-f28d-42c0-8499-6a31bbd0fdc6'
|
|
},
|
|
|
|
alreadyBlocking: {
|
|
message: 'You are already blocking that user.',
|
|
code: 'ALREADY_BLOCKING',
|
|
id: '787fed64-acb9-464a-82eb-afbd745b9614'
|
|
},
|
|
}
|
|
};
|
|
|
|
export default define(meta, async (ps, user) => {
|
|
const blocker = user;
|
|
|
|
// 自分自身
|
|
if (user._id.equals(ps.userId)) {
|
|
throw new ApiError(meta.errors.blockeeIsYourself);
|
|
}
|
|
|
|
// Get blockee
|
|
const blockee = await User.findOne({
|
|
_id: ps.userId
|
|
}, {
|
|
fields: {
|
|
data: false,
|
|
profile: false
|
|
}
|
|
});
|
|
|
|
if (blockee === null) {
|
|
throw new ApiError(meta.errors.noSuchUser);
|
|
}
|
|
|
|
// Check if already blocking
|
|
const exist = await Blocking.findOne({
|
|
blockerId: blocker._id,
|
|
blockeeId: blockee._id
|
|
});
|
|
|
|
if (exist !== null) {
|
|
throw new ApiError(meta.errors.alreadyBlocking);
|
|
}
|
|
|
|
// Create blocking
|
|
await create(blocker, blockee);
|
|
|
|
return await pack(blockee._id, user, {
|
|
detail: true
|
|
});
|
|
});
|