Use R2 for upload signing endpoint
This commit is contained in:
parent
32f3cf908f
commit
89ce6ec6d3
@ -1,27 +1,22 @@
|
|||||||
|
import { AwsClient } from "aws4fetch";
|
||||||
|
|
||||||
export async function onRequestGet(context: RequestContext) {
|
export async function onRequestGet(context: RequestContext) {
|
||||||
const attachment = (context.params.id as string[]).join("/");
|
const attachment = (context.params.id as string[]).join("/");
|
||||||
const unsignedURL = `https://mediaproxy.carcrushers.cc/${attachment}?Expires=${(
|
const aws = new AwsClient({
|
||||||
Math.round(Date.now() / 1000) + 1800
|
accessKeyId: context.env.R2_ACCESS_KEY,
|
||||||
).toString()}&KeyName=portal-media-linkgen`;
|
secretAccessKey: context.env.R2_SECRET_KEY,
|
||||||
const signingKey = await crypto.subtle.importKey(
|
});
|
||||||
"raw",
|
|
||||||
Uint8Array.from(atob(context.env.URL_SIGNING_KEY), (c) => c.charCodeAt(0)),
|
|
||||||
{ hash: "SHA-1", name: "HMAC" },
|
|
||||||
false,
|
|
||||||
["sign"],
|
|
||||||
);
|
|
||||||
const signature = await crypto.subtle.sign(
|
|
||||||
"HMAC",
|
|
||||||
signingKey,
|
|
||||||
new TextEncoder().encode(unsignedURL),
|
|
||||||
);
|
|
||||||
|
|
||||||
return Response.redirect(
|
return Response.redirect(
|
||||||
`${unsignedURL}&Signature=${btoa(
|
(
|
||||||
String.fromCharCode(...new Uint8Array(signature)),
|
await aws.sign(
|
||||||
|
`https://car-crushers.${context.env.R2_ZONE}.r2.cloudflarestorage.com/${attachment}?X-Amz-Expires=1800`,
|
||||||
|
{
|
||||||
|
aws: {
|
||||||
|
signQuery: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
)
|
)
|
||||||
.replaceAll("+", "-")
|
).url,
|
||||||
.replaceAll("/", "_")
|
|
||||||
.replaceAll("=", "")}`,
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user