Moderator system

Closes #2357
This commit is contained in:
syuilo
2018-11-15 04:15:42 +09:00
parent dc9a19b9c7
commit 56d571c0f0
23 changed files with 191 additions and 17 deletions

View File

@ -8,7 +8,7 @@ export const meta = {
},
requireCredential: true,
requireAdmin: true,
requireModerator: true,
params: {
name: {

View File

@ -8,7 +8,7 @@ export const meta = {
},
requireCredential: true,
requireAdmin: true,
requireModerator: true,
params: {
host: {

View File

@ -9,7 +9,7 @@ export const meta = {
},
requireCredential: true,
requireAdmin: true,
requireModerator: true,
params: {
id: {

View File

@ -9,7 +9,7 @@ export const meta = {
},
requireCredential: true,
requireAdmin: true,
requireModerator: true,
params: {
id: {

View File

@ -8,7 +8,7 @@ export const meta = {
},
requireCredential: true,
requireAdmin: true,
requireModerator: true,
params: {}
};

View File

@ -0,0 +1,45 @@
import $ from 'cafy';
import ID, { transform } from '../../../../../misc/cafy-id';
import define from '../../../define';
import User from '../../../../../models/user';
export const meta = {
desc: {
'ja-JP': '指定したユーザーをモデレーターにします。',
'en-US': 'Mark a user as moderator.'
},
requireCredential: true,
requireAdmin: true,
params: {
userId: {
validator: $.type(ID),
transform: transform,
desc: {
'ja-JP': '対象のユーザーID',
'en-US': 'The user ID'
}
},
}
};
export default define(meta, (ps) => new Promise(async (res, rej) => {
const user = await User.findOne({
_id: ps.userId
});
if (user == null) {
return rej('user not found');
}
await User.update({
_id: user._id
}, {
$set: {
isModerator: true
}
});
res();
}));

View File

@ -0,0 +1,45 @@
import $ from 'cafy';
import ID, { transform } from '../../../../../misc/cafy-id';
import define from '../../../define';
import User from '../../../../../models/user';
export const meta = {
desc: {
'ja-JP': '指定したユーザーをモデレーター解除します。',
'en-US': 'Unmark a user as moderator.'
},
requireCredential: true,
requireAdmin: true,
params: {
userId: {
validator: $.type(ID),
transform: transform,
desc: {
'ja-JP': '対象のユーザーID',
'en-US': 'The user ID'
}
},
}
};
export default define(meta, (ps) => new Promise(async (res, rej) => {
const user = await User.findOne({
_id: ps.userId
});
if (user == null) {
return rej('user not found');
}
await User.update({
_id: user._id
}, {
$set: {
isModerator: false
}
});
res();
}));

View File

@ -10,7 +10,7 @@ export const meta = {
},
requireCredential: true,
requireAdmin: true,
requireModerator: true,
params: {
userId: {

View File

@ -10,7 +10,7 @@ export const meta = {
},
requireCredential: true,
requireAdmin: true,
requireModerator: true,
params: {
userId: {

View File

@ -10,7 +10,7 @@ export const meta = {
},
requireCredential: true,
requireAdmin: true,
requireModerator: true,
params: {
userId: {

View File

@ -8,7 +8,7 @@ export const meta = {
},
requireCredential: true,
requireAdmin: true,
requireModerator: true,
params: {
broadcasts: {

View File

@ -10,7 +10,7 @@ export const meta = {
},
requireCredential: true,
requireAdmin: true,
requireModerator: true,
params: {
userId: {

View File

@ -84,7 +84,7 @@ export default define(meta, (ps, me) => new Promise(async (res, rej) => {
};
}
if (me && me.isAdmin) {
if (me && (me.isAdmin || me.isModerator)) {
response.hidedTags = instance.hidedTags;
response.recaptchaSecretKey = instance.recaptchaSecretKey;
response.proxyAccount = instance.proxyAccount;

View File

@ -38,7 +38,7 @@ export default define(meta, (ps, user) => new Promise(async (res, rej) => {
return rej('note not found');
}
if (!user.isAdmin && !note.userId.equals(user._id)) {
if (!user.isAdmin && !user.isModerator && !note.userId.equals(user._id)) {
return rej('access denied');
}