diff --git a/scripts/seed.js b/scripts/seed.js index 01fc3e3c..649f3fc3 100644 --- a/scripts/seed.js +++ b/scripts/seed.js @@ -9,7 +9,7 @@ const {createServer} = require("http") const {prompt} = require("enquirer") const Input = require("enquirer/lib/prompts/input") -const fetch = require("node-fetch") +const fetch = require("node-fetch").default const {magenta, bold, cyan} = require("ansi-colors") const HeatSync = require("heatsync") const {SnowTransfer} = require("snowtransfer") diff --git a/src/d2m/converters/remove-reaction.test.js b/src/d2m/converters/remove-reaction.test.js index dc6eda59..b42c11a3 100644 --- a/src/d2m/converters/remove-reaction.test.js +++ b/src/d2m/converters/remove-reaction.test.js @@ -10,7 +10,9 @@ function fakeSpecificReactionRemoval(userID, emoji, emojiID) { channel_id: "THE_CHANNEL", message_id: "THE_MESSAGE", user_id: userID, - emoji: {id: emojiID, name: emoji} + emoji: {id: emojiID, name: emoji}, + burst: false, + type: 0 } } diff --git a/src/matrix/api.js b/src/matrix/api.js index 4b1c676c..4866495e 100644 --- a/src/matrix/api.js +++ b/src/matrix/api.js @@ -3,7 +3,7 @@ const Ty = require("../types") const assert = require("assert").strict -const fetch = require("node-fetch") +const fetch = require("node-fetch").default const passthrough = require("../passthrough") const { discord, sync, db } = passthrough @@ -315,7 +315,7 @@ async function ping() { /** * @param {string} mxc - * @param {RequestInit} [init] + * @param {fetch.RequestInit} [init] */ function getMedia(mxc, init = {}) { const mediaParts = mxc?.match(/^mxc:\/\/([^/]+)\/(\w+)$/) diff --git a/src/web/routes/download-matrix.js b/src/web/routes/download-matrix.js index 79f6a0e6..137af7c3 100644 --- a/src/web/routes/download-matrix.js +++ b/src/web/routes/download-matrix.js @@ -1,8 +1,9 @@ // @ts-check +const assert = require("assert/strict") const {defineEventHandler, getValidatedRouterParams, setResponseStatus, setResponseHeader, sendStream, createError} = require("h3") const {z} = require("zod") -const fetch = require("node-fetch") +const fetch = require("node-fetch").default /** @type {import("xxhash-wasm").XXHashAPI} */ // @ts-ignore let hasher = null @@ -40,9 +41,11 @@ as.router.get(`/download/matrix/:server_name/:media_id`, defineEventHandler(asyn } }) - setResponseStatus(event, res.status) - setResponseHeader(event, "Content-Type", res.headers.get("content-type")) - setResponseHeader(event, "Transfer-Encoding", "chunked") + const contentType = res.headers.get("content-type") + assert(contentType) - return sendStream(event, res.body) + setResponseStatus(event, res.status) + setResponseHeader(event, "Content-Type", contentType) + setResponseHeader(event, "Transfer-Encoding", "chunked") + return res.body }))