summary refs log tree commit diff
path: root/src/api/routes/discoverable-guilds.ts
blob: 383e2b2468221acd54258f37a238aca46d5236ec (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import { Guild, Config } from "@fosscord/util";

import { Router, Request, Response } from "express";
import { route } from "@fosscord/api";
import { Like } from "typeorm";

const router = Router();

router.get("/", route({}), async (req: Request, res: Response) => {
	const { offset, limit, categories } = req.query;
	var showAllGuilds = Config.get().guild.discovery.showAllGuilds;
	var configLimit = Config.get().guild.discovery.limit;
	// ! this only works using SQL querys
	// TODO: implement this with default typeorm query
	// const guilds = await Guild.find({ where: { features: "DISCOVERABLE" } }); //, take: Math.abs(Number(limit)) });
	let guilds;
	if (categories == undefined) {
		guilds = showAllGuilds
			? await Guild.find({ take: Math.abs(Number(limit || configLimit)) })
			: await Guild.find({ where: { features: Like(`%DISCOVERABLE%`) }, take: Math.abs(Number(limit || configLimit)) });
	} else {
		guilds = showAllGuilds
			? await Guild.find({ where: { primary_category_id: categories.toString() }, take: Math.abs(Number(limit || configLimit)) })
			: await Guild.find({
				where: { primary_category_id: categories.toString(), features: Like("%DISCOVERABLE%") },
				take: Math.abs(Number(limit || configLimit))
			});
	}

	const total = guilds ? guilds.length : undefined;

	res.send({ total: total, guilds: guilds, offset: Number(offset || Config.get().guild.discovery.offset), limit: Number(limit || configLimit) });
});

export default router;