fix: customer edit not consider related branch perm
This commit is contained in:
parent
a32ed2ea2c
commit
71a8a25cda
1 changed files with 30 additions and 10 deletions
|
|
@ -432,7 +432,15 @@ export class CustomerController extends Controller {
|
||||||
where: { id: customerId },
|
where: { id: customerId },
|
||||||
include: {
|
include: {
|
||||||
registeredBranch: {
|
registeredBranch: {
|
||||||
include: { user: { where: { userId: req.user.sub } } },
|
include: {
|
||||||
|
headOffice: {
|
||||||
|
include: {
|
||||||
|
branch: { where: { user: { some: { userId: req.user.sub } } } },
|
||||||
|
user: { where: { userId: req.user.sub } },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
user: { where: { userId: req.user.sub } },
|
||||||
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
@ -441,15 +449,27 @@ export class CustomerController extends Controller {
|
||||||
throw new HttpError(HttpStatus.NOT_FOUND, "Customer cannot be found.", "customerNotFound");
|
throw new HttpError(HttpStatus.NOT_FOUND, "Customer cannot be found.", "customerNotFound");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (
|
if (!isSystem(req.user)) {
|
||||||
!globalAllow(req.user) &&
|
if (!globalAllow(req.user) && record.registeredBranch?.user.length === 0) {
|
||||||
(!record.registeredBranch || record.registeredBranch.user.length === 0)
|
throw new HttpError(
|
||||||
) {
|
HttpStatus.FORBIDDEN,
|
||||||
throw new HttpError(
|
"You do not have permission to perform this action.",
|
||||||
HttpStatus.FORBIDDEN,
|
"noPermission",
|
||||||
"You do not have permission to perform this action.",
|
);
|
||||||
"noPermission",
|
} else {
|
||||||
);
|
if (
|
||||||
|
(record.registeredBranch?.user.length === 0 && !record.registeredBranch?.headOffice) ||
|
||||||
|
(record.registeredBranch?.headOffice &&
|
||||||
|
record.registeredBranch?.headOffice.user.length === 0 &&
|
||||||
|
record.registeredBranch?.headOffice.branch.length === 0)
|
||||||
|
) {
|
||||||
|
throw new HttpError(
|
||||||
|
HttpStatus.FORBIDDEN,
|
||||||
|
"You do not have permission to perform this action.",
|
||||||
|
"noPermission",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (record.status !== Status.CREATED) {
|
if (record.status !== Status.CREATED) {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue