refactor(federation): ♻️ Use new federation package to send inbox requests

This commit is contained in:
Jesse Wierzbinski 2024-05-16 22:47:30 -10:00
parent 820591dddc
commit dfe678ffae
No known key found for this signature in database

View file

@ -1,4 +1,7 @@
import type { EntityValidator } from "@lysand-org/federation"; import {
type EntityValidator,
SignatureConstructor,
} from "@lysand-org/federation";
import { config } from "config-manager"; import { config } from "config-manager";
import type { User } from "~packages/database-interface/user"; import type { User } from "~packages/database-interface/user";
@ -25,40 +28,18 @@ export const objectToInboxRequest = async (
["sign"], ["sign"],
); );
const digest = await crypto.subtle.digest( const ctor = new SignatureConstructor(privateKey, author.getUri());
"SHA-256",
new TextEncoder().encode(JSON.stringify(object)),
);
const userInbox = new URL(userToSendTo.getUser().endpoints?.inbox ?? ""); const userInbox = new URL(userToSendTo.getUser().endpoints?.inbox ?? "");
const date = new Date(); const request = new Request(userInbox, {
const signature = await crypto.subtle.sign(
"Ed25519",
privateKey,
new TextEncoder().encode(
`(request-target): post ${userInbox.pathname}\n` +
`host: ${userInbox.host}\n` +
`date: ${date.toISOString()}\n` +
`digest: SHA-256=${Buffer.from(new Uint8Array(digest)).toString(
"base64",
)}\n`,
),
);
const signatureBase64 = Buffer.from(new Uint8Array(signature)).toString(
"base64",
);
return new Request(userInbox, {
method: "POST", method: "POST",
headers: { headers: {
"Content-Type": "application/json", "Content-Type": "application/json",
Date: date.toISOString(),
Origin: new URL(config.http.base_url).host, Origin: new URL(config.http.base_url).host,
Signature: `keyId="${author.getUri()}",algorithm="ed25519",headers="(request-target) host date digest",signature="${signatureBase64}"`,
}, },
body: JSON.stringify(object), body: JSON.stringify(object),
}); });
return await ctor.sign(request);
}; };