Store Discord media proxy hashes in the database
This commit is contained in:
parent
f3eb1fbeb3
commit
06f502dd89
2 changed files with 19 additions and 1 deletions
|
@ -5,6 +5,13 @@ const assert = require("assert").strict
|
||||||
|
|
||||||
const {reg} = require("../matrix/read-registration")
|
const {reg} = require("../matrix/read-registration")
|
||||||
|
|
||||||
|
const {db} = require("../passthrough")
|
||||||
|
|
||||||
|
/** @type {import("xxhash-wasm").XXHashAPI} */ // @ts-ignore
|
||||||
|
let hasher = null
|
||||||
|
// @ts-ignore
|
||||||
|
require("xxhash-wasm")().then(h => hasher = h)
|
||||||
|
|
||||||
const EPOCH = 1420070400000
|
const EPOCH = 1420070400000
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -123,6 +130,9 @@ function timestampToSnowflakeInexact(timestamp) {
|
||||||
function getPublicUrlForCdn(url) {
|
function getPublicUrlForCdn(url) {
|
||||||
const match = url.match(/https:\/\/(cdn|media)\.discordapp\.(?:com|net)\/attachments\/([0-9]+)\/([0-9]+)\/([-A-Za-z0-9_.,]+)/)
|
const match = url.match(/https:\/\/(cdn|media)\.discordapp\.(?:com|net)\/attachments\/([0-9]+)\/([0-9]+)\/([-A-Za-z0-9_.,]+)/)
|
||||||
if (!match) return url
|
if (!match) return url
|
||||||
|
const unsignedHash = hasher.h64(match[3]) // attachment ID
|
||||||
|
const signedHash = unsignedHash - 0x8000000000000000n // shifting down to signed 64-bit range
|
||||||
|
db.prepare("INSERT OR IGNORE INTO media_proxy (permitted_hash) VALUES (?)").run(signedHash)
|
||||||
return `${reg.ooye.bridge_origin}/download/discord${match[1]}/${match[2]}/${match[3]}/${match[4]}`
|
return `${reg.ooye.bridge_origin}/download/discord${match[1]}/${match[2]}/${match[3]}/${match[4]}`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,11 @@ const assert = require("assert/strict")
|
||||||
const {defineEventHandler, getValidatedRouterParams, sendRedirect, createError} = require("h3")
|
const {defineEventHandler, getValidatedRouterParams, sendRedirect, createError} = require("h3")
|
||||||
const {z} = require("zod")
|
const {z} = require("zod")
|
||||||
|
|
||||||
|
/** @type {import("xxhash-wasm").XXHashAPI} */ // @ts-ignore
|
||||||
|
let hasher = null
|
||||||
|
// @ts-ignore
|
||||||
|
require("xxhash-wasm")().then(h => hasher = h)
|
||||||
|
|
||||||
const {discord, as, select} = require("../../passthrough")
|
const {discord, as, select} = require("../../passthrough")
|
||||||
|
|
||||||
const schema = {
|
const schema = {
|
||||||
|
@ -31,7 +36,10 @@ function defineMediaProxyHandler(domain) {
|
||||||
return defineEventHandler(async event => {
|
return defineEventHandler(async event => {
|
||||||
const params = await getValidatedRouterParams(event, schema.params.parse)
|
const params = await getValidatedRouterParams(event, schema.params.parse)
|
||||||
|
|
||||||
const row = select("channel_room", "channel_id", {channel_id: params.channel_id}).get()
|
const unsignedHash = hasher.h64(params.attachment_id)
|
||||||
|
const signedHash = unsignedHash - 0x8000000000000000n // shifting down to signed 64-bit range
|
||||||
|
|
||||||
|
const row = select("media_proxy", "permitted_hash", {permitted_hash: signedHash}).get()
|
||||||
if (row == null) {
|
if (row == null) {
|
||||||
throw createError({
|
throw createError({
|
||||||
status: 403,
|
status: 403,
|
||||||
|
|
Loading…
Reference in a new issue