mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-26 16:46:12 +01:00
refactor(socket.io): deprecate SocketModules.chats.searchMessages in favour of api.search.roomMessages
This commit is contained in:
@@ -232,6 +232,8 @@ paths:
|
|||||||
$ref: 'write/search/categories.yaml'
|
$ref: 'write/search/categories.yaml'
|
||||||
/search/chats/{roomId}/users:
|
/search/chats/{roomId}/users:
|
||||||
$ref: 'write/search/chats/roomId/users.yaml'
|
$ref: 'write/search/chats/roomId/users.yaml'
|
||||||
|
/search/chats/{roomId}/messages:
|
||||||
|
$ref: 'write/search/chats/roomId/messages.yaml'
|
||||||
/admin/settings/{setting}:
|
/admin/settings/{setting}:
|
||||||
$ref: 'write/admin/settings/setting.yaml'
|
$ref: 'write/admin/settings/setting.yaml'
|
||||||
/admin/analytics:
|
/admin/analytics:
|
||||||
|
|||||||
37
public/openapi/write/search/chats/roomId/messages.yaml
Normal file
37
public/openapi/write/search/chats/roomId/messages.yaml
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
get:
|
||||||
|
tags:
|
||||||
|
- search
|
||||||
|
summary: find chat messages by keyword
|
||||||
|
description: This operation returns a set of messages in a chat room matching the keyword search.
|
||||||
|
parameters:
|
||||||
|
- in: path
|
||||||
|
name: roomId
|
||||||
|
schema:
|
||||||
|
type: number
|
||||||
|
required: true
|
||||||
|
description: room ID to check
|
||||||
|
example: 1
|
||||||
|
- in: query
|
||||||
|
name: 'query'
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: false
|
||||||
|
description: The keyword used in the message search
|
||||||
|
example: 'foobar'
|
||||||
|
responses:
|
||||||
|
'200':
|
||||||
|
description: matching messages successfully retrieved
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
status:
|
||||||
|
$ref: ../../../../components/schemas/Status.yaml#/Status
|
||||||
|
response:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
messages:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
$ref: ../../../../components/schemas/Chats.yaml#/MessageObject
|
||||||
@@ -16,7 +16,7 @@ get:
|
|||||||
schema:
|
schema:
|
||||||
type: string
|
type: string
|
||||||
required: false
|
required: false
|
||||||
description: The keyword used in the category search
|
description: The keyword used in the user search
|
||||||
example: 'admin'
|
example: 'admin'
|
||||||
responses:
|
responses:
|
||||||
'200':
|
'200':
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
const _ = require('lodash');
|
const _ = require('lodash');
|
||||||
|
|
||||||
|
const db = require('../database');
|
||||||
const user = require('../user');
|
const user = require('../user');
|
||||||
const categories = require('../categories');
|
const categories = require('../categories');
|
||||||
const messaging = require('../messaging');
|
const messaging = require('../messaging');
|
||||||
@@ -152,3 +153,40 @@ searchApi.roomUsers = async (caller, { query, roomId }) => {
|
|||||||
|
|
||||||
return { users: roomUsers };
|
return { users: roomUsers };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
searchApi.roomMessages = async (caller, { query, roomId, uid }) => {
|
||||||
|
const [roomData, inRoom] = await Promise.all([
|
||||||
|
messaging.getRoomData(roomId),
|
||||||
|
messaging.isUserInRoom(caller.uid, roomId),
|
||||||
|
]);
|
||||||
|
|
||||||
|
if (!roomData) {
|
||||||
|
throw new Error('[[error:no-room]]');
|
||||||
|
}
|
||||||
|
if (!inRoom) {
|
||||||
|
throw new Error('[[error:no-privileges]]');
|
||||||
|
}
|
||||||
|
const { ids } = await plugins.hooks.fire('filter:messaging.searchMessages', {
|
||||||
|
content: query,
|
||||||
|
roomId: [roomId],
|
||||||
|
uid: [uid],
|
||||||
|
matchWords: 'any',
|
||||||
|
ids: [],
|
||||||
|
});
|
||||||
|
|
||||||
|
let userjoinTimestamp = 0;
|
||||||
|
if (!roomData.public) {
|
||||||
|
userjoinTimestamp = await db.sortedSetScore(`chat:room:${roomId}:uids`, caller.uid);
|
||||||
|
}
|
||||||
|
let messageData = await messaging.getMessagesData(ids, caller.uid, roomId, false);
|
||||||
|
messageData = messageData
|
||||||
|
.map((msg) => {
|
||||||
|
if (msg) {
|
||||||
|
msg.newSet = true;
|
||||||
|
}
|
||||||
|
return msg;
|
||||||
|
})
|
||||||
|
.filter(msg => msg && !msg.deleted && msg.timestamp > userjoinTimestamp);
|
||||||
|
|
||||||
|
return { messages: messageData };
|
||||||
|
};
|
||||||
|
|||||||
@@ -10,6 +10,11 @@ Search.categories = async (req, res) => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
Search.roomUsers = async (req, res) => {
|
Search.roomUsers = async (req, res) => {
|
||||||
const { query } = req.query;
|
const { query, uid } = req.query;
|
||||||
helpers.formatApiResponse(200, res, await api.search.roomUsers(req, { query, ...req.params }));
|
helpers.formatApiResponse(200, res, await api.search.roomUsers(req, { query, uid, ...req.params }));
|
||||||
|
};
|
||||||
|
|
||||||
|
Search.roomMessages = async (req, res) => {
|
||||||
|
const { query } = req.query;
|
||||||
|
helpers.formatApiResponse(200, res, await api.search.roomMessages(req, { query, ...req.params }));
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -14,7 +14,9 @@ module.exports = function () {
|
|||||||
// setupApiRoute(router, 'post', '/', [...middlewares], controllers.write.search.TBD);
|
// setupApiRoute(router, 'post', '/', [...middlewares], controllers.write.search.TBD);
|
||||||
|
|
||||||
setupApiRoute(router, 'get', '/categories', [], controllers.write.search.categories);
|
setupApiRoute(router, 'get', '/categories', [], controllers.write.search.categories);
|
||||||
|
|
||||||
setupApiRoute(router, 'get', '/chats/:roomId/users', [...middlewares, middleware.checkRequired.bind(null, ['query']), middleware.canChat, middleware.assert.room], controllers.write.search.roomUsers);
|
setupApiRoute(router, 'get', '/chats/:roomId/users', [...middlewares, middleware.checkRequired.bind(null, ['query']), middleware.canChat, middleware.assert.room], controllers.write.search.roomUsers);
|
||||||
|
setupApiRoute(router, 'get', '/chats/:roomId/messages', [...middlewares, middleware.checkRequired.bind(null, ['query']), middleware.canChat, middleware.assert.room], controllers.write.search.roomMessages);
|
||||||
|
|
||||||
return router;
|
return router;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -189,40 +189,16 @@ SocketModules.chats.setNotificationSetting = async (socket, data) => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
SocketModules.chats.searchMessages = async (socket, data) => {
|
SocketModules.chats.searchMessages = async (socket, data) => {
|
||||||
|
sockets.warnDeprecated(socket, 'GET /api/v3/search/chats/:roomId/messages');
|
||||||
|
|
||||||
if (!data || !utils.isNumber(data.roomId) || !data.content) {
|
if (!data || !utils.isNumber(data.roomId) || !data.content) {
|
||||||
throw new Error('[[error:invalid-data]]');
|
throw new Error('[[error:invalid-data]]');
|
||||||
}
|
}
|
||||||
const [roomData, inRoom] = await Promise.all([
|
|
||||||
Messaging.getRoomData(data.roomId),
|
|
||||||
Messaging.isUserInRoom(socket.uid, data.roomId),
|
|
||||||
]);
|
|
||||||
|
|
||||||
if (!roomData) {
|
// parameter renamed; backwards compatibility
|
||||||
throw new Error('[[error:no-room]]');
|
data.query = data.content;
|
||||||
}
|
delete data.content;
|
||||||
if (!inRoom) {
|
return await api.search.roomMessages(socket, data);
|
||||||
throw new Error('[[error:no-privileges]]');
|
|
||||||
}
|
|
||||||
const { ids } = await plugins.hooks.fire('filter:messaging.searchMessages', {
|
|
||||||
content: data.content,
|
|
||||||
roomId: [data.roomId],
|
|
||||||
uid: [data.uid],
|
|
||||||
matchWords: 'any',
|
|
||||||
ids: [],
|
|
||||||
});
|
|
||||||
|
|
||||||
let userjoinTimestamp = 0;
|
|
||||||
if (!roomData.public) {
|
|
||||||
userjoinTimestamp = await db.sortedSetScore(`chat:room:${data.roomId}:uids`, socket.uid);
|
|
||||||
}
|
|
||||||
const messageData = await Messaging.getMessagesData(ids, socket.uid, data.roomId, false);
|
|
||||||
messageData.forEach((msg) => {
|
|
||||||
if (msg) {
|
|
||||||
msg.newSet = true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return messageData.filter(msg => msg && !msg.deleted && msg.timestamp > userjoinTimestamp);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
SocketModules.chats.loadPinnedMessages = async (socket, data) => {
|
SocketModules.chats.loadPinnedMessages = async (socket, data) => {
|
||||||
|
|||||||
Reference in New Issue
Block a user