mirror of
https://github.com/spacebarchat/server.git
synced 2024-11-13 14:12:41 +01:00
Typing + create pin + get pin
This commit is contained in:
parent
da711d037d
commit
a4ee68336e
14
package-lock.json
generated
14
package-lock.json
generated
@ -21,7 +21,7 @@
|
|||||||
"i18next-http-middleware": "^3.1.0",
|
"i18next-http-middleware": "^3.1.0",
|
||||||
"i18next-node-fs-backend": "^2.1.3",
|
"i18next-node-fs-backend": "^2.1.3",
|
||||||
"jsonwebtoken": "^8.5.1",
|
"jsonwebtoken": "^8.5.1",
|
||||||
"lambert-server": "^1.1.9",
|
"lambert-server": "^1.2.1",
|
||||||
"missing-native-js-functions": "^1.2.6",
|
"missing-native-js-functions": "^1.2.6",
|
||||||
"mongodb": "^3.6.4",
|
"mongodb": "^3.6.4",
|
||||||
"mongoose": "^5.12.3",
|
"mongoose": "^5.12.3",
|
||||||
@ -7622,9 +7622,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/lambert-server": {
|
"node_modules/lambert-server": {
|
||||||
"version": "1.1.9",
|
"version": "1.2.1",
|
||||||
"resolved": "https://registry.npmjs.org/lambert-server/-/lambert-server-1.1.9.tgz",
|
"resolved": "https://registry.npmjs.org/lambert-server/-/lambert-server-1.2.1.tgz",
|
||||||
"integrity": "sha512-LXiIB6m4nExFgn1Rsv+uuP0KoxHfStsNzxsud+8cajd2MgJlMARRxjuGdr7smhx1WftQWbU6g1jghFEYJ++9SQ==",
|
"integrity": "sha512-ApyFBSOLlhCcTOePIILgtBz5m3+4AGaQEiS9T35etwKcZt9yjHQmMUOXD49ELxV9RQk620LB2APIlB9MexeprQ==",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"body-parser": "^1.19.0",
|
"body-parser": "^1.19.0",
|
||||||
"express": "^4.17.1",
|
"express": "^4.17.1",
|
||||||
@ -18608,9 +18608,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"lambert-server": {
|
"lambert-server": {
|
||||||
"version": "1.1.9",
|
"version": "1.2.1",
|
||||||
"resolved": "https://registry.npmjs.org/lambert-server/-/lambert-server-1.1.9.tgz",
|
"resolved": "https://registry.npmjs.org/lambert-server/-/lambert-server-1.2.1.tgz",
|
||||||
"integrity": "sha512-LXiIB6m4nExFgn1Rsv+uuP0KoxHfStsNzxsud+8cajd2MgJlMARRxjuGdr7smhx1WftQWbU6g1jghFEYJ++9SQ==",
|
"integrity": "sha512-ApyFBSOLlhCcTOePIILgtBz5m3+4AGaQEiS9T35etwKcZt9yjHQmMUOXD49ELxV9RQk620LB2APIlB9MexeprQ==",
|
||||||
"requires": {
|
"requires": {
|
||||||
"body-parser": "^1.19.0",
|
"body-parser": "^1.19.0",
|
||||||
"express": "^4.17.1",
|
"express": "^4.17.1",
|
||||||
|
@ -42,7 +42,7 @@
|
|||||||
"i18next-http-middleware": "^3.1.0",
|
"i18next-http-middleware": "^3.1.0",
|
||||||
"i18next-node-fs-backend": "^2.1.3",
|
"i18next-node-fs-backend": "^2.1.3",
|
||||||
"jsonwebtoken": "^8.5.1",
|
"jsonwebtoken": "^8.5.1",
|
||||||
"lambert-server": "^1.1.9",
|
"lambert-server": "^1.2.1",
|
||||||
"missing-native-js-functions": "^1.2.6",
|
"missing-native-js-functions": "^1.2.6",
|
||||||
"mongodb": "^3.6.4",
|
"mongodb": "^3.6.4",
|
||||||
"mongoose": "^5.12.3",
|
"mongoose": "^5.12.3",
|
||||||
|
@ -1,5 +1,37 @@
|
|||||||
import { Router } from "express";
|
import { ChannelModel, getPermission, MessageModel, toObject } from "@fosscord/server-util";
|
||||||
const router: Router = Router();
|
import { Router, Request, Response } from "express";
|
||||||
// TODO:
|
import Config from "../../../util/Config"
|
||||||
|
import { HTTPError } from "lambert-server";
|
||||||
|
|
||||||
|
const router: Router = Router();
|
||||||
|
|
||||||
|
router.put("/:message_id", async (req: Request, res: Response) => {
|
||||||
|
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")
|
||||||
|
permission.hasThrow("MANAGE_MESSAGES")
|
||||||
|
|
||||||
|
const pinned_count = await MessageModel.count({ channel_id, pinned: true }).exec()
|
||||||
|
const { maxPins } = Config.get().limits.channel
|
||||||
|
if (pinned_count >= maxPins) throw new HTTPError("Max pin count reached: " + maxPins)
|
||||||
|
|
||||||
|
await MessageModel.updateOne({ id: message_id }, { pinned: true }).exec()
|
||||||
|
|
||||||
|
res.sendStatus(204)
|
||||||
|
});
|
||||||
|
|
||||||
|
router.get("/", async (req: Request, res: Response) => {
|
||||||
|
const { channel_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")
|
||||||
|
|
||||||
|
let pins = await MessageModel.find({ channel_id: channel_id, pinned: true }).exec()
|
||||||
|
|
||||||
|
res.send(toObject(pins))
|
||||||
|
});
|
||||||
export default router;
|
export default router;
|
||||||
|
@ -1,5 +1,34 @@
|
|||||||
import { Router } from "express";
|
import { ChannelModel, MemberModel, toObject, TypingStartEvent } from "@fosscord/server-util";
|
||||||
|
import { Router, Request, Response } from "express";
|
||||||
|
|
||||||
|
import { HTTPError } from "lambert-server";
|
||||||
|
import { emitEvent } from "../../../util/Event";
|
||||||
|
|
||||||
const router: Router = Router();
|
const router: Router = Router();
|
||||||
// TODO:
|
|
||||||
|
router.post("/", async (req: Request, res: Response) => {
|
||||||
|
const { channel_id } = req.params;
|
||||||
|
const user_id = req.user_id;
|
||||||
|
const timestamp = Date.now()
|
||||||
|
const channel = await ChannelModel.findOne({ id: channel_id });
|
||||||
|
if (!channel) throw new HTTPError("Channel not found", 404)
|
||||||
|
const member = await MemberModel.findOne({ id: user_id }).exec()
|
||||||
|
if (!member) throw new HTTPError("Member not found", 404)
|
||||||
|
|
||||||
|
|
||||||
|
await emitEvent({
|
||||||
|
event: "TYPING_START",
|
||||||
|
channel_id: channel_id,
|
||||||
|
guild_id: channel.guild_id,
|
||||||
|
data: { // this is the paylod
|
||||||
|
member: toObject(member),
|
||||||
|
channel_id,
|
||||||
|
timestamp,
|
||||||
|
user_id,
|
||||||
|
guild_id: channel.guild_id
|
||||||
|
}
|
||||||
|
} as TypingStartEvent)
|
||||||
|
res.sendStatus(204)
|
||||||
|
});
|
||||||
|
|
||||||
export default router;
|
export default router;
|
||||||
|
Loading…
Reference in New Issue
Block a user