add function for user
- create house - edit house - delete house - list all member for active house
This commit is contained in:
@@ -4,6 +4,7 @@ import { DB_TABLE, LOG_ACTION } from '@/types/enum';
|
||||
import { auth } from '@lib/auth';
|
||||
import { authMiddleware } from '@lib/middleware';
|
||||
import { createServerFn } from '@tanstack/react-start';
|
||||
import { getRequestHeaders } from '@tanstack/react-start/server';
|
||||
import { parseError } from '@utils/helper';
|
||||
import {
|
||||
baseHouse,
|
||||
@@ -43,6 +44,7 @@ export const getAllHouse = createServerFn({ method: 'GET' })
|
||||
role: true,
|
||||
user: {
|
||||
select: {
|
||||
id: true,
|
||||
name: true,
|
||||
email: true,
|
||||
image: true,
|
||||
@@ -74,6 +76,43 @@ export const getAllHouse = createServerFn({ method: 'GET' })
|
||||
}
|
||||
});
|
||||
|
||||
export const getCurrentUserHouses = createServerFn({ method: 'GET' })
|
||||
.middleware([authMiddleware])
|
||||
.handler(async ({ context: { user } }) => {
|
||||
try {
|
||||
const houses = await prisma.organization.findMany({
|
||||
where: { members: { some: { userId: user.id } } },
|
||||
orderBy: { createdAt: 'asc' },
|
||||
include: {
|
||||
_count: {
|
||||
select: {
|
||||
members: true,
|
||||
},
|
||||
},
|
||||
members: {
|
||||
select: {
|
||||
role: true,
|
||||
user: {
|
||||
select: {
|
||||
id: true,
|
||||
name: true,
|
||||
email: true,
|
||||
image: true,
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
});
|
||||
|
||||
return houses;
|
||||
} catch (error) {
|
||||
console.error(error);
|
||||
const { message, code } = parseError(error);
|
||||
throw { message, code };
|
||||
}
|
||||
});
|
||||
|
||||
export const createHouse = createServerFn({ method: 'POST' })
|
||||
.middleware([authMiddleware])
|
||||
.inputValidator(houseCreateBESchema)
|
||||
@@ -177,3 +216,40 @@ export const deleteHouse = createServerFn({ method: 'POST' })
|
||||
throw { message, code };
|
||||
}
|
||||
});
|
||||
|
||||
export const deleteUserHouse = createServerFn({ method: 'POST' })
|
||||
.middleware([authMiddleware])
|
||||
.inputValidator(baseHouse)
|
||||
.handler(async ({ data, context: { user } }) => {
|
||||
try {
|
||||
const currentHouse = await prisma.organization.findUnique({
|
||||
where: { id: data.id },
|
||||
});
|
||||
if (!currentHouse) throw Error('House not found');
|
||||
|
||||
const headers = getRequestHeaders();
|
||||
const result = await auth.api.deleteOrganization({
|
||||
body: {
|
||||
organizationId: data.id, // required
|
||||
},
|
||||
headers,
|
||||
});
|
||||
|
||||
if (result) {
|
||||
await createAuditLog({
|
||||
action: LOG_ACTION.DELETE,
|
||||
tableName: DB_TABLE.ORGANIZATION,
|
||||
recordId: result?.id,
|
||||
oldValue: JSON.stringify(currentHouse),
|
||||
newValue: '',
|
||||
userId: user.id,
|
||||
});
|
||||
}
|
||||
|
||||
return result;
|
||||
} catch (error) {
|
||||
console.error(error);
|
||||
const { message, code } = parseError(error);
|
||||
throw { message, code };
|
||||
}
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user