external templates + fosscord draft and more configs
This commit is contained in:
parent
9cda0c2c5a
commit
7c724175ce
@ -4,24 +4,47 @@ import { Template, Guild, Role, Snowflake, Config, User, Member } from "@fosscor
|
|||||||
import { route } from "@fosscord/api";
|
import { route } from "@fosscord/api";
|
||||||
import { DiscordApiErrors } from "@fosscord/util";
|
import { DiscordApiErrors } from "@fosscord/util";
|
||||||
import fetch from "node-fetch";
|
import fetch from "node-fetch";
|
||||||
|
|
||||||
|
const { enabled, allowTemplateCreation, allowDiscordTemplates, allowOtherInstancesTemplates, allowExternalRaws } = Config.get().templates;
|
||||||
export interface GuildTemplateCreateSchema {
|
export interface GuildTemplateCreateSchema {
|
||||||
name: string;
|
name: string;
|
||||||
avatar?: string | null;
|
avatar?: string | null;
|
||||||
}
|
}
|
||||||
|
|
||||||
router.get("/:code", route({}), async (req: Request, res: Response) => {
|
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;
|
const { code } = req.params;
|
||||||
|
|
||||||
if (code.startsWith("discord:")) {
|
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 discordTemplateID = code.split("discord:", 2)[1];
|
||||||
if (Config.get().templates.allowDiscordTemplates == false) return res.json({ code: 403, message: "Discord templates are disabled on this instance."}).sendStatus(403)
|
|
||||||
|
|
||||||
const discordTemplateData = await fetch(`https://discord.com/api/v9/guilds/templates/${discordTemplateID}`, {
|
const discordTemplateData = await fetch(`https://discord.com/api/v9/guilds/templates/${discordTemplateID}`, {
|
||||||
method: "get",
|
method: "get",
|
||||||
headers: { "Content-Type": "application/json" }
|
headers: { "Content-Type": "application/json" }
|
||||||
});
|
});
|
||||||
|
|
||||||
return res.json(await discordTemplateData.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 });
|
const template = await Template.findOneOrFail({ code: code });
|
||||||
@ -30,6 +53,9 @@ router.get("/:code", route({}), async (req: Request, res: Response) => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
router.post("/:code", route({ body: "GuildTemplateCreateSchema" }), async (req: Request, res: Response) => {
|
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 { code } = req.params;
|
||||||
const body = req.body as GuildTemplateCreateSchema;
|
const body = req.body as GuildTemplateCreateSchema;
|
||||||
|
|
||||||
|
@ -161,7 +161,11 @@ export interface ConfigValue {
|
|||||||
brokers: KafkaBroker[] | null;
|
brokers: KafkaBroker[] | null;
|
||||||
};
|
};
|
||||||
templates: {
|
templates: {
|
||||||
allowDiscordTemplates: Boolean
|
enabled: Boolean;
|
||||||
|
allowTemplateCreation: Boolean;
|
||||||
|
allowDiscordTemplates: Boolean;
|
||||||
|
allowOtherInstancesTemplates: Boolean;
|
||||||
|
allowExternalRaws: Boolean
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -325,6 +329,10 @@ export const DefaultConfigOptions: ConfigValue = {
|
|||||||
brokers: null,
|
brokers: null,
|
||||||
},
|
},
|
||||||
templates: {
|
templates: {
|
||||||
allowDiscordTemplates: true
|
enabled: true,
|
||||||
|
allowTemplateCreation: true,
|
||||||
|
allowDiscordTemplates: true,
|
||||||
|
allowOtherInstancesTemplates: false, //Incomple
|
||||||
|
allowExternalRaws: false
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user