1 | <?php |
||
19 | class HeaderCheckerManager |
||
20 | { |
||
21 | /** |
||
22 | * @var HeaderChecker[] |
||
23 | */ |
||
24 | private $checkers = []; |
||
25 | |||
26 | /** |
||
27 | * @var TokenTypeSupport[] |
||
28 | */ |
||
29 | private $tokenTypes = []; |
||
30 | |||
31 | /** |
||
32 | * HeaderCheckerManager constructor. |
||
33 | * |
||
34 | * @param HeaderChecker[] $checkers |
||
35 | * @param TokenTypeSupport[] $tokenTypes |
||
36 | */ |
||
37 | public function __construct(array $checkers, array $tokenTypes) |
||
46 | |||
47 | /** |
||
48 | * This method returns all checkers handled by this manager. |
||
49 | * |
||
50 | * @return HeaderChecker[] |
||
51 | */ |
||
52 | public function getCheckers(): array |
||
56 | |||
57 | /** |
||
58 | * This method checks all the header parameters passed as argument. |
||
59 | * All header parameters are checked against the header parameter checkers. |
||
60 | * If one fails, the InvalidHeaderException is thrown. |
||
61 | * |
||
62 | * @param string[] $mandatoryHeaderParameters |
||
63 | * |
||
64 | * @throws InvalidArgumentException if the token format is not valid |
||
65 | */ |
||
66 | public function check(JWT $jwt, int $index, array $mandatoryHeaderParameters = []): void |
||
83 | |||
84 | private function addTokenTypeSupport(TokenTypeSupport $tokenType): void |
||
88 | |||
89 | private function add(HeaderChecker $checker): void |
||
94 | |||
95 | /** |
||
96 | * @throws InvalidArgumentException if the header contains duplicated entries |
||
97 | */ |
||
98 | private function checkDuplicatedHeaderParameters(array $header1, array $header2): void |
||
105 | |||
106 | /** |
||
107 | * @param string[] $mandatoryHeaderParameters |
||
108 | * |
||
109 | * @throws MissingMandatoryHeaderParameterException if a mandatory header parameter is missing |
||
110 | */ |
||
111 | private function checkMandatoryHeaderParameters(array $mandatoryHeaderParameters, array $protected, array $unprotected): void |
||
121 | |||
122 | /** |
||
123 | * @throws InvalidHeaderException if a protected header parameter is not in the protected header |
||
124 | */ |
||
125 | private function checkHeaders(array $protected, array $header): void |
||
148 | |||
149 | /** |
||
150 | * @throws InvalidHeaderException if the "crit" parameter is not valid or if a critical header parameter cannot be verified |
||
151 | */ |
||
152 | private function checkCriticalHeader(array $protected, array $header, array $checkedHeaderParameters): void |
||
166 | } |
||
167 |