a bunch of bug fixes and improvements
This commit is contained in:
47
server/api/user/[id]/[guildId]/profile.get.ts
Normal file
47
server/api/user/[id]/[guildId]/profile.get.ts
Normal file
@@ -0,0 +1,47 @@
|
||||
import { IServer } from '~/types';
|
||||
import { PrismaClient } from '@prisma/client';
|
||||
const prisma = new PrismaClient();
|
||||
|
||||
export default defineEventHandler(async (event) => {
|
||||
if (!event.context.user.authenticated) {
|
||||
throw createError({
|
||||
statusCode: 401,
|
||||
statusMessage: 'You must be logged in to view a user in a guild.',
|
||||
});
|
||||
}
|
||||
|
||||
if (!event.context.params?.id || !event.context.params?.guildId) {
|
||||
throw createError({
|
||||
statusCode: 400,
|
||||
statusMessage: 'A userId or guildId is required',
|
||||
});
|
||||
}
|
||||
|
||||
const { id: userId, guildId } = event.context.params;
|
||||
|
||||
if (!userId || !guildId) throw new Error('id or guild id missing on a dynamic route?');
|
||||
|
||||
const user = await prisma.user.findFirst({
|
||||
where: {
|
||||
id: userId,
|
||||
},
|
||||
select: {
|
||||
id: true,
|
||||
username: true,
|
||||
roles: {
|
||||
where: {
|
||||
serverId: guildId,
|
||||
},
|
||||
select: {
|
||||
id: true,
|
||||
name: true,
|
||||
administrator: true,
|
||||
owner: true,
|
||||
},
|
||||
},
|
||||
createdAt: true,
|
||||
},
|
||||
});
|
||||
|
||||
return user;
|
||||
});
|
||||
35
server/api/user/[id]/profile.get.ts
Normal file
35
server/api/user/[id]/profile.get.ts
Normal file
@@ -0,0 +1,35 @@
|
||||
import { PrismaClient } from '@prisma/client';
|
||||
const prisma = new PrismaClient();
|
||||
|
||||
export default defineEventHandler(async (event) => {
|
||||
if (!event.context.user.authenticated) {
|
||||
throw createError({
|
||||
statusCode: 401,
|
||||
statusMessage: 'You must be logged in to view a user in a guild.',
|
||||
});
|
||||
}
|
||||
|
||||
if (!event.context.params?.id) {
|
||||
throw createError({
|
||||
statusCode: 400,
|
||||
statusMessage: 'A userId is required',
|
||||
});
|
||||
}
|
||||
|
||||
const { id: userId } = event.context.params;
|
||||
|
||||
if (!userId) throw new Error('id missing on a dynamic route?');
|
||||
|
||||
const user = await prisma.user.findFirst({
|
||||
where: {
|
||||
id: userId,
|
||||
},
|
||||
select: {
|
||||
id: true,
|
||||
username: true,
|
||||
createdAt: true,
|
||||
},
|
||||
});
|
||||
|
||||
return user;
|
||||
});
|
||||
Reference in New Issue
Block a user