2017-11-11 03:08:28 +08:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Copyright (C) 2017 Merlok
|
|
|
|
//
|
|
|
|
// This code is licensed to you under the terms of the GNU GPL, version 2 or,
|
|
|
|
// at your option, any later version. See the LICENSE.txt file for the text of
|
|
|
|
// the license.
|
|
|
|
//-----------------------------------------------------------------------------
|
2017-11-25 10:28:02 +08:00
|
|
|
// EMV core functionality
|
2017-11-11 03:08:28 +08:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#ifndef EMVCORE_H__
|
|
|
|
#define EMVCORE_H__
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <inttypes.h>
|
2017-11-25 10:28:02 +08:00
|
|
|
#include <string.h>
|
2018-11-20 22:26:35 +08:00
|
|
|
#include <jansson.h>
|
2017-11-11 03:08:28 +08:00
|
|
|
#include "util.h"
|
|
|
|
#include "common.h"
|
|
|
|
#include "ui.h"
|
2017-11-25 10:28:02 +08:00
|
|
|
#include "cmdhf14a.h"
|
2017-12-24 17:26:47 +08:00
|
|
|
#include "apduinfo.h"
|
|
|
|
#include "tlv.h"
|
|
|
|
#include "dol.h"
|
|
|
|
#include "dump.h"
|
|
|
|
#include "emv_tags.h"
|
|
|
|
#include "emv_pk.h"
|
|
|
|
#include "emv_pki.h"
|
2017-11-11 03:08:28 +08:00
|
|
|
|
2017-11-25 10:28:02 +08:00
|
|
|
#define APDU_RES_LEN 260
|
|
|
|
#define APDU_AID_LEN 50
|
|
|
|
|
2018-12-04 01:29:31 +08:00
|
|
|
typedef enum {
|
|
|
|
ECC_CONTACTLESS,
|
|
|
|
ECC_CONTACT
|
|
|
|
} EMVCommandChannel;
|
|
|
|
|
2017-12-05 22:44:35 +08:00
|
|
|
enum TransactionType {
|
|
|
|
TT_MSD,
|
2019-02-20 03:19:45 +08:00
|
|
|
TT_VSDC, // contact only. not standart for contactless
|
2017-12-05 22:44:35 +08:00
|
|
|
TT_QVSDCMCHIP,
|
|
|
|
TT_CDA,
|
|
|
|
};
|
2018-11-20 22:26:35 +08:00
|
|
|
extern char *TransactionTypeStr[];
|
2017-12-05 22:44:35 +08:00
|
|
|
|
2017-12-03 01:58:33 +08:00
|
|
|
typedef struct {
|
|
|
|
uint8_t CLA;
|
|
|
|
uint8_t INS;
|
|
|
|
uint8_t P1;
|
|
|
|
uint8_t P2;
|
|
|
|
uint8_t Lc;
|
|
|
|
uint8_t *data;
|
|
|
|
} sAPDU;
|
|
|
|
|
|
|
|
enum CardPSVendor {
|
|
|
|
CV_NA,
|
|
|
|
CV_VISA,
|
|
|
|
CV_MASTERCARD,
|
|
|
|
CV_AMERICANEXPRESS,
|
|
|
|
CV_JCB,
|
|
|
|
CV_CB,
|
|
|
|
CV_OTHER,
|
|
|
|
};
|
|
|
|
extern enum CardPSVendor GetCardPSVendor(uint8_t * AID, size_t AIDlen);
|
|
|
|
|
2018-12-23 16:48:46 +08:00
|
|
|
extern bool TLVPrintFromBuffer(uint8_t *data, int datalen);
|
2017-11-25 10:28:02 +08:00
|
|
|
extern void TLVPrintFromTLV(struct tlvdb *tlv);
|
2017-12-03 01:58:33 +08:00
|
|
|
extern void TLVPrintFromTLVLev(struct tlvdb *tlv, int level);
|
2017-11-25 10:28:02 +08:00
|
|
|
extern void TLVPrintAIDlistFromSelectTLV(struct tlvdb *tlv);
|
|
|
|
|
2017-12-03 01:58:33 +08:00
|
|
|
extern struct tlvdb *GetPANFromTrack2(const struct tlv *track2);
|
|
|
|
extern struct tlvdb *GetdCVVRawFromTrack2(const struct tlv *track2);
|
|
|
|
|
2017-11-25 10:28:02 +08:00
|
|
|
extern void SetAPDULogging(bool logging);
|
|
|
|
|
2018-11-08 23:29:58 +08:00
|
|
|
// exchange
|
2018-12-04 01:29:31 +08:00
|
|
|
extern int EMVExchange(EMVCommandChannel channel, bool LeaveFieldON, sAPDU apdu, uint8_t *Result, size_t MaxResultLen, size_t *ResultLen, uint16_t *sw, struct tlvdb *tlv);
|
2018-11-08 23:29:58 +08:00
|
|
|
|
2017-11-25 10:28:02 +08:00
|
|
|
// search application
|
2018-12-29 02:48:45 +08:00
|
|
|
extern int EMVSearchPSE(EMVCommandChannel channel, bool ActivateField, bool LeaveFieldON, uint8_t PSENum, bool decodeTLV, struct tlvdb *tlv);
|
2018-12-04 01:29:31 +08:00
|
|
|
extern int EMVSearch(EMVCommandChannel channel, bool ActivateField, bool LeaveFieldON, bool decodeTLV, struct tlvdb *tlv);
|
|
|
|
extern int EMVSelectPSE(EMVCommandChannel channel, bool ActivateField, bool LeaveFieldON, uint8_t PSENum, uint8_t *Result, size_t MaxResultLen, size_t *ResultLen, uint16_t *sw);
|
|
|
|
extern int EMVSelect(EMVCommandChannel channel, bool ActivateField, bool LeaveFieldON, uint8_t *AID, size_t AIDLen, uint8_t *Result, size_t MaxResultLen, size_t *ResultLen, uint16_t *sw, struct tlvdb *tlv);
|
2017-11-25 10:28:02 +08:00
|
|
|
// select application
|
|
|
|
extern int EMVSelectApplication(struct tlvdb *tlv, uint8_t *AID, size_t *AIDlen);
|
|
|
|
// Get Processing Options
|
2018-12-04 01:29:31 +08:00
|
|
|
extern int EMVGPO(EMVCommandChannel channel, bool LeaveFieldON, uint8_t *PDOL, size_t PDOLLen, uint8_t *Result, size_t MaxResultLen, size_t *ResultLen, uint16_t *sw, struct tlvdb *tlv);
|
|
|
|
extern int EMVReadRecord(EMVCommandChannel channel, bool LeaveFieldON, uint8_t SFI, uint8_t SFIrec, uint8_t *Result, size_t MaxResultLen, size_t *ResultLen, uint16_t *sw, struct tlvdb *tlv);
|
2017-12-05 22:44:35 +08:00
|
|
|
// AC
|
2018-12-04 01:29:31 +08:00
|
|
|
extern int EMVGenerateChallenge(EMVCommandChannel channel, bool LeaveFieldON, uint8_t *Result, size_t MaxResultLen, size_t *ResultLen, uint16_t *sw, struct tlvdb *tlv);
|
|
|
|
extern int EMVAC(EMVCommandChannel channel, bool LeaveFieldON, uint8_t RefControl, uint8_t *CDOL, size_t CDOLLen, uint8_t *Result, size_t MaxResultLen, size_t *ResultLen, uint16_t *sw, struct tlvdb *tlv);
|
2017-12-24 17:26:47 +08:00
|
|
|
// DDA
|
2018-12-04 01:29:31 +08:00
|
|
|
extern int EMVInternalAuthenticate(EMVCommandChannel channel, bool LeaveFieldON, uint8_t *DDOL, size_t DDOLLen, uint8_t *Result, size_t MaxResultLen, size_t *ResultLen, uint16_t *sw, struct tlvdb *tlv);
|
2017-12-03 01:58:33 +08:00
|
|
|
// Mastercard
|
2018-12-04 01:29:31 +08:00
|
|
|
int MSCComputeCryptoChecksum(EMVCommandChannel channel, bool LeaveFieldON, uint8_t *UDOL, uint8_t UDOLlen, uint8_t *Result, size_t MaxResultLen, size_t *ResultLen, uint16_t *sw, struct tlvdb *tlv);
|
2017-12-05 22:44:35 +08:00
|
|
|
// Auth
|
2017-12-24 17:26:47 +08:00
|
|
|
extern int trSDA(struct tlvdb *tlv);
|
2018-12-04 01:29:31 +08:00
|
|
|
extern int trDDA(EMVCommandChannel channel, bool decodeTLV, struct tlvdb *tlv);
|
2017-12-24 17:26:47 +08:00
|
|
|
extern int trCDA(struct tlvdb *tlv, struct tlvdb *ac_tlv, struct tlv *pdol_data_tlv, struct tlv *ac_data_tlv);
|
2017-11-11 03:08:28 +08:00
|
|
|
|
2018-11-20 22:26:35 +08:00
|
|
|
extern int RecoveryCertificates(struct tlvdb *tlvRoot, json_t *root);
|
|
|
|
|
2018-12-26 18:02:00 +08:00
|
|
|
extern struct emv_pk *get_ca_pk(struct tlvdb *db);
|
2017-11-11 03:08:28 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|