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()) {
43 throw IllegalArgumentException(
"Signature can't be null");
46 if (signature.size() != 4 && signature.size() != 8 && signature.size() != 16) {
48 throw IllegalArgumentException(
"Signature is not the right length : length is " +
49 std::to_string(signature.size()));
53 const uint8_t p1 = 0x00;
54 const uint8_t p2 = 0x00;
57 std::make_shared<ApduRequestAdapter>(
61const std::map<const int, const std::shared_ptr<StatusProperties>>
62 CmdSamDigestAuthenticate::initStatusTable()
64 std::map<const int, const std::shared_ptr<StatusProperties>> m =
68 std::make_shared<StatusProperties>(
"Incorrect Lc.",
71 std::make_shared<StatusProperties>(
"Preconditions not satisfied.",
72 typeid(CalypsoSamAccessForbiddenException))});
74 std::make_shared<StatusProperties>(
"Incorrect signature.",
75 typeid(CalypsoSamSecurityDataException))});
80const 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 std::shared_ptr< CalypsoSamAdapter > calypsoSam, 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)