Merge pull request #1103 from spacebarchat/patch/api-compat

Fixes for bot libs
This commit is contained in:
Puyodead1 2023-12-04 23:36:31 -05:00 committed by GitHub
commit 26e3b47f4f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 2476 additions and 393 deletions

File diff suppressed because it is too large Load Diff

View File

@ -17,7 +17,11 @@
*/
import { route } from "@spacebar/api";
import { Application } from "@spacebar/util";
import {
Application,
DiscordApiErrors,
PublicUserProjection,
} from "@spacebar/util";
import { Request, Response, Router } from "express";
const router: Router = Router();
@ -29,18 +33,27 @@ router.get(
200: {
body: "Application",
},
400: {
body: "APIErrorResponse",
},
},
}),
async (req: Request, res: Response) => {
const app = await Application.findOneOrFail({
where: { id: req.user_id },
relations: ["owner", "bot"],
where: { id: req.params.id },
relations: ["bot", "owner"],
select: {
owner: Object.fromEntries(
PublicUserProjection.map((x) => [x, true]),
),
},
});
if (!app.bot) throw DiscordApiErrors.BOT_ONLY_ENDPOINT;
res.json({
...app,
owner: app.owner.toPublicUser(),
install_params:
app.install_params !== null ? app.install_params : undefined,
});
return res.json(app);
},
);
export default router;

View File

@ -229,7 +229,7 @@ export class ReadyGuildDTO implements IReadyGuildDTO {
nsfw: guild.nsfw,
safety_alerts_channel_id: null,
};
this.roles = guild.roles;
this.roles = guild.roles.map((x) => x.toJSON());
this.stage_instances = [];
this.stickers = guild.stickers;
this.threads = [];

View File

@ -238,6 +238,7 @@ export class Message extends BaseClass {
activity: this.activity ?? undefined,
application: this.application ?? undefined,
components: this.components ?? undefined,
content: this.content ?? "",
};
}
}

View File

@ -69,4 +69,11 @@ export class Role extends BaseClass {
@Column({ default: 0 })
flags: number;
toJSON(): Role {
return {
...this,
tags: this.tags ?? undefined,
};
}
}