diff --git a/api/src/routes/guilds/templates/index.ts b/api/src/routes/guilds/templates/index.ts
index 86316d23..b82fb102 100644
--- a/api/src/routes/guilds/templates/index.ts
+++ b/api/src/routes/guilds/templates/index.ts
@@ -3,21 +3,67 @@ const router: Router = Router();
import { Template, Guild, Role, Snowflake, Config, User, Member } from "@fosscord/util";
import { route } from "@fosscord/api";
import { DiscordApiErrors } from "@fosscord/util";
+import fetch from "node-fetch";
+const { enabled, allowTemplateCreation, allowDiscordTemplates, allowOtherInstancesTemplates, allowExternalRaws } = Config.get().templates;
export interface GuildTemplateCreateSchema {
name: string;
avatar?: string | null;
}
router.get("/:code", route({}), async (req: Request, res: Response) => {
+ if (enabled == false) return res.json({ code: 403, message: "Templates are disabled on this instance." }).sendStatus(403);
const { code } = req.params;
+ if (code.startsWith("discord:")) {
+ if (allowDiscordTemplates == false)
+ return res.json({ code: 403, message: "Discord templates are disabled on this instance." }).sendStatus(403);
+ const discordTemplateID = code.split("discord:", 2)[1];
+
+ const discordTemplateData = await fetch(`https://discord.com/api/v9/guilds/templates/${discordTemplateID}`, {
+ method: "get",
+ headers: { "Content-Type": "application/json" }
+ });
+
+ res.json(await discordTemplateData.json());
+ };
+
+ if (code.startsWith("fosscord:")) {
+ if (allowOtherInstancesTemplates == false)
+ return res.json({ code: 403, message: "Other instance templates are disabled on this instance." }).sendStatus(403);
+ //TODO: TBD when federation came out
+ res.json({}).sendStatus(200);
+ };
+
+ //TODO: Validation
+ if (code.startsWith("external:")) {
+ if (allowExternalRaws == false)
+ return res.json({ code: 403, message: "Importing templates from raws is disabled on this instance." }).sendStatus(403);
+ const url = code.split("external:", 2)[1];
+
+ const rawTemplateData =
+ (await fetch(`${url}`, {
+ method: "get",
+ headers: { "Content-Type": "application/json" }
+ })) || null;
+
+ res.json(
+ rawTemplateData !== null
+ ? await rawTemplateData.json()
+ : { code: 500, message: "An error occurred while trying to fetch the raw." }
+ );
+ };
+
const template = await Template.findOneOrFail({ code: code });
res.json(template);
});
router.post("/:code", route({ body: "GuildTemplateCreateSchema" }), async (req: Request, res: Response) => {
+ if (enabled == false) return res.json({ code: 403, message: "Templates are disabled on this instance." }).sendStatus(403);
+ if (allowTemplateCreation == false)
+ return res.json({ code: 403, message: "Template creation is disabled on this instance." }).sendStatus(403);
+
const { code } = req.params;
const body = req.body as GuildTemplateCreateSchema;
diff --git a/util/src/entities/Config.ts b/util/src/entities/Config.ts
index b3167ac7..1d2d496a 100644
--- a/util/src/entities/Config.ts
+++ b/util/src/entities/Config.ts
@@ -160,6 +160,13 @@ export interface ConfigValue {
kafka: {
brokers: KafkaBroker[] | null;
};
+ templates: {
+ enabled: Boolean;
+ allowTemplateCreation: Boolean;
+ allowDiscordTemplates: Boolean;
+ allowOtherInstancesTemplates: Boolean;
+ allowExternalRaws: Boolean
+ }
}
export const DefaultConfigOptions: ConfigValue = {
@@ -321,4 +328,11 @@ export const DefaultConfigOptions: ConfigValue = {
kafka: {
brokers: null,
},
+ templates: {
+ enabled: true,
+ allowTemplateCreation: true,
+ allowDiscordTemplates: true,
+ allowOtherInstancesTemplates: false, //Incomple
+ allowExternalRaws: false
+ }
};
|