| @@ 33-83 (lines=51) @@ | ||
| 30 | /** |
|
| 31 | * @SuppressWarnings(PHPMD.CouplingBetweenObjects) |
|
| 32 | */ |
|
| 33 | class RaSecondFactorService |
|
| 34 | { |
|
| 35 | /** |
|
| 36 | * @var LibraryRaSecondFactorService |
|
| 37 | */ |
|
| 38 | private $service; |
|
| 39 | ||
| 40 | /** |
|
| 41 | * @var ValidatorInterface |
|
| 42 | */ |
|
| 43 | private $validator; |
|
| 44 | ||
| 45 | /** |
|
| 46 | * @param LibraryRaSecondFactorService $service |
|
| 47 | * @param ValidatorInterface $validator |
|
| 48 | */ |
|
| 49 | public function __construct(LibraryRaSecondFactorService $service, ValidatorInterface $validator) |
|
| 50 | { |
|
| 51 | $this->service = $service; |
|
| 52 | $this->validator = $validator; |
|
| 53 | } |
|
| 54 | ||
| 55 | /** |
|
| 56 | * @param RaSecondFactorSearchQuery $query |
|
| 57 | * @return RaSecondFactorCollection |
|
| 58 | * @throws AccessDeniedToResourceException When the consumer isn't authorised to access given resource. |
|
| 59 | * @throws InvalidResponseException When the API responded with invalid data. |
|
| 60 | * @throws ResourceReadException When the API doesn't respond with the resource. |
|
| 61 | * @throws MalformedResponseException When the API doesn't respond with a proper response. |
|
| 62 | */ |
|
| 63 | public function search(RaSecondFactorSearchQuery $query) |
|
| 64 | { |
|
| 65 | $data = $this->service->search($query); |
|
| 66 | ||
| 67 | if ($data === null) { |
|
| 68 | return null; |
|
| 69 | } |
|
| 70 | ||
| 71 | $secondFactors = RaSecondFactorCollection::fromData($data); |
|
| 72 | $violations = $this->validator->validate($secondFactors); |
|
| 73 | ||
| 74 | if (count($violations) > 0) { |
|
| 75 | throw InvalidResponseException::withViolations( |
|
| 76 | "One or more second factors retrieved from the Middleware were invalid", |
|
| 77 | $violations |
|
| 78 | ); |
|
| 79 | } |
|
| 80 | ||
| 81 | return $secondFactors; |
|
| 82 | } |
|
| 83 | } |
|
| 84 | ||
| @@ 30-80 (lines=51) @@ | ||
| 27 | use Surfnet\StepupMiddlewareClientBundle\Identity\Dto\AuditLog; |
|
| 28 | use Symfony\Component\Validator\Validator\ValidatorInterface; |
|
| 29 | ||
| 30 | class AuditLogService |
|
| 31 | { |
|
| 32 | /** |
|
| 33 | * @var LibraryAuditLogService |
|
| 34 | */ |
|
| 35 | private $service; |
|
| 36 | ||
| 37 | /** |
|
| 38 | * @var ValidatorInterface |
|
| 39 | */ |
|
| 40 | private $validator; |
|
| 41 | ||
| 42 | /** |
|
| 43 | * @param LibraryAuditLogService $service |
|
| 44 | * @param ValidatorInterface $validator |
|
| 45 | */ |
|
| 46 | public function __construct(LibraryAuditLogService $service, ValidatorInterface $validator) |
|
| 47 | { |
|
| 48 | $this->service = $service; |
|
| 49 | $this->validator = $validator; |
|
| 50 | } |
|
| 51 | ||
| 52 | /** |
|
| 53 | * @param SecondFactorAuditLogSearchQuery $query |
|
| 54 | * @return AuditLog |
|
| 55 | * @throws AccessDeniedToResourceException When the consumer isn't authorised to access given resource. |
|
| 56 | * @throws InvalidResponseException When the API responded with invalid data. |
|
| 57 | * @throws ResourceReadException When the API doesn't respond with the resource. |
|
| 58 | * @throws MalformedResponseException When the API doesn't respond with a proper response. |
|
| 59 | */ |
|
| 60 | public function searchSecondFactorAuditLog(SecondFactorAuditLogSearchQuery $query) |
|
| 61 | { |
|
| 62 | $data = $this->service->searchSecondFactorAuditLog($query); |
|
| 63 | ||
| 64 | if ($data === null) { |
|
| 65 | return null; |
|
| 66 | } |
|
| 67 | ||
| 68 | $auditLog = AuditLog::fromData($data); |
|
| 69 | $violations = $this->validator->validate($auditLog); |
|
| 70 | ||
| 71 | if (count($violations) > 0) { |
|
| 72 | throw InvalidResponseException::withViolations( |
|
| 73 | "One or more audit log entries retrieved from the Middleware were invalid", |
|
| 74 | $violations |
|
| 75 | ); |
|
| 76 | } |
|
| 77 | ||
| 78 | return $auditLog; |
|
| 79 | } |
|
| 80 | } |
|
| 81 | ||
| @@ 26-63 (lines=38) @@ | ||
| 23 | use Surfnet\StepupMiddlewareClientBundle\Exception\InvalidResponseException; |
|
| 24 | use Symfony\Component\Validator\Validator\ValidatorInterface; |
|
| 25 | ||
| 26 | final class InstitutionConfigurationOptionsService |
|
| 27 | { |
|
| 28 | /** |
|
| 29 | * @var LibraryInstitutionConfigurationOptionsService |
|
| 30 | */ |
|
| 31 | private $service; |
|
| 32 | /** |
|
| 33 | * @var ValidatorInterface |
|
| 34 | */ |
|
| 35 | private $validator; |
|
| 36 | ||
| 37 | public function __construct(LibraryInstitutionConfigurationOptionsService $service, ValidatorInterface $validator) |
|
| 38 | { |
|
| 39 | $this->service = $service; |
|
| 40 | $this->validator = $validator; |
|
| 41 | } |
|
| 42 | ||
| 43 | /** |
|
| 44 | * @param $institution |
|
| 45 | * @return null|InstitutionConfigurationOptions |
|
| 46 | */ |
|
| 47 | public function getInstitutionConfigurationOptionsFor($institution) |
|
| 48 | { |
|
| 49 | $data = $this->service->getInstitutionConfigurationOptionsFor($institution); |
|
| 50 | ||
| 51 | if ($data === null) { |
|
| 52 | return null; |
|
| 53 | } |
|
| 54 | ||
| 55 | $institutionConfigurationOptions = InstitutionConfigurationOptions::fromData($data); |
|
| 56 | ||
| 57 | $violations = $this->validator->validate($institutionConfigurationOptions); |
|
| 58 | if (count($violations) > 0) { |
|
| 59 | throw InvalidResponseException::withViolations( |
|
| 60 | sprintf('Could not get institution configuration options for "%s": invalid response', $institution), |
|
| 61 | $violations |
|
| 62 | ); |
|
| 63 | } |
|
| 64 | ||
| 65 | return $institutionConfigurationOptions; |
|
| 66 | } |
|