80 lines
2.6 KiB
JavaScript
80 lines
2.6 KiB
JavaScript
#!/usr/bin/env node
|
|
// @ts-check
|
|
|
|
console.log("-=- This script is experimental. It WILL mess up the room history on Matrix. -=-")
|
|
console.log()
|
|
|
|
const {channel: channelID} = require("minimist")(process.argv.slice(2), {string: ["channel"]})
|
|
if (!channelID) {
|
|
console.error("Usage: ./scripts/backfill.js --channel=<channel id here>")
|
|
process.exit(1)
|
|
}
|
|
|
|
const assert = require("assert/strict")
|
|
const sqlite = require("better-sqlite3")
|
|
const backfill = new sqlite("scripts/backfill.db")
|
|
backfill.prepare("CREATE TABLE IF NOT EXISTS backfill (channel_id TEXT NOT NULL, message_id INTEGER NOT NULL, PRIMARY KEY (channel_id, message_id))").run()
|
|
|
|
const HeatSync = require("heatsync")
|
|
|
|
const {reg} = require("../src/matrix/read-registration")
|
|
const passthrough = require("../src/passthrough")
|
|
|
|
const sync = new HeatSync({watchFS: false})
|
|
const db = new sqlite("ooye.db")
|
|
Object.assign(passthrough, {sync, db})
|
|
|
|
const DiscordClient = require("../src/d2m/discord-client")
|
|
|
|
const discord = new DiscordClient(reg.ooye.discord_token, "half")
|
|
passthrough.discord = discord
|
|
|
|
const orm = sync.require("../src/db/orm")
|
|
passthrough.from = orm.from
|
|
passthrough.select = orm.select
|
|
|
|
/** @type {import("../src/d2m/event-dispatcher")}*/
|
|
const eventDispatcher = sync.require("../src/d2m/event-dispatcher")
|
|
|
|
const roomID = passthrough.select("channel_room", "room_id", {channel_id: channelID}).pluck().get()
|
|
if (!roomID) {
|
|
console.error("Please choose a channel that's already bridged.")
|
|
process.exit(1)
|
|
}
|
|
|
|
;(async () => {
|
|
await discord.cloud.connect()
|
|
console.log("Connected, waiting for data about requested channel...")
|
|
|
|
discord.cloud.on("event", event)
|
|
})()
|
|
|
|
const preparedInsert = backfill.prepare("INSERT INTO backfill (channel_id, message_id) VALUES (?, ?)")
|
|
|
|
async function event(event) {
|
|
if (event.t !== "GUILD_CREATE") return
|
|
const channel = event.d.channels.find(c => c.id === channelID)
|
|
if (!channel) return
|
|
const guild_id = event.d.id
|
|
|
|
let last = backfill.prepare("SELECT cast(max(message_id) as TEXT) FROM backfill WHERE channel_id = ?").pluck().get(channelID) || "0"
|
|
console.log(`OK, processing messages for #${channel.name}, continuing from ${last}`)
|
|
|
|
while (last) {
|
|
const messages = await discord.snow.channel.getChannelMessages(channelID, {limit: 50, after: String(last)})
|
|
messages.reverse() // More recent messages come first -> More recent messages come last
|
|
for (const message of messages) {
|
|
const simulatedGatewayDispatchData = {
|
|
guild_id,
|
|
backfill: true,
|
|
...message
|
|
}
|
|
await eventDispatcher.onMessageCreate(discord, simulatedGatewayDispatchData)
|
|
preparedInsert.run(channelID, message.id)
|
|
}
|
|
last = messages.at(-1)?.id
|
|
}
|
|
|
|
process.exit()
|
|
}
|