Skip to content

Commit

Permalink
refactor: post edit
Browse files Browse the repository at this point in the history
  • Loading branch information
barisusakli committed Sep 25, 2020
1 parent d0010c4 commit 16039b1
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 32 deletions.
3 changes: 1 addition & 2 deletions src/posts/data.js
Expand Up @@ -51,8 +51,7 @@ module.exports = function (Posts) {

Posts.setPostFields = async function (pid, data) {
await db.setObject('post:' + pid, data);
data.pid = pid;
plugins.fireHook('action:post.setFields', { data: data });
plugins.fireHook('action:post.setFields', { data: { ...data, pid } });
};
};

Expand Down
73 changes: 43 additions & 30 deletions src/posts/edit.js
@@ -1,17 +1,17 @@
'use strict';

var validator = require('validator');
var _ = require('lodash');

var db = require('../database');
var meta = require('../meta');
var topics = require('../topics');
var user = require('../user');
var privileges = require('../privileges');
var plugins = require('../plugins');
var pubsub = require('../pubsub');
var utils = require('../utils');
var translator = require('../translator');
const validator = require('validator');
const _ = require('lodash');

const db = require('../database');
const meta = require('../meta');
const topics = require('../topics');
const user = require('../user');
const privileges = require('../privileges');
const plugins = require('../plugins');
const pubsub = require('../pubsub');
const utils = require('../utils');
const translator = require('../translator');

module.exports = function (Posts) {
pubsub.on('post:edit', function (pid) {
Expand All @@ -23,27 +23,35 @@ module.exports = function (Posts) {
if (!canEdit.flag) {
throw new Error(canEdit.message);
}
let postData = await db.getObject('post:' + data.pid);
const postData = await Posts.getPostData(data.pid);
if (!postData) {
throw new Error('[[error:no-post]]');
}

const oldContent = postData.content; // for diffing purposes
postData.content = data.content;
postData.edited = Date.now();
postData.editor = data.uid;
const now = Date.now();
const editPostData = {
content: data.content,
edited: now,
editor: data.uid,
};
if (data.handle) {
postData.handle = data.handle;
editPostData.handle = data.handle;
}
const result = await plugins.fireHook('filter:post.edit', { req: data.req, post: postData, data: data, uid: data.uid });
postData = result.post;

const result = await plugins.fireHook('filter:post.edit', {
req: data.req,
post: editPostData,
data: data,
uid: data.uid,
});

const [editor, topic] = await Promise.all([
user.getUserFields(data.uid, ['username', 'userslug']),
editMainPost(data, postData),
]);

await Posts.setPostFields(data.pid, postData);
await Posts.setPostFields(data.pid, result.post);

if (meta.config.enablePostHistory === 1) {
await Posts.diffs.save({
Expand All @@ -54,27 +62,28 @@ module.exports = function (Posts) {
});
}
await Posts.uploads.sync(data.pid);
const returnPostData = { ...postData, ...editPostData };
returnPostData.cid = topic.cid;
returnPostData.topic = topic;
returnPostData.editedISO = utils.toISOString(now);

postData.cid = topic.cid;
postData.topic = topic;

await topics.notifyFollowers(postData, data.uid, {
await topics.notifyFollowers(returnPostData, data.uid, {
type: 'post-edit',
bodyShort: translator.compile('notifications:user_edited_post', editor.username, postData.topic.title),
nid: 'edit_post:' + postData.pid + ':uid:' + data.uid,
bodyShort: translator.compile('notifications:user_edited_post', editor.username, topic.title),
nid: 'edit_post:' + data.pid + ':uid:' + data.uid,
});

plugins.fireHook('action:post.edit', { post: _.clone(postData), data: data, uid: data.uid });
plugins.fireHook('action:post.edit', { post: _.clone(returnPostData), data: data, uid: data.uid });

require('./cache').del(String(postData.pid));
pubsub.publish('post:edit', String(postData.pid));

postData = await Posts.parsePost(postData);
await Posts.parsePost(returnPostData);

return {
topic: topic,
editor: editor,
post: postData,
post: returnPostData,
};
};

Expand Down Expand Up @@ -119,7 +128,11 @@ module.exports = function (Posts) {
}
await topics.validateTags(data.tags, topicData.cid);

const results = await plugins.fireHook('filter:topic.edit', { req: data.req, topic: newTopicData, data: data });
const results = await plugins.fireHook('filter:topic.edit', {
req: data.req,
topic: newTopicData,
data: data,
});
await db.setObject('topic:' + tid, results.topic);
await topics.updateTopicTags(tid, data.tags);
const tags = await topics.getTopicTagsObjects(tid);
Expand Down

0 comments on commit 16039b1

Please sign in to comment.