Create roles.ts
This commit is contained in:
		
							parent
							
								
									63b81db2a2
								
							
						
					
					
						commit
						7080cc65ed
					
				
							
								
								
									
										49
									
								
								src/routes/guilds/#guild_id/roles.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								src/routes/guilds/#guild_id/roles.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,49 @@ | ||||
| import { Request, Response, Router } from "express"; | ||||
| import { RoleModel, GuildModel, getPermission, toObject, UserModel, Snowflake, MemberModel } from "@fosscord/server-util"; | ||||
| import { HTTPError } from "lambert-server"; | ||||
| import { emitEvent } from "../../../util/Event"; | ||||
| import { check } from "../../../util/instanceOf"; | ||||
| import { RoleCreateSchema } from "../../../schema/Roles"; | ||||
| import { getPublicUser } from "../../../util/User"; | ||||
| 
 | ||||
| const router: Router = Router(); | ||||
| 
 | ||||
| router.get("/", async (req: Request, res: Response) => { | ||||
| 	const guild_id = req.params.id; | ||||
| 
 | ||||
| 	const guild = await GuildModel.exists({ id: guild_id }); | ||||
| 	if (!guild) throw new HTTPError("Guild not found", 404); | ||||
| 
 | ||||
| 	var roles = await RoleModel.find({ guild_id: guild_id }).exec(); | ||||
| 	return res.json(toObject(roles)); | ||||
| }); | ||||
| 
 | ||||
| router.post("/", check(RoleCreateSchema), async (req: Request, res: Response) => { | ||||
| 
 | ||||
|     const guild_id = req.params.guild_id; | ||||
|     const body = req.body as RoleCreateSchema; | ||||
| 
 | ||||
| 	const guild = await GuildModel.findOne({ id: guild_id }, { id: true }).exec(); | ||||
| 	if (!guild) throw new HTTPError("Guild not found", 404); | ||||
| 
 | ||||
| 	const user = await UserModel.findOne({ id: req.user_id }).exec(); | ||||
| 	if (!user) throw new HTTPError("User not found", 404); | ||||
| 
 | ||||
| 	const perms = await getPermission(req.user_id, guild_id); | ||||
| 
 | ||||
| 	if (!perms.has("MANAGE_ROLES")) | ||||
| 		throw new HTTPError("You missing the MANAGE_ROLES permission", 401); | ||||
| 
 | ||||
| 	const role_id = Snowflake.generate(); | ||||
| 
 | ||||
| 	var role = { | ||||
| 		...body, | ||||
| 		id: role_id, | ||||
| 	} | ||||
| 
 | ||||
| 	const roleNew = await new RoleModel(role).save(); | ||||
| 
 | ||||
| 	res.json(toObject(roleNew)).send(); | ||||
| }); | ||||
| 
 | ||||
| export default router; | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Intevel ツ
						Intevel ツ