feat: Filter user listings by deactivation status, include a total count in the response, and simplify account activation to use user ID directly.
This commit is contained in:
parent
000de75dd1
commit
8960e90dbd
2 changed files with 9 additions and 6 deletions
|
|
@ -18,15 +18,20 @@ export class UserManagementService {
|
||||||
async listUsers(): Promise<ListUsersResponse> {
|
async listUsers(): Promise<ListUsersResponse> {
|
||||||
try {
|
try {
|
||||||
const users = await prisma.user.findMany({
|
const users = await prisma.user.findMany({
|
||||||
|
where: {
|
||||||
|
is_deactivated: false
|
||||||
|
},
|
||||||
include: {
|
include: {
|
||||||
profile: true,
|
profile: true,
|
||||||
role: true
|
role: true,
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
return {
|
return {
|
||||||
code: 200,
|
code: 200,
|
||||||
message: 'Users fetched successfully',
|
message: 'Users fetched successfully',
|
||||||
|
total: users.length,
|
||||||
data: users.map(user => this.formatUserResponse(user))
|
data: users.map(user => this.formatUserResponse(user))
|
||||||
};
|
};
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
|
|
@ -138,12 +143,9 @@ export class UserManagementService {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async activateAccount(token: string): Promise<ActivateAccountResponse> {
|
async activateAccount(id: number): Promise<ActivateAccountResponse> {
|
||||||
try {
|
try {
|
||||||
// Decode JWT token to get user ID
|
const user = await prisma.user.findUnique({ where: { id } });
|
||||||
const decoded = jwt.verify(token, config.jwt.secret) as { id: number; username: string; email: string; roleCode: string };
|
|
||||||
|
|
||||||
const user = await prisma.user.findUnique({ where: { id: decoded.id } });
|
|
||||||
if (!user) throw new UnauthorizedError('User not found');
|
if (!user) throw new UnauthorizedError('User not found');
|
||||||
|
|
||||||
// Check if account is already activated
|
// Check if account is already activated
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,7 @@ import { ProfileUpdate, UserResponse } from "./user.types";
|
||||||
export interface ListUsersResponse {
|
export interface ListUsersResponse {
|
||||||
code: number;
|
code: number;
|
||||||
message: string;
|
message: string;
|
||||||
|
total: number;
|
||||||
data: UserResponse[] | null;
|
data: UserResponse[] | null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue