public function updatePolicy(APIPolicy $policy, APIPolicyUpdateStruct $policyUpdateStruct)
{
if (!is_string($policy->module)) {
throw new InvalidArgumentValue('module', $policy->module, 'Policy');
}
if (!is_string($policy->function)) {
throw new InvalidArgumentValue('function', $policy->function, 'Policy');
}
if ($this->repository->hasAccess('role', 'update') !== true) {
throw new UnauthorizedException('role', 'update');
}
$limitations = $policyUpdateStruct->getLimitations();
$limitationValidationErrors = $this->validatePolicy($policy->module, $policy->function, $limitations);
if (!empty($limitationValidationErrors)) {
throw new LimitationValidationException($limitationValidationErrors);
}
$spiPolicy = $this->roleDomainMapper->buildPersistencePolicyObject($policy->module, $policy->function, $limitations);
$spiPolicy->id = $policy->id;
$spiPolicy->roleId = $policy->roleId;
$this->repository->beginTransaction();
try {
$this->userHandler->updatePolicy($spiPolicy);
$this->repository->commit();
} catch (Exception $e) {
$this->repository->rollback();
throw $e;
}
return $this->roleDomainMapper->buildDomainPolicyObject($spiPolicy);
}