2016-06-19 18:02:32 +08:00
|
|
|
const Joi = require('joi');
|
|
|
|
const Serialization = require('../serialization');
|
2016-06-29 06:35:35 +08:00
|
|
|
const {createSyncbackRequest} = require('../route-helpers')
|
2016-06-19 18:02:32 +08:00
|
|
|
|
|
|
|
module.exports = (server) => {
|
|
|
|
server.route({
|
|
|
|
method: 'GET',
|
|
|
|
path: '/threads',
|
|
|
|
config: {
|
|
|
|
description: 'Returns threads',
|
|
|
|
notes: 'Notes go here',
|
|
|
|
tags: ['threads'],
|
|
|
|
validate: {
|
2016-06-25 07:14:04 +08:00
|
|
|
query: {
|
2016-06-29 06:01:41 +08:00
|
|
|
'id': Joi.number().integer().min(0),
|
|
|
|
'subject': Joi.string(),
|
|
|
|
'unread': Joi.boolean(),
|
|
|
|
'starred': Joi.boolean(),
|
|
|
|
'startedBefore': Joi.date().timestamp(),
|
|
|
|
'startedAfter': Joi.date().timestamp(),
|
|
|
|
'lastMessageBefore': Joi.date().timestamp(),
|
|
|
|
'lastMessageAfter': Joi.date().timestamp(),
|
|
|
|
'in': Joi.string().allow(Joi.number()),
|
2016-06-19 18:02:32 +08:00
|
|
|
},
|
|
|
|
},
|
|
|
|
response: {
|
|
|
|
schema: Joi.array().items(
|
2016-06-24 06:46:52 +08:00
|
|
|
Serialization.jsonSchema('Thread')
|
2016-06-19 18:02:32 +08:00
|
|
|
),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
handler: (request, reply) => {
|
|
|
|
request.getAccountDatabase().then((db) => {
|
2016-06-29 06:01:41 +08:00
|
|
|
const {Thread, Category} = db;
|
2016-06-28 03:30:28 +08:00
|
|
|
const query = request.query;
|
2016-06-28 01:15:05 +08:00
|
|
|
const where = {};
|
2016-06-29 06:01:41 +08:00
|
|
|
const include = [];
|
2016-06-28 01:15:05 +08:00
|
|
|
|
2016-06-28 03:30:28 +08:00
|
|
|
if (query.id) {
|
|
|
|
where.id = query.id;
|
2016-06-28 01:35:34 +08:00
|
|
|
}
|
2016-06-28 04:45:11 +08:00
|
|
|
if (query.subject) {
|
|
|
|
// the 'like' operator is case-insenstive in sequelite and for
|
|
|
|
// non-binary strings in mysql
|
2016-06-29 06:56:35 +08:00
|
|
|
where.cleanedSubject = {like: query.subject};
|
2016-06-28 04:45:11 +08:00
|
|
|
}
|
2016-06-28 03:30:28 +08:00
|
|
|
|
|
|
|
// Boolean queries
|
|
|
|
if (query.unread) {
|
2016-06-28 01:15:05 +08:00
|
|
|
where.unreadCount = {gt: 0};
|
2016-06-28 03:30:28 +08:00
|
|
|
} else if (query.unread !== undefined) {
|
2016-06-28 01:15:05 +08:00
|
|
|
where.unreadCount = 0;
|
|
|
|
}
|
2016-06-28 03:30:28 +08:00
|
|
|
if (query.starred) {
|
2016-06-28 01:15:05 +08:00
|
|
|
where.starredCount = {gt: 0};
|
2016-06-28 03:30:28 +08:00
|
|
|
} else if (query.starred !== undefined) {
|
2016-06-28 01:15:05 +08:00
|
|
|
where.starredCount = 0;
|
2016-06-25 07:14:04 +08:00
|
|
|
}
|
2016-06-28 01:15:05 +08:00
|
|
|
|
2016-06-28 03:30:28 +08:00
|
|
|
// Timestamp queries
|
|
|
|
if (query.lastMessageBefore) {
|
2016-06-29 09:01:43 +08:00
|
|
|
where.lastMessageReceivedDate = {lt: query.lastMessageBefore};
|
2016-06-28 03:30:28 +08:00
|
|
|
}
|
|
|
|
if (query.lastMessageAfter) {
|
2016-06-29 09:01:43 +08:00
|
|
|
if (where.lastMessageReceivedDate) {
|
|
|
|
where.lastMessageReceivedDate.gt = query.lastMessageAfter;
|
2016-06-28 03:30:28 +08:00
|
|
|
} else {
|
2016-06-29 09:01:43 +08:00
|
|
|
where.lastMessageReceivedDate = {gt: query.lastMessageAfter};
|
2016-06-28 03:30:28 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (query.startedBefore) {
|
2016-06-29 09:01:43 +08:00
|
|
|
where.firstMessageDate = {lt: query.startedBefore};
|
2016-06-28 03:30:28 +08:00
|
|
|
}
|
|
|
|
if (query.startedAfter) {
|
2016-06-29 09:01:43 +08:00
|
|
|
if (where.firstMessageDate) {
|
|
|
|
where.firstMessageDate.gt = query.startedAfter;
|
2016-06-28 03:30:28 +08:00
|
|
|
} else {
|
2016-06-29 09:01:43 +08:00
|
|
|
where.firstMessageDate = {gt: query.startedAfter};
|
2016-06-28 03:30:28 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-29 06:01:41 +08:00
|
|
|
// Association queries
|
|
|
|
if (query.in) {
|
|
|
|
include.push({
|
|
|
|
model: Category,
|
|
|
|
where: { $or: [
|
|
|
|
{ id: query.in },
|
|
|
|
{ name: query.in },
|
|
|
|
{ role: query.in },
|
|
|
|
]},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-06-28 01:15:05 +08:00
|
|
|
Thread.findAll({
|
|
|
|
where: where,
|
2016-06-29 06:01:41 +08:00
|
|
|
include: include,
|
2016-06-28 01:15:05 +08:00
|
|
|
limit: 50,
|
|
|
|
}).then((threads) => {
|
|
|
|
reply(Serialization.jsonStringify(threads));
|
|
|
|
})
|
2016-06-19 18:02:32 +08:00
|
|
|
})
|
|
|
|
},
|
|
|
|
});
|
2016-06-24 06:46:52 +08:00
|
|
|
|
|
|
|
server.route({
|
|
|
|
method: 'PUT',
|
|
|
|
path: '/threads/${id}',
|
|
|
|
config: {
|
|
|
|
description: 'Update a thread',
|
|
|
|
notes: 'Can move between folders',
|
|
|
|
tags: ['threads'],
|
|
|
|
validate: {
|
|
|
|
params: {
|
|
|
|
payload: {
|
|
|
|
folder_id: Joi.string(),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
response: {
|
|
|
|
schema: Joi.array().items(
|
|
|
|
Serialization.jsonSchema('Thread')
|
|
|
|
),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
handler: (request, reply) => {
|
2016-06-29 06:35:35 +08:00
|
|
|
createSyncbackRequest(request, reply, {
|
|
|
|
type: "MoveToFolder",
|
|
|
|
props: {
|
|
|
|
folderId: request.params.folder_id,
|
2016-06-29 09:01:43 +08:00
|
|
|
threadId: request.params.id,
|
|
|
|
},
|
2016-06-24 06:46:52 +08:00
|
|
|
})
|
|
|
|
},
|
|
|
|
});
|
2016-06-19 18:02:32 +08:00
|
|
|
};
|