52774bbe64
* wip * wip * wip * Update index.ts * Update gen-openapi-spec.ts * Update api.ja-JP.md * Fix * Improve doc * Update gen-openapi-spec.ts * Update redoc.html * Improve doc * Update gen-openapi-spec.ts * Improve doc * Update CHANGELOG.md
93 lines
2 KiB
TypeScript
93 lines
2 KiB
TypeScript
import $ from 'cafy';
|
|
import ID, { transform } from '../../../../misc/cafy-id';
|
|
import * as ms from 'ms';
|
|
import { pack } from '../../../../models/user';
|
|
import Blocking from '../../../../models/blocking';
|
|
import deleteBlocking from '../../../../services/blocking/delete';
|
|
import define from '../../define';
|
|
import { ApiError } from '../../error';
|
|
import { getUser } from '../../common/getters';
|
|
|
|
export const meta = {
|
|
stability: 'stable',
|
|
|
|
desc: {
|
|
'ja-JP': '指定したユーザーのブロックを解除します。',
|
|
'en-US': 'Unblock a user.'
|
|
},
|
|
|
|
tags: ['blocking', 'users'],
|
|
|
|
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: '8621d8bf-c358-4303-a066-5ea78610eb3f'
|
|
},
|
|
|
|
blockeeIsYourself: {
|
|
message: 'Blockee is yourself.',
|
|
code: 'BLOCKEE_IS_YOURSELF',
|
|
id: '06f6fac6-524b-473c-a354-e97a40ae6eac'
|
|
},
|
|
|
|
notBlocking: {
|
|
message: 'You are not blocking that user.',
|
|
code: 'NOT_BLOCKING',
|
|
id: '291b2efa-60c6-45c0-9f6a-045c8f9b02cd'
|
|
},
|
|
}
|
|
};
|
|
|
|
export default define(meta, async (ps, user) => {
|
|
const blocker = user;
|
|
|
|
// Check if the blockee is yourself
|
|
if (user._id.equals(ps.userId)) {
|
|
throw new ApiError(meta.errors.blockeeIsYourself);
|
|
}
|
|
|
|
// Get blockee
|
|
const blockee = await getUser(ps.userId).catch(e => {
|
|
if (e.id === '15348ddd-432d-49c2-8a5a-8069753becff') throw new ApiError(meta.errors.noSuchUser);
|
|
throw e;
|
|
});
|
|
|
|
// Check not blocking
|
|
const exist = await Blocking.findOne({
|
|
blockerId: blocker._id,
|
|
blockeeId: blockee._id
|
|
});
|
|
|
|
if (exist === null) {
|
|
throw new ApiError(meta.errors.notBlocking);
|
|
}
|
|
|
|
// Delete blocking
|
|
await deleteBlocking(blocker, blockee);
|
|
|
|
return await pack(blockee._id, user, {
|
|
detail: true
|
|
});
|
|
});
|