1 | <?php |
||
18 | class JWESerializerManager |
||
19 | { |
||
20 | /** |
||
21 | * @var JWESerializer[] |
||
22 | */ |
||
23 | private $serializers = []; |
||
24 | |||
25 | /** |
||
26 | * JWESerializerManager constructor. |
||
27 | * |
||
28 | * @param JWESerializer[] $serializers |
||
29 | */ |
||
30 | private function __construct(array $serializers) |
||
36 | |||
37 | /** |
||
38 | * Creates a serializer manager using the given serializers. |
||
39 | * |
||
40 | * @param JWESerializer[] $serializers |
||
41 | * |
||
42 | * @return JWESerializerManager |
||
43 | */ |
||
44 | public static function create(array $serializers): self |
||
48 | |||
49 | /** |
||
50 | * Adds a serializer to the manager. |
||
51 | * |
||
52 | * @param JWESerializer $serializer |
||
53 | * |
||
54 | * @return JWESerializerManager |
||
55 | */ |
||
56 | private function add(JWESerializer $serializer): self |
||
62 | |||
63 | /** |
||
64 | * Return the serializer names supported by the manager. |
||
65 | * |
||
66 | * @deprecated Will be removed in v2.0. Please use names() instead. |
||
67 | * |
||
68 | * @return string[] |
||
69 | */ |
||
70 | public function list(): array |
||
74 | |||
75 | /** |
||
76 | * Return the serializer names supported by the manager. |
||
77 | * |
||
78 | * @return string[] |
||
79 | */ |
||
80 | public function names(): array |
||
84 | |||
85 | /** |
||
86 | * Converts a JWE into a string. |
||
87 | * Throws an exception if none of the serializer was able to convert the input. |
||
88 | * |
||
89 | * @param string $name |
||
90 | * @param JWE $jws |
||
91 | * @param int|null $recipientIndex |
||
92 | * |
||
93 | * @throws \Exception |
||
94 | * |
||
95 | * @return string |
||
96 | */ |
||
97 | public function serialize(string $name, JWE $jws, ?int $recipientIndex = null): string |
||
105 | |||
106 | /** |
||
107 | * Loads data and return a JWE object. |
||
108 | * Throws an exception if none of the serializer was able to convert the input. |
||
109 | * |
||
110 | * @param string $input A string that represents a JWE |
||
111 | * @param string|null $name the name of the serializer if the input is unserialized |
||
112 | * |
||
113 | * @throws \Exception |
||
114 | * |
||
115 | * @return JWE |
||
116 | */ |
||
117 | public function unserialize(string $input, ?string &$name = null): JWE |
||
132 | } |
||
133 |