diff --git a/d2m/converters/message-to-event.js b/d2m/converters/message-to-event.js index 24c7f2d..b9e13dd 100644 --- a/d2m/converters/message-to-event.js +++ b/d2m/converters/message-to-event.js @@ -268,7 +268,6 @@ async function messageToEvent(message, guild, options = {}, di) { * @param {string} content Partial or complete Discord message content */ async function transformContentMessageLinks(content) { - let offset = 0 for (const match of [...content.matchAll(/https:\/\/(?:ptb\.|canary\.|www\.)?discord(?:app)?\.com\/channels\/([0-9]+)\/([0-9]+)\/([0-9]+)/g)]) { assert(typeof match.index === "number") const channelID = match[2] @@ -287,8 +286,7 @@ async function messageToEvent(message, guild, options = {}, di) { } else { result = `${match[0]} [event is from another server]` } - content = content.slice(0, match.index + offset) + result + content.slice(match.index + match[0].length + offset) - offset += result.length - match[0].length + content = content.slice(0, match.index) + result + content.slice(match.index + match[0].length) } return content } diff --git a/d2m/converters/message-to-event.test.js b/d2m/converters/message-to-event.test.js index f3ac895..980b1f5 100644 --- a/d2m/converters/message-to-event.test.js +++ b/d2m/converters/message-to-event.test.js @@ -136,19 +136,6 @@ test("message2event: message link that OOYE doesn't know about", async t => { t.equal(called, 1, "getEventForTimestamp should be called once") }) -test("message2event: message link from another server", async t => { - const events = await messageToEvent(data.message.message_link_from_another_server, data.guild.general) - t.deepEqual(events, [{ - $type: "m.room.message", - "m.mentions": {}, - msgtype: "m.text", - body: "Neither of these servers are known to OOYE: https://discord.com/channels/111/222/333 [event is from another server] https://canary.discordapp.com/channels/444/555/666 [event is from another server]", - format: "org.matrix.custom.html", - formatted_body: 'Neither of these servers are known to OOYE: https://discord.com/channels/111/222/333 [event is from another server]' - + ' https://canary.discordapp.com/channels/444/555/666 [event is from another server]' - }]) -}) - test("message2event: attachment with no content", async t => { const events = await messageToEvent(data.message.attachment_no_content, data.guild.general, {}) t.deepEqual(events, [{ diff --git a/db/orm.js b/db/orm.js index d9cc1e8..9325bc0 100644 --- a/db/orm.js +++ b/db/orm.js @@ -82,6 +82,7 @@ class From { /** @type {Pluck