From 90f8fe7e538bb7e52d2558152a0390e693f39b11 Mon Sep 17 00:00:00 2001 From: Akihiko Odaki Date: Thu, 29 Mar 2018 01:20:40 +0900 Subject: Introduce processor --- src/api/models/messaging-message.ts | 81 ------------------------------------- 1 file changed, 81 deletions(-) delete mode 100644 src/api/models/messaging-message.ts (limited to 'src/api/models/messaging-message.ts') diff --git a/src/api/models/messaging-message.ts b/src/api/models/messaging-message.ts deleted file mode 100644 index fcb356c5ca..0000000000 --- a/src/api/models/messaging-message.ts +++ /dev/null @@ -1,81 +0,0 @@ -import * as mongo from 'mongodb'; -import deepcopy = require('deepcopy'); -import { pack as packUser } from './user'; -import { pack as packFile } from './drive-file'; -import db from '../../db/mongodb'; -import parse from '../common/text'; - -const MessagingMessage = db.get('messaging_messages'); -export default MessagingMessage; - -export interface IMessagingMessage { - _id: mongo.ObjectID; - created_at: Date; - text: string; - user_id: mongo.ObjectID; - recipient_id: mongo.ObjectID; - is_read: boolean; -} - -export function isValidText(text: string): boolean { - return text.length <= 1000 && text.trim() != ''; -} - -/** - * Pack a messaging message for API response - * - * @param {any} message - * @param {any} me? - * @param {any} options? - * @return {Promise} - */ -export const pack = ( - message: any, - me?: any, - options?: { - populateRecipient: boolean - } -) => new Promise(async (resolve, reject) => { - const opts = options || { - populateRecipient: true - }; - - let _message: any; - - // Populate the message if 'message' is ID - if (mongo.ObjectID.prototype.isPrototypeOf(message)) { - _message = await MessagingMessage.findOne({ - _id: message - }); - } else if (typeof message === 'string') { - _message = await MessagingMessage.findOne({ - _id: new mongo.ObjectID(message) - }); - } else { - _message = deepcopy(message); - } - - // Rename _id to id - _message.id = _message._id; - delete _message._id; - - // Parse text - if (_message.text) { - _message.ast = parse(_message.text); - } - - // Populate user - _message.user = await packUser(_message.user_id, me); - - if (_message.file_id) { - // Populate file - _message.file = await packFile(_message.file_id); - } - - if (opts.populateRecipient) { - // Populate recipient - _message.recipient = await packUser(_message.recipient_id, me); - } - - resolve(_message); -}); -- cgit v1.2.3-freya