mirror of
https://github.com/discordeno/discordeno.git
synced 2026-05-28 14:30:11 +00:00
* fix: check new types idea * fix: type errors * fix: new style * fix: more cleanup * fix: more cleanup * fix: cleanup audit logs * fix: cleanup stickers * fix: cleanup integrations * fix: more cleanup * fix: organize into 1 place * fix: few errors * fix: some broken import fixes * fix: quite a lot of fixes across the board * fix: more fixes for broken imports * fix: more fixes for broken imports * fix: handler imports * fix: all remaining import errors * fix: more errors needing fixes * fix: clearing up transformers * fix: few moer types * fix: more cleanup of extra types * fix: fmt * fix: cleanup discordeno file * Nuke Base Types (#2102) * fix: cleanup snake stuff * convert camelCase to snake_case (#2103) * fix: add camelize * fix: finalize remaining errors * fix: imports in test Co-authored-by: LTS20050703 <87189679+lts20050703@users.noreply.github.com>
52 lines
2.0 KiB
TypeScript
52 lines
2.0 KiB
TypeScript
import { RestManager } from "../bot.ts";
|
|
import { FileContent } from "../types/discordeno.ts";
|
|
import { USER_AGENT } from "../util/constants.ts";
|
|
import { RestPayload, RestRequest } from "./rest.ts";
|
|
|
|
/** Creates the request body and headers that are necessary to send a request. Will handle different types of methods and everything necessary for discord. */
|
|
export function createRequestBody(rest: RestManager, queuedRequest: { request: RestRequest; payload: RestPayload }) {
|
|
const headers: { [key: string]: string } = {
|
|
Authorization: `Bot ${rest.token}`,
|
|
"User-Agent": USER_AGENT,
|
|
};
|
|
|
|
// GET METHODS SHOULD NOT HAVE A BODY
|
|
if (queuedRequest.request.method.toUpperCase() === "GET") {
|
|
queuedRequest.payload.body = undefined;
|
|
}
|
|
|
|
// IF A REASON IS PROVIDED ENCODE IT IN HEADERS
|
|
if (queuedRequest.payload.body?.reason) {
|
|
headers["X-Audit-Log-Reason"] = encodeURIComponent(queuedRequest.payload.body.reason as string);
|
|
queuedRequest.payload.body.reason = undefined;
|
|
}
|
|
|
|
// IF A FILE/ATTACHMENT IS PRESENT WE NEED SPECIAL HANDLING
|
|
if (queuedRequest.payload.body?.file) {
|
|
if (!Array.isArray(queuedRequest.payload.body.file)) {
|
|
queuedRequest.payload.body.file = [queuedRequest.payload.body.file];
|
|
}
|
|
|
|
const form = new FormData();
|
|
|
|
for (let i = 0; i < (queuedRequest.payload.body.file as FileContent[]).length; i++) {
|
|
form.append(
|
|
`file${i}`,
|
|
(queuedRequest.payload.body.file as FileContent[])[i].blob,
|
|
(queuedRequest.payload.body.file as FileContent[])[i].name,
|
|
);
|
|
}
|
|
|
|
form.append("payload_json", JSON.stringify({ ...queuedRequest.payload.body, file: undefined }));
|
|
queuedRequest.payload.body.file = form;
|
|
} else if (queuedRequest.payload.body && !["GET", "DELETE"].includes(queuedRequest.request.method)) {
|
|
headers["Content-Type"] = "application/json";
|
|
}
|
|
|
|
return {
|
|
headers,
|
|
body: (queuedRequest.payload.body?.file ?? JSON.stringify(queuedRequest.payload.body)) as FormData | string,
|
|
method: queuedRequest.request.method.toUpperCase(),
|
|
};
|
|
}
|