|
|
@ -80,23 +80,26 @@ module.exports = function (Topics) {
|
|
|
|
data = await plugins.hooks.fire('filter:topic.post', data);
|
|
|
|
data = await plugins.hooks.fire('filter:topic.post', data);
|
|
|
|
const { uid } = data;
|
|
|
|
const { uid } = data;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const [categoryExists, canCreate, canTag, isAdmin] = await Promise.all([
|
|
|
|
|
|
|
|
categories.exists(data.cid),
|
|
|
|
|
|
|
|
privileges.categories.can('topics:create', data.cid, uid),
|
|
|
|
|
|
|
|
privileges.categories.can('topics:tag', data.cid, uid),
|
|
|
|
|
|
|
|
privileges.users.isAdministrator(uid),
|
|
|
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
|
|
data.title = String(data.title).trim();
|
|
|
|
data.title = String(data.title).trim();
|
|
|
|
data.tags = data.tags || [];
|
|
|
|
data.tags = data.tags || [];
|
|
|
|
data.content = String(data.content || '').trimEnd();
|
|
|
|
data.content = String(data.content || '').trimEnd();
|
|
|
|
|
|
|
|
if (!isAdmin) {
|
|
|
|
|
|
|
|
Topics.checkTitle(data.title);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Topics.checkTitle(data.title);
|
|
|
|
|
|
|
|
await Topics.validateTags(data.tags, data.cid, uid);
|
|
|
|
await Topics.validateTags(data.tags, data.cid, uid);
|
|
|
|
data.tags = await Topics.filterTags(data.tags, data.cid);
|
|
|
|
data.tags = await Topics.filterTags(data.tags, data.cid);
|
|
|
|
if (!data.fromQueue) {
|
|
|
|
if (!data.fromQueue && !isAdmin) {
|
|
|
|
Topics.checkContent(data.content);
|
|
|
|
Topics.checkContent(data.content);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const [categoryExists, canCreate, canTag] = await Promise.all([
|
|
|
|
|
|
|
|
categories.exists(data.cid),
|
|
|
|
|
|
|
|
privileges.categories.can('topics:create', data.cid, uid),
|
|
|
|
|
|
|
|
privileges.categories.can('topics:tag', data.cid, uid),
|
|
|
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!categoryExists) {
|
|
|
|
if (!categoryExists) {
|
|
|
|
throw new Error('[[error:no-category]]');
|
|
|
|
throw new Error('[[error:no-category]]');
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -159,7 +162,10 @@ module.exports = function (Topics) {
|
|
|
|
const { tid } = data;
|
|
|
|
const { tid } = data;
|
|
|
|
const { uid } = data;
|
|
|
|
const { uid } = data;
|
|
|
|
|
|
|
|
|
|
|
|
const topicData = await Topics.getTopicData(tid);
|
|
|
|
const [topicData, isAdmin] = await Promise.all([
|
|
|
|
|
|
|
|
Topics.getTopicData(tid),
|
|
|
|
|
|
|
|
privileges.users.isAdministrator(uid),
|
|
|
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
|
|
await canReply(data, topicData);
|
|
|
|
await canReply(data, topicData);
|
|
|
|
|
|
|
|
|
|
|
@ -168,7 +174,7 @@ module.exports = function (Topics) {
|
|
|
|
await guestHandleValid(data);
|
|
|
|
await guestHandleValid(data);
|
|
|
|
data.content = String(data.content || '').trimEnd();
|
|
|
|
data.content = String(data.content || '').trimEnd();
|
|
|
|
|
|
|
|
|
|
|
|
if (!data.fromQueue) {
|
|
|
|
if (!data.fromQueue && !isAdmin) {
|
|
|
|
await user.isReadyToPost(uid, data.cid);
|
|
|
|
await user.isReadyToPost(uid, data.cid);
|
|
|
|
Topics.checkContent(data.content);
|
|
|
|
Topics.checkContent(data.content);
|
|
|
|
}
|
|
|
|
}
|
|
|
|