-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathConformite.php
More file actions
99 lines (87 loc) · 3.63 KB
/
Conformite.php
File metadata and controls
99 lines (87 loc) · 3.63 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<?php
namespace Qdequippe\Pappers\Api\Endpoint;
use Psr\Http\Message\ResponseInterface;
use Qdequippe\Pappers\Api\Exception\ConformiteBadRequestException;
use Qdequippe\Pappers\Api\Exception\ConformiteServiceUnavailableException;
use Qdequippe\Pappers\Api\Exception\ConformiteUnauthorizedException;
use Qdequippe\Pappers\Api\Model\ConformitePersonnePhysiqueGetResponse200;
use Qdequippe\Pappers\Api\Runtime\Client\BaseEndpoint;
use Qdequippe\Pappers\Api\Runtime\Client\Endpoint;
use Qdequippe\Pappers\Api\Runtime\Client\EndpointTrait;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Symfony\Component\Serializer\SerializerInterface;
class Conformite extends BaseEndpoint implements Endpoint
{
use EndpointTrait;
/**
* Cette route vérifie le statut de personne politiquement exposée et la présence de sanctions internationales pour une personne physique.
*
* Pour vérifier le statut de dirigeants et bénéficiaires effectifs d'entreprises, vous pouvez directement utiliser la route `/entreprise` avec les champs supplémentaires `personne_politiquement_exposee` et `sanctions`.
*
* @param array $queryParameters {
*
* @var string $nom Nom de la personne physique
* @var string $prenom Prénom de la personne physique
* @var string $date_de_naissance Date de naissance de la personne physique, au format AAAA-MM-JJ ou AAAA-MM
* }
*/
public function __construct(array $queryParameters = [])
{
$this->queryParameters = $queryParameters;
}
public function getMethod(): string
{
return 'GET';
}
public function getUri(): string
{
return '/conformite/personne_physique';
}
public function getBody(SerializerInterface $serializer, $streamFactory = null): array
{
return [[], null];
}
public function getExtraHeaders(): array
{
return ['Accept' => ['application/json']];
}
protected function getQueryOptionsResolver(): OptionsResolver
{
$optionsResolver = parent::getQueryOptionsResolver();
$optionsResolver->setDefined(['nom', 'prenom', 'date_de_naissance']);
$optionsResolver->setRequired(['nom', 'prenom', 'date_de_naissance']);
$optionsResolver->setDefaults([]);
$optionsResolver->addAllowedTypes('nom', ['string']);
$optionsResolver->addAllowedTypes('prenom', ['string']);
$optionsResolver->addAllowedTypes('date_de_naissance', ['string']);
return $optionsResolver;
}
/**
* @return ConformitePersonnePhysiqueGetResponse200|null
*
* @throws ConformiteBadRequestException
* @throws ConformiteUnauthorizedException
* @throws ConformiteServiceUnavailableException
*/
protected function transformResponseBody(ResponseInterface $response, SerializerInterface $serializer, ?string $contentType = null)
{
$status = $response->getStatusCode();
$body = (string) $response->getBody();
if ((null === $contentType) === false && (200 === $status && false !== mb_strpos(strtolower($contentType), 'application/json'))) {
return $serializer->deserialize($body, 'Qdequippe\Pappers\Api\Model\ConformitePersonnePhysiqueGetResponse200', 'json');
}
if (400 === $status) {
throw new ConformiteBadRequestException($response);
}
if (401 === $status) {
throw new ConformiteUnauthorizedException($response);
}
if (503 === $status) {
throw new ConformiteServiceUnavailableException($response);
}
}
public function getAuthenticationScopes(): array
{
return ['apiKey'];
}
}