Fix mentions in comments
authorChocobozzz <me@florianbigard.com>
Wed, 21 Mar 2018 10:17:01 +0000 (11:17 +0100)
committerChocobozzz <me@florianbigard.com>
Wed, 21 Mar 2018 10:17:01 +0000 (11:17 +0100)
server/models/video/video-comment.ts

index bf8da924d5555ee5d06911941100f5ee47881c7d..5386a10aa4892a8fa9f9b58f6150da30c1c0b31d 100644 (file)
@@ -307,15 +307,15 @@ export class VideoCommentModel extends Model<VideoCommentModel> {
     const query = {
       order: [ [ 'createdAt', order ] ],
       where: {
-        [ Sequelize.Op.or ]: [
-          { id: comment.getThreadId() },
-          { originCommentId: comment.getThreadId() }
-        ],
         id: {
+          [ Sequelize.Op.in ]: Sequelize.literal('(' +
+            'WITH RECURSIVE children (id, "inReplyToCommentId") AS ( ' +
+            'SELECT id, "inReplyToCommentId" FROM "videoComment" WHERE id = ' + comment.id + ' UNION ' +
+            'SELECT p.id, p."inReplyToCommentId" from "videoComment" p ' +
+            'INNER JOIN children c ON c."inReplyToCommentId" = p.id) ' +
+            'SELECT id FROM children' +
+          ')'),
           [ Sequelize.Op.ne ]: comment.id
-        },
-        createdAt: {
-          [ Sequelize.Op.lt ]: comment.createdAt
         }
       },
       transaction: t