diff --git a/src/d2m/converters/message-to-event.embeds.test.js b/src/d2m/converters/message-to-event.embeds.test.js index 4d76624..08558b4 100644 --- a/src/d2m/converters/message-to-event.embeds.test.js +++ b/src/d2m/converters/message-to-event.embeds.test.js @@ -1,7 +1,7 @@ const {test} = require("supertape") const {messageToEvent} = require("./message-to-event") const data = require("../../../test/data") -const Ty = require("../../types") +const {db} = require("../../passthrough") test("message2event embeds: nothing but a field", async t => { const events = await messageToEvent(data.message_with_embeds.nothing_but_a_field, data.guild.general, {}) @@ -351,3 +351,16 @@ test("message2event embeds: if discord creates an embed preview for a discord ch "m.mentions": {} }]) }) + +test("message2event embeds: nothing generated if embeds are disabled in settings", async t => { + db.prepare("UPDATE guild_space SET url_preview = 0 WHERE guild_id = ?").run(data.guild.general.id) + const events = await messageToEvent(data.message_with_embeds.youtube_video, data.guild.general) + t.deepEqual(events, [{ + $type: "m.room.message", + msgtype: "m.text", + body: "https://youtu.be/kDMHHw8JqLE?si=NaqNjVTtXugHeG_E\n\n\nJutomi I'm gonna make these sounds in your walls tonight", + format: "org.matrix.custom.html", + formatted_body: `https://youtu.be/kDMHHw8JqLE?si=NaqNjVTtXugHeG_E


Jutomi I'm gonna make these sounds in your walls tonight`, + "m.mentions": {} + }]) +}) diff --git a/src/d2m/converters/message-to-event.js b/src/d2m/converters/message-to-event.js index 41ce09a..b6268dc 100644 --- a/src/d2m/converters/message-to-event.js +++ b/src/d2m/converters/message-to-event.js @@ -597,7 +597,12 @@ async function messageToEvent(message, guild, options = {}, di) { } // Then embeds + const urlPreviewEnabled = select("guild_space", "url_preview", {guild_id: guild?.id}).pluck().get() ?? 1 for (const embed of message.embeds || []) { + if (!urlPreviewEnabled && !message.author?.bot) { + continue // show embeds for everyone if enabled, or bot users only if disabled (bots often send content in embeds) + } + if (embed.type === "image") { continue // Matrix's own URL previews are fine for images. } diff --git a/src/db/migrations/0021-add-url-preview-to-guild-space.sql b/src/db/migrations/0021-add-url-preview-to-guild-space.sql new file mode 100644 index 0000000..64bc0dd --- /dev/null +++ b/src/db/migrations/0021-add-url-preview-to-guild-space.sql @@ -0,0 +1,5 @@ +BEGIN TRANSACTION; + +ALTER TABLE guild_space ADD COLUMN url_preview INTEGER NOT NULL DEFAULT 1; + +COMMIT; diff --git a/src/db/orm-defs.d.ts b/src/db/orm-defs.d.ts index ac026f1..c38dc35 100644 --- a/src/db/orm-defs.d.ts +++ b/src/db/orm-defs.d.ts @@ -34,6 +34,7 @@ export type Models = { space_id: string privacy_level: number presence: 0 | 1 + url_preview: 0 | 1 } guild_active: { diff --git a/src/web/pug/guild.pug b/src/web/pug/guild.pug index 29ab301..43deef3 100644 --- a/src/web/pug/guild.pug +++ b/src/web/pug/guild.pug @@ -102,13 +102,24 @@ block body #autocreate-loading if space_id + h3.mt32.fs-category URL preview + .s-card + form.d-flex.ai-center.g8 + label.s-label.fl-grow1(for="url-preview") + | Show Discord's URL previews on Matrix + p.s-description Shows info about links posted to chat. Discord's previews are generally better quality than Synapse's, especially for social media and videos. + - let value = !!select("guild_space", "url_preview", {guild_id}).pluck().get() + input(type="hidden" name="guild_id" value=guild_id) + input.s-toggle-switch.order-last#autocreate(name="url_preview" type="checkbox" hx-post="/api/url-preview" hx-indicator="#url-preview-loading" hx-disabled-elt="this" checked=value autocomplete="off") + #url-preview-loading + h3.mt32.fs-category Presence .s-card form.d-flex.ai-center.g8 label.s-label.fl-grow1(for="presence") | Show online statuses on Matrix p.s-description This might cause lag on really big Discord servers. - - let value = !!select("guild_space", "presence", {guild_id}).pluck().get() + - value = !!select("guild_space", "presence", {guild_id}).pluck().get() input(type="hidden" name="guild_id" value=guild_id) input.s-toggle-switch.order-last#autocreate(name="presence" type="checkbox" hx-post="/api/presence" hx-indicator="#presence-loading" hx-disabled-elt="this" checked=value autocomplete="off") #presence-loading diff --git a/src/web/routes/guild-settings.js b/src/web/routes/guild-settings.js index 4e36059..cdb9a63 100644 --- a/src/web/routes/guild-settings.js +++ b/src/web/routes/guild-settings.js @@ -27,6 +27,10 @@ const schema = { guild_id: z.string(), autocreate: z.string().optional() }), + urlPreview: z.object({ + guild_id: z.string(), + url_preview: z.string().optional() + }), presence: z.object({ guild_id: z.string(), presence: z.string().optional() @@ -57,6 +61,16 @@ as.router.post("/api/autocreate", defineEventHandler(async event => { return null // 204 })) +as.router.post("/api/url-preview", defineEventHandler(async event => { + const parsedBody = await readValidatedBody(event, schema.urlPreview.parse) + const managed = await auth.getManagedGuilds(event) + if (!managed.has(parsedBody.guild_id)) throw createError({status: 403, message: "Forbidden", data: "Can't change settings for a guild you don't have Manage Server permissions in"}) + + db.prepare("UPDATE guild_space SET url_preview = ? WHERE guild_id = ?").run(+!!parsedBody.url_preview, parsedBody.guild_id) + + return null // 204 +})) + as.router.post("/api/presence", defineEventHandler(async event => { const parsedBody = await readValidatedBody(event, schema.presence.parse) const managed = await auth.getManagedGuilds(event)