small frontend rewrite
This commit is contained in:
@@ -1,113 +1,117 @@
|
||||
import { Server } from 'socket.io';
|
||||
import { PrismaClient } from '@prisma/client';
|
||||
import { IChannel, IServer, IUser, SafeUser } from '~~/types';
|
||||
import { Socket } from 'socket.io';
|
||||
const prisma = new PrismaClient();
|
||||
|
||||
export default defineEventHandler(({ node }) => {
|
||||
if (!global.io) {
|
||||
global.io = new Server(node.res.socket?.server);
|
||||
if (global.io) return;
|
||||
|
||||
global.io = new Server(node.res.socket?.server);
|
||||
|
||||
global.io.on('connection', async (socket) => {
|
||||
const token = socket.handshake.auth.token;
|
||||
if (!token) {
|
||||
return;
|
||||
}
|
||||
global.io.on('connection', async (socket: Socket) => {
|
||||
const token = socket.handshake.auth.token;
|
||||
|
||||
const { user } = await prisma.session.findFirst({
|
||||
where: {
|
||||
token
|
||||
},
|
||||
select: {
|
||||
user: {
|
||||
select: {
|
||||
id: true,
|
||||
username: true,
|
||||
servers: {
|
||||
select: {
|
||||
id: true,
|
||||
name: true,
|
||||
participants: {
|
||||
select: {
|
||||
id: true,
|
||||
username: true,
|
||||
roles: {
|
||||
select: {
|
||||
id: true,
|
||||
administrator: true,
|
||||
owner: true
|
||||
}
|
||||
if (!token) {
|
||||
socket.disconnect();
|
||||
return;
|
||||
}
|
||||
|
||||
const { user } = await prisma.session.findFirst({
|
||||
where: {
|
||||
token
|
||||
},
|
||||
select: {
|
||||
user: {
|
||||
select: {
|
||||
id: true,
|
||||
username: true,
|
||||
servers: {
|
||||
select: {
|
||||
id: true,
|
||||
name: true,
|
||||
participants: {
|
||||
select: {
|
||||
id: true,
|
||||
username: true,
|
||||
roles: {
|
||||
select: {
|
||||
id: true,
|
||||
administrator: true,
|
||||
owner: true
|
||||
}
|
||||
}
|
||||
},
|
||||
channels: {
|
||||
select: {
|
||||
id: true,
|
||||
DM: true,
|
||||
server: {
|
||||
select: {
|
||||
id: true,
|
||||
name: true,
|
||||
participants: {
|
||||
select: {
|
||||
id: true,
|
||||
username: true,
|
||||
roles: {
|
||||
select: {
|
||||
id: true,
|
||||
administrator: true,
|
||||
owner: true
|
||||
}
|
||||
}
|
||||
},
|
||||
channels: {
|
||||
select: {
|
||||
id: true,
|
||||
DM: true,
|
||||
server: {
|
||||
select: {
|
||||
id: true,
|
||||
name: true,
|
||||
participants: {
|
||||
select: {
|
||||
id: true,
|
||||
username: true,
|
||||
roles: {
|
||||
select: {
|
||||
id: true,
|
||||
administrator: true,
|
||||
owner: true
|
||||
}
|
||||
}
|
||||
},
|
||||
}
|
||||
}
|
||||
},
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
channels: {
|
||||
select: {
|
||||
id: true,
|
||||
DM: true,
|
||||
dmParticipants: {
|
||||
select: {
|
||||
id: true,
|
||||
username: true
|
||||
}
|
||||
},
|
||||
}
|
||||
}
|
||||
},
|
||||
channels: {
|
||||
select: {
|
||||
id: true,
|
||||
DM: true,
|
||||
dmParticipants: {
|
||||
select: {
|
||||
id: true,
|
||||
username: true
|
||||
}
|
||||
},
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}) as unknown as { user: IUser };
|
||||
}
|
||||
}) as unknown as { user: IUser };
|
||||
|
||||
if (!user) {
|
||||
if (!user) {
|
||||
socket.disconnect();
|
||||
return;
|
||||
}
|
||||
|
||||
socket.on('typing', async (ev) => {
|
||||
if (!ev) {
|
||||
return;
|
||||
}
|
||||
|
||||
socket.on('typing', async (ev) => {
|
||||
if (!ev) {
|
||||
let channel = user.channels?.find((c: IChannel) => c.id === ev) || user.servers?.find((s: IServer) => s.channels.some((c: IChannel) => c.id === ev));
|
||||
if (channel?.DM === undefined) {
|
||||
// assume its a server
|
||||
channel = channel?.channels.find((c: IChannel) => c.id === ev);
|
||||
}
|
||||
|
||||
if (!channel) return;
|
||||
|
||||
if (!channel.dmParticipants?.find((e: SafeUser) => e.id === user.id)) {
|
||||
if (!channel.server || !channel.server.participants.find((e: SafeUser) => e.id === user.id)) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
let channel = user.channels?.find((c: IChannel) => c.id === ev) || user.servers?.find((s: IServer) => s.channels.some((c: IChannel) => c.id === ev));
|
||||
if (channel?.DM === undefined) {
|
||||
// assume its a server
|
||||
channel = channel?.channels.find((c: IChannel) => c.id === ev);
|
||||
}
|
||||
|
||||
if (!channel) return;
|
||||
|
||||
if (!channel.dmParticipants?.find((e: SafeUser) => e.id === user.id)) {
|
||||
if (!channel.server || !channel.server.participants.find((e: SafeUser) => e.id === user.id)) {
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
global.io.emit(`typing-${channel.id}`, user.username);
|
||||
});
|
||||
global.io.emit(`typing-${channel.id}`, user.username);
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user