ILIAS  trunk Revision v11.0_alpha-2662-g519ff7d528f
ILIAS\FileDelivery\Token\SigningSerializer Class Reference
+ Collaboration diagram for ILIAS\FileDelivery\Token\SigningSerializer:

Public Member Functions

 __construct (private KeyRotatingSigner $signer, private Serializer $serializer, private Compression $compression, private Transport $transport)
 
 sign (Payload $payload, Salt $salt)
 
 verify (string $data, Salt $salt)
 

Private Attributes

const SEPARATOR = '<<>>'
 

Detailed Description

Author
Fabian Schmid fabia.nosp@m.n@sr.nosp@m..solu.nosp@m.tion.nosp@m.s

Definition at line 36 of file SigningSerializer.php.

Constructor & Destructor Documentation

◆ __construct()

ILIAS\FileDelivery\Token\SigningSerializer::__construct ( private KeyRotatingSigner  $signer,
private Serializer  $serializer,
private Compression  $compression,
private Transport  $transport 
)

Definition at line 43 of file SigningSerializer.php.

48  {
49  }

Member Function Documentation

◆ sign()

ILIAS\FileDelivery\Token\SigningSerializer::sign ( Payload  $payload,
Salt  $salt 
)

Definition at line 51 of file SigningSerializer.php.

References ILIAS\FileDelivery\Token\Signer\Payload\Payload\get(), and ILIAS\FileDelivery\Token\Signer\Payload\Payload\until().

51  : string
52  {
53  // serialize payload
54  $serialized_payload = $this->serializer->serializePayload($payload->get());
55  $serialized_validity = $this->serializer->serializeValidity($payload->until());
56  $signable_payload = $serialized_payload . self::SEPARATOR . $serialized_validity;
57 
58  // sign payload
59  $signature = $this->signer->sign($signable_payload, $salt);
60 
61  $signed_payload = $signable_payload . self::SEPARATOR . $signature;
62 
63  $compressed_payload = $this->compression->compress($signed_payload);
64 
65  $prepare_for_transport = $this->transport->prepareForTransport($compressed_payload);
66 
67  return $prepare_for_transport;
68  }
if(count($parts) !=3) $payload
Definition: ltitoken.php:67
+ Here is the call graph for this function:

◆ verify()

ILIAS\FileDelivery\Token\SigningSerializer::verify ( string  $data,
Salt  $salt 
)

Definition at line 70 of file SigningSerializer.php.

References null.

70  : ?Payload
71  {
72  // decompress payload
73  try {
74  $decompressed_payload = $this->compression->decompress(
75  $this->transport->readFromTransport($data)
76  );
77  } catch (\Throwable) {
78  return null;
79  }
80 
81  $split_data = explode(self::SEPARATOR, $decompressed_payload);
82  $serialized_payload = $split_data[0] ?? '';
83  $validity = $split_data[1] ?? '';
84  $signature = $split_data[2] ?? '';
85 
86  $payload_with_validity = $serialized_payload . self::SEPARATOR . $validity;
87 
88  if ($this->signer->verify($payload_with_validity, $signature, (int) $validity, $salt) === false) {
89  return null;
90  }
91 
92  return new StructuredPayload($this->serializer->unserializePayload($serialized_payload));
93  }
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null

Field Documentation

◆ SEPARATOR

const ILIAS\FileDelivery\Token\SigningSerializer::SEPARATOR = '<<>>'
private

Definition at line 41 of file SigningSerializer.php.


The documentation for this class was generated from the following file: