fix(user): add user role update

This commit is contained in:
OxSaitama 2023-07-25 15:24:21 +02:00
parent 109c8438c0
commit f7bc4e58d6
4 changed files with 98 additions and 26 deletions

View File

@ -1,5 +1,5 @@
import { Response, Request } from "express"; import { Response, Request } from "express";
import { Controller, Get } from "@ControllerPattern/index"; import { Controller, Get, Put } from "@ControllerPattern/index";
import ApiController from "@Common/system/controller-pattern/ApiController"; import ApiController from "@Common/system/controller-pattern/ApiController";
import UsersService from "@Services/admin/UsersService/UsersService"; import UsersService from "@Services/admin/UsersService/UsersService";
import { Service } from "typedi"; import { Service } from "typedi";
@ -8,6 +8,7 @@ import { Prisma } from "@prisma/client";
import authHandler from "@App/middlewares/AuthHandler"; import authHandler from "@App/middlewares/AuthHandler";
import ruleHandler from "@App/middlewares/RulesHandler"; import ruleHandler from "@App/middlewares/RulesHandler";
import userHandler from "@App/middlewares/OfficeMembershipHandlers/UserHandler"; import userHandler from "@App/middlewares/OfficeMembershipHandlers/UserHandler";
import { validateOrReject } from "class-validator";
@Controller() @Controller()
@Service() @Service()
@ -61,6 +62,47 @@ export default class UsersController extends ApiController {
} }
} }
/**
* @description Modify a specific user by uid
*/
@Put("/api/v1/admin/users/:uid", [authHandler, ruleHandler])
protected async put(req: Request, response: Response) {
try {
const uid = req.params["uid"];
if (!uid) {
this.httpBadRequest(response, "No uid provided");
return;
}
const userFound = await this.usersService.getByUid(uid);
if (!userFound) {
this.httpNotFoundRequest(response, "user not found");
return;
}
//init IUser resource with request body values
const userEntity = User.hydrate<User>(req.body);
//validate user
await validateOrReject(userEntity, { groups: ["updateUser"] });
//call service to get prisma entity
const userEntityUpdated = await this.usersService.update(uid, userEntity);
//Hydrate ressource with prisma entity
const user = User.hydrate<User>(userEntityUpdated, {
strategy: "excludeAll",
});
//success
this.httpSuccess(response, user);
} catch (error) {
this.httpInternalError(response, error);
return;
}
}
/** /**
* @description Get a specific user by uid * @description Get a specific user by uid
*/ */

View File

@ -106,7 +106,7 @@ export default class UsersController extends ApiController {
const userEntity = User.hydrate<User>(req.body); const userEntity = User.hydrate<User>(req.body);
//validate user //validate user
await validateOrReject(userEntity, { groups: ["update"] }); await validateOrReject(userEntity, { groups: ["updateUser"] });
//call service to get prisma entity //call service to get prisma entity
const userEntityUpdated = await this.usersService.update(uid, userEntity); const userEntityUpdated = await this.usersService.update(uid, userEntity);

View File

@ -94,30 +94,11 @@ export default class UsersRepository extends BaseRepository {
}, },
data: { data: {
idNot: user.idNot, idNot: user.idNot,
office_membership: {
connectOrCreate: {
where: {
idNot: user.office_membership!.idNot,
},
create: {
idNot: user.office_membership!.idNot,
name: user.office_membership!.name,
crpcen: user.office_membership!.crpcen,
address: {
create: {
address: user.office_membership!.address!.address,
zip_code: user.office_membership!.address!.zip_code,
city: user.office_membership!.address!.city,
},
},
},
},
},
contact: { contact: {
update: { update: {
first_name: user.contact!.first_name, first_name: user.contact?.first_name,
last_name: user.contact!.last_name, last_name: user.contact?.last_name,
email: user.contact!.email, email: user.contact?.email,
phone_number: user.contact?.phone_number, phone_number: user.contact?.phone_number,
cell_phone_number: user.contact?.cell_phone_number, cell_phone_number: user.contact?.cell_phone_number,
civility: ECivility[user.contact?.civility as keyof typeof ECivility], civility: ECivility[user.contact?.civility as keyof typeof ECivility],
@ -125,6 +106,15 @@ export default class UsersRepository extends BaseRepository {
}, },
}, },
}; };
if(user.office_membership) {
updateArgs.data.office_membership = {
connect: {
idNot: user.office_membership?.idNot,
},
};
}
if (user.contact?.address) { if (user.contact?.address) {
updateArgs.data.contact!.update!.address!.update = { updateArgs.data.contact!.update!.address!.update = {
address: user.contact?.address?.address, address: user.contact?.address?.address,
@ -132,13 +122,53 @@ export default class UsersRepository extends BaseRepository {
city: user.contact?.address?.city, city: user.contact?.address?.city,
}; };
} }
if (user.office_role) {
if(user.office_role) {
updateArgs.data.office_role = { updateArgs.data.office_role = {
connect: { connect: {
uid: user.office_role.uid, uid: user.office_role.uid,
}, },
}; };
} }
if(user.role) {
updateArgs.data.role = {
connect: {
uid: user.role.uid,
},
};
}
return this.model.update({ ...updateArgs, include: { contact: true, office_membership: { include: { address: true } } } });
}
/**
* @description : Update role from a user
*/
public async updateRole(uid: string, user: User): Promise<Users> {
const updateArgs: Prisma.UsersUpdateArgs = {
where: {
uid: uid,
},
data: {}
};
if(user.office_role) {
updateArgs.data.office_role = {
connect: {
uid: user.office_role.uid,
},
};
}
if(user.role) {
updateArgs.data.role = {
connect: {
uid: user.role.uid,
},
};
}
return this.model.update({ ...updateArgs, include: { contact: true, office_membership: { include: { address: true } } } }); return this.model.update({ ...updateArgs, include: { contact: true, office_membership: { include: { address: true } } } });
} }

View File

@ -32,7 +32,7 @@ export default class UsersService extends BaseService {
* @throws {Error} If user modification failed * @throws {Error} If user modification failed
*/ */
public update(uid: string, userEntity: User): Promise<Users> { public update(uid: string, userEntity: User): Promise<Users> {
return this.userRepository.update(uid, userEntity); return this.userRepository.updateRole(uid, userEntity);
} }
/** /**