23#include "IllegalArgumentException.h"
29using namespace keyple::core::util;
30using namespace keyple::core::util::cpp::exception;
34const std::map<const int, const std::shared_ptr<StatusProperties>>
35 CmdSamDigestAuthenticate::STATUS_TABLE = initStatusTable();
38 const std::vector<uint8_t>& signature)
41 if (signature.empty()) {
42 throw IllegalArgumentException(
"Signature can't be null");
45 if (signature.size() != 4 && signature.size() != 8 && signature.size() != 16) {
46 throw IllegalArgumentException(
"Signature is not the right length : length is " +
47 std::to_string(signature.size()));
51 const uint8_t p1 = 0x00;
52 const uint8_t p2 = 0x00;
55 std::make_shared<ApduRequestAdapter>(
59const std::map<const int, const std::shared_ptr<StatusProperties>>
60 CmdSamDigestAuthenticate::initStatusTable()
62 std::map<const int, const std::shared_ptr<StatusProperties>> m =
66 std::make_shared<StatusProperties>(
"Incorrect Lc.",
69 std::make_shared<StatusProperties>(
"Preconditions not satisfied.",
70 typeid(CalypsoSamAccessForbiddenException))});
72 std::make_shared<StatusProperties>(
"Incorrect signature.",
73 typeid(CalypsoSamSecurityDataException))});
78const std::map<const int, const std::shared_ptr<StatusProperties>>&
virtual void setApduRequest(const std::shared_ptr< ApduRequestAdapter > apduRequest) final
static const std::map< const int, const std::shared_ptr< StatusProperties > > STATUS_TABLE
static const CalypsoSamCommand DIGEST_AUTHENTICATE
uint8_t getInstructionByte() const override
CmdSamDigestAuthenticate(const CalypsoSam::ProductType productType, const std::vector< uint8_t > &signature)
const std::map< const int, const std::shared_ptr< StatusProperties > > & getStatusTable() const override
static uint8_t getClassByte(const ProductType productType)
CalypsoSam::ProductType ProductType