Merge pull request #1182 from DEVTomatoCake/fix/msg-update-pinned
Send "pinned" as "true" in pins update event
This commit is contained in:
commit
f7f16db37e
@ -1,24 +1,23 @@
|
|||||||
/*
|
/*
|
||||||
Spacebar: A FOSS re-implementation and extension of the Discord.com backend.
|
Spacebar: A FOSS re-implementation and extension of the Discord.com backend.
|
||||||
Copyright (C) 2023 Spacebar and Spacebar Contributors
|
Copyright (C) 2023 Spacebar and Spacebar Contributors
|
||||||
|
|
||||||
This program is free software: you can redistribute it and/or modify
|
This program is free software: you can redistribute it and/or modify
|
||||||
it under the terms of the GNU Affero General Public License as published
|
it under the terms of the GNU Affero General Public License as published
|
||||||
by the Free Software Foundation, either version 3 of the License, or
|
by the Free Software Foundation, either version 3 of the License, or
|
||||||
(at your option) any later version.
|
(at your option) any later version.
|
||||||
|
|
||||||
This program is distributed in the hope that it will be useful,
|
This program is distributed in the hope that it will be useful,
|
||||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
GNU Affero General Public License for more details.
|
GNU Affero General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU Affero General Public License
|
You should have received a copy of the GNU Affero General Public License
|
||||||
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { route } from "@spacebar/api";
|
import { route } from "@spacebar/api";
|
||||||
import {
|
import {
|
||||||
Channel,
|
|
||||||
ChannelPinsUpdateEvent,
|
ChannelPinsUpdateEvent,
|
||||||
Config,
|
Config,
|
||||||
DiscordApiErrors,
|
DiscordApiErrors,
|
||||||
@ -60,8 +59,10 @@ router.put(
|
|||||||
if (pinned_count >= maxPins)
|
if (pinned_count >= maxPins)
|
||||||
throw DiscordApiErrors.MAXIMUM_PINS.withParams(maxPins);
|
throw DiscordApiErrors.MAXIMUM_PINS.withParams(maxPins);
|
||||||
|
|
||||||
|
message.pinned = true;
|
||||||
|
|
||||||
await Promise.all([
|
await Promise.all([
|
||||||
Message.update({ id: message_id }, { pinned: true }),
|
message.save(),
|
||||||
emitEvent({
|
emitEvent({
|
||||||
event: "MESSAGE_UPDATE",
|
event: "MESSAGE_UPDATE",
|
||||||
channel_id,
|
channel_id,
|
||||||
@ -98,31 +99,27 @@ router.delete(
|
|||||||
async (req: Request, res: Response) => {
|
async (req: Request, res: Response) => {
|
||||||
const { channel_id, message_id } = req.params;
|
const { channel_id, message_id } = req.params;
|
||||||
|
|
||||||
const channel = await Channel.findOneOrFail({
|
|
||||||
where: { id: channel_id },
|
|
||||||
});
|
|
||||||
if (channel.guild_id) req.permission?.hasThrow("MANAGE_MESSAGES");
|
|
||||||
|
|
||||||
const message = await Message.findOneOrFail({
|
const message = await Message.findOneOrFail({
|
||||||
where: { id: message_id },
|
where: { id: message_id },
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (message.guild_id) req.permission?.hasThrow("MANAGE_MESSAGES");
|
||||||
|
|
||||||
message.pinned = false;
|
message.pinned = false;
|
||||||
|
|
||||||
await Promise.all([
|
await Promise.all([
|
||||||
message.save(),
|
message.save(),
|
||||||
|
|
||||||
emitEvent({
|
emitEvent({
|
||||||
event: "MESSAGE_UPDATE",
|
event: "MESSAGE_UPDATE",
|
||||||
channel_id,
|
channel_id,
|
||||||
data: message,
|
data: message,
|
||||||
} as MessageUpdateEvent),
|
} as MessageUpdateEvent),
|
||||||
|
|
||||||
emitEvent({
|
emitEvent({
|
||||||
event: "CHANNEL_PINS_UPDATE",
|
event: "CHANNEL_PINS_UPDATE",
|
||||||
channel_id,
|
channel_id,
|
||||||
data: {
|
data: {
|
||||||
channel_id,
|
channel_id,
|
||||||
guild_id: channel.guild_id,
|
guild_id: message.guild_id,
|
||||||
last_pin_timestamp: undefined,
|
last_pin_timestamp: undefined,
|
||||||
},
|
},
|
||||||
} as ChannelPinsUpdateEvent),
|
} as ChannelPinsUpdateEvent),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user