✨ Message Pins
This commit is contained in:
		
							parent
							
								
									350b932ef6
								
							
						
					
					
						commit
						f435d33da1
					
				| @ -1,10 +1,10 @@ | |||||||
| import { ChannelModel, getPermission, MessageModel, toObject } from "@fosscord/server-util"; | import { ChannelModel, ChannelPinsUpdateEvent, getPermission, MessageModel, MessageUpdateEvent, toObject } from "@fosscord/server-util"; | ||||||
| import { Router, Request, Response } from "express"; | import { Router, Request, Response } from "express"; | ||||||
| import Config from "../../../util/Config"; | import Config from "../../../util/Config"; | ||||||
| import { HTTPError } from "lambert-server"; | import { HTTPError } from "lambert-server"; | ||||||
|  | import { emitEvent } from "../../../util/Event"; | ||||||
| 
 | 
 | ||||||
| const router: Router = Router(); | const router: Router = Router(); | ||||||
| 
 |  | ||||||
| // TODO: auto throw error if findOne doesn't find anything
 | // TODO: auto throw error if findOne doesn't find anything
 | ||||||
| 
 | 
 | ||||||
| router.put("/:message_id", async (req: Request, res: Response) => { | router.put("/:message_id", async (req: Request, res: Response) => { | ||||||
| @ -22,6 +22,59 @@ router.put("/:message_id", async (req: Request, res: Response) => { | |||||||
| 	if (pinned_count >= maxPins) throw new HTTPError("Max pin count reached: " + maxPins); | 	if (pinned_count >= maxPins) throw new HTTPError("Max pin count reached: " + maxPins); | ||||||
| 
 | 
 | ||||||
| 	await MessageModel.updateOne({ id: message_id }, { pinned: true }).exec(); | 	await MessageModel.updateOne({ id: message_id }, { pinned: true }).exec(); | ||||||
|  | 	const message = toObject(await MessageModel.findOne({ id: message_id }).exec()); | ||||||
|  | 	if (!message) throw new HTTPError("Message not found", 404); | ||||||
|  | 
 | ||||||
|  | 	await emitEvent({ | ||||||
|  | 		event: "MESSAGE_UPDATE", | ||||||
|  | 		channel_id, | ||||||
|  | 		guild_id: channel.guild_id, | ||||||
|  | 		data: message | ||||||
|  | 	} as MessageUpdateEvent); | ||||||
|  | 
 | ||||||
|  | 	await emitEvent({ | ||||||
|  | 		event: "CHANNEL_PINS_UPDATE", | ||||||
|  | 		channel_id, | ||||||
|  | 		guild_id: channel.guild_id, | ||||||
|  | 		data: { | ||||||
|  | 			channel_id, | ||||||
|  | 			guild_id: channel.guild_id, | ||||||
|  | 			last_pin_timestamp: undefined | ||||||
|  | 		} | ||||||
|  | 	} as ChannelPinsUpdateEvent); | ||||||
|  | 
 | ||||||
|  | 	res.sendStatus(204); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
|  | router.delete("/:message_id", async (req, res) => { | ||||||
|  | 	const { channel_id, message_id } = req.params; | ||||||
|  | 
 | ||||||
|  | 	const channel = await ChannelModel.findOne({ id: channel_id }).exec(); | ||||||
|  | 	if (!channel) throw new HTTPError("Channel not found", 404); | ||||||
|  | 
 | ||||||
|  | 	const permission = await getPermission(req.user_id, channel.guild_id, channel_id); | ||||||
|  | 	permission.hasThrow("VIEW_CHANNEL"); | ||||||
|  | 	if (channel.guild_id) permission.hasThrow("MANAGE_MESSAGES"); | ||||||
|  | 
 | ||||||
|  | 	const message = toObject(await MessageModel.findOneAndUpdate({ id: message_id }, { pinned: false }).exec()); | ||||||
|  | 
 | ||||||
|  | 	await emitEvent({ | ||||||
|  | 		event: "MESSAGE_UPDATE", | ||||||
|  | 		channel_id, | ||||||
|  | 		guild_id: channel.guild_id, | ||||||
|  | 		data: message | ||||||
|  | 	} as MessageUpdateEvent); | ||||||
|  | 
 | ||||||
|  | 	await emitEvent({ | ||||||
|  | 		event: "CHANNEL_PINS_UPDATE", | ||||||
|  | 		channel_id, | ||||||
|  | 		guild_id: channel.guild_id, | ||||||
|  | 		data: { | ||||||
|  | 			channel_id, | ||||||
|  | 			guild_id: channel.guild_id, | ||||||
|  | 			last_pin_timestamp: undefined | ||||||
|  | 		} | ||||||
|  | 	} as ChannelPinsUpdateEvent); | ||||||
| 
 | 
 | ||||||
| 	res.sendStatus(204); | 	res.sendStatus(204); | ||||||
| }); | }); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Flam3rboy
						Flam3rboy