#ifndef LIBFRAMEWORK_CARDISSUER_IMPL_H #define LIBFRAMEWORK_CARDISSUER_IMPL_H #include "CardIssuerClass.h" #include #include "DeviceSimulator.h" #define EntityName "CardIssuerStore" using namespace std; class CardIssuerImpl : public CardIssuerClass { public: CardIssuerImpl(); ~CardIssuerImpl(); static void HttpsLogCallBack(const char* logtxt) {} //DeviceBaseClass ErrorCodeEnum GetDevCategory(DevCategoryInfo& devCategory); ErrorCodeEnum Reset(); ErrorCodeEnum DevClose(); ErrorCodeEnum GetLastErr(DevErrorInfo& devErrInfo); //本接口几乎废弃不用。连接卡机,请使用DevOpenEx替代本接口 ErrorCodeEnum DevOpen(DWORD dwPort, DWORD dwBaudRate) { return Error_NotImpl; }//废弃 // Get card issuer status //使用(卡库,卡机) ErrorCodeEnum GetDevStatus(CardIssuerStatus& devStatus); // // Get device serial number. // 设备唯一标识,且需贴在设备外壳上 // 使用(pad) ErrorCodeEnum GetDeviceSN(char*& pDevSN) ; // // Move card to specified position. // hopperNo:多卡箱发卡时指定发卡箱号(面对发卡机,从左往右依次是1,2,3,...号卡箱) // 卡库:卡片从卡库加卡箱移动到读卡器,eCardPos为CI_MOVECARD_FROM_HOPPER,hopperNo固定传入99 // 卡库:卡片从卡库加卡箱移动到读卡器,若加卡箱已经无卡,返回Error_Dev_HopperHasNoCard //使用(卡库,卡机)***** ErrorCodeEnum MoveCard(CardPosEnum eCardPos, int hopperNo = 1) ; // // Set card entry //使用(卡库,卡机)***** ErrorCodeEnum SetCardInType(CardInEnum eCardIn) ; // // Read data from magnetic track. //使用(卡库,卡机) ErrorCodeEnum MagRead(MagTracks& magTracks) ; // Write data to magnetic track. //使用(卡库)***** ErrorCodeEnum MagWrite(MagTracks magTracks, MagWriteModeEnum eWriteMode) ; // // Set retract counter ErrorCodeEnum SetRetractCounter(DWORD dwCount) { return Error_NotImpl; } //废弃 // // Set issuer counter // hopperNo:多卡箱发卡时指定发卡箱号(面对发卡机,从左往右依次是1,2,3,...号卡箱) ErrorCodeEnum SetIssuerCounter(DWORD dwCount, int hopperNo = 1) { return Error_NotImpl; }//废弃 // // Active contact IC card //使用(卡库,卡机)***** ErrorCodeEnum ActiveICCard() ; // // Move IC card to contact position //使用(卡库,卡机)***** ErrorCodeEnum ContactIC() ; // // Release IC contact //使用(卡库,卡机)***** ErrorCodeEnum ReleaseIC() ; // // Warm reset card(IC) //使用(卡库,卡机)***** ErrorCodeEnum WarmReset() ; // APDU:Application Protocol Data Unit // CmdSend.lpCmd:Command-APDU // CmdRecv.lpData:Response-APDU //使用(卡库,卡机) ErrorCodeEnum ICCommand(CmdInfo sendBuf, CmdInfo& recvBuf) ; //////////////////SAM 卡操作部分//////////////////// ErrorCodeEnum SAMActive(BYTE vcc = 0x30);//使用(卡库,卡机) ErrorCodeEnum SAMDeactivate();//使用(卡库,卡机) ErrorCodeEnum SAMWarmReset();//使用(卡库,卡机) ErrorCodeEnum SAMQueryStatus(SAMStatus& samStatus);//使用(卡库,卡机) ErrorCodeEnum SAMSelect(const int sn);//使用(卡库,卡机) //即时制卡卡库需要实现SAMCommand,用来执行apdu指令 ErrorCodeEnum SAMCommand(CmdInfo sendBuf, CmdInfo& recvBuf) ;//使用(卡库,卡机) //即时制卡卡库需要实现ActiveICCardATR,用来激活卡片,返回ATR ErrorCodeEnum ActiveICCardATR(CmdInfo& atrBuf) ;//使用(卡库,卡机) ////////////////卡面打印部分(非即时制卡的卡面印刷,即时制卡的卡面打印接口为PrintCardFaceRightNow),部分机型(例如合肥分行大机)有此功能////////////////// ErrorCodeEnum Print(BYTE*& data, const int dataSize, const int side) { return Error_NotImpl; }//废弃 ErrorCodeEnum QueryPrinterStatus() { return Error_NotImpl; }//废弃 //////////////////////////////////////////////////////////////////////////// ////////非接(IC)部分 start,没有此部分,在接口实现中直接返回Error_NotImpl/////////////// //////////////////////////////////////////////////////////////////////////// // Active contactless IC card(Type A,B,Mifare) // The first,second,third activation order decided by fstType,scdType,thdType respectively // fstType,scdType,thdType can be one of 'A','B','M','0'(30H,no type) // outType indicates the type of activation result // ErrorCodeEnum ActiveContactlessICCard(char fstType, char scdType, char thdType, char& outType) ;//使用(卡库,卡机) // // Deactivate contact IC card ***** // ErrorCodeEnum DeactivateICCard() ; //使用(卡库,卡机) // // Deactivate contactless IC card ***** // ErrorCodeEnum DeactContactlessICCard() ;//使用(卡库,卡机) // // RF Mifare Classic protocol operation // Arguments: // - eFunType:function type as load key,authentication and so on // - sendBuf:[parameter][data] // - recvBuf:[status(1byte)][return data] // ErrorCodeEnum MifareCommand(MifareFuctionEnum eFunType, CmdInfo sendBuf, CmdInfo& recvBuf) { return Error_NotImpl; }//废弃 // // RF Type A,B command. // APDU:Application Protocol Data Unit // Arguments: // - CmdSend.lpCmd:Command-APDU // - CmdRecv.lpData:Response-APDU // ErrorCodeEnum RFTypeABCommand(CmdInfo sendBuf, CmdInfo& recvBuf) ;//使用(卡库,卡机) ////////非接(IC)部分 end///////////////////////////////////////////////////////// // 发卡机调用打开设备 // 1. btOpenType:设定通过哪种方式连接设备,由DevOpenType的枚举值组合。usb及蓝牙设备连接可忽略dwPort,dwBaudRate // 2.通过pDevSN来指定连接对应设备号的蓝牙发卡机(考虑存在多台发卡机的情况) // 例如通过蓝牙或者usb连接设备,则btOpenType = (DEV_OPEN_TYPE_USB|DEV_OPEN_TYPE_BLUETOOTH) // 3. btType返回设备实际通过哪种方式相连,返回值参考DevOpenType(大机,卡库参考下一条) // 4.对于大机(柜式可视柜台,卡库)dwPort,dwBaudRate传入端口,波特率,btOpenType为DEV_OPEN_TYPE_COM,pDevSN为"" // ,btType返回值表示卡槽数量(例如目前存在单卡槽1,双卡槽2,三卡槽3的机型) // ***** ErrorCodeEnum DevOpenEx(DWORD dwPort, DWORD dwBaudRate, BYTE btOpenType, const char* pDevSN, BYTE& btType) ;//使用(卡库,卡机) ///////////////////////////////////////////////////////////////////////// ///以下是便携式卡机特有API,接口实现中其他机型直接返回Error_NotImpl即可// ///////////////////////////////////////////////////////////////////////// // 返回值Error_Succeed表示成功,其他值表示失败 // iStatus 0:成功 -1:银行公钥不存在 -2:产生设备密钥故障 -x:其他厂商自定义故障 // Cr1:随机数r1的密文; Cr3:随机数r3的密文,dKey:用银行公钥加密的设备公钥密文 // r1,r3第16字节为数据完整性校验字节,例如r1为B1B2...B15B16,则B16=B1^B2^...^B15 ErrorCodeEnum TransferEnInit(int& iStatus, BYTE*& Cr1, int& lenR1, BYTE*& Cr3, int& lenR3, BYTE*& dKey, int& lenKey) ;//使用(刷卡器) // 返回值Error_Succeed表示成功,其他值表示失败 // iStatus 0:成功 -x:厂商自定义故障 // r2第16字节为数据完整性校验字节,例如r2为B1B2...B15B16,则B16=B1^B2^...^B15 ErrorCodeEnum SetR2(int& iStatus, BYTE* pCr2, int lenR2) ;//使用(刷卡器) // // 设置会话密钥 // pWorkingKey:会话密钥,传递16进制的字符形式,例如0x123456FFAB --> "123456FFAB" ErrorCodeEnum SendWorkingKey(const char* pWorkingKey) ;//使用(刷卡器) //安全锁接口部分 begin ErrorCodeEnum SLLoadKey(const SCIKeyInfo key) { return Error_NotImpl; }// 使用(刷卡器) 废弃 //case ParamBeep: value:0,close beep;value:1,open beep //case ParamLed: value:0,close led;value:1,open led //case ParamLevelTime: value:the duration of level,100ms per unit // ex. the value 10 means duration time is 1 second ErrorCodeEnum SLSetParam(SCIParamType eType, int value) { return Error_NotImpl; }//废弃 ErrorCodeEnum SLLock() { return Error_NotImpl; }//废弃 ErrorCodeEnum SLUnLock(const SCICheckCode checkCode, bool bTemp = true) { return Error_NotImpl; }//废弃 ErrorCodeEnum SLGetTempData(SCITempData& ksnData, SCITempData& ramData) { return Error_NotImpl; }//废弃 ErrorCodeEnum SLOpenDoor(const SCITempData data) { return Error_NotImpl; }//废弃 //安全锁接口部分 end //蓝牙控制部分 start //蓝牙指令控制,命令参看SCIBluetoothCMD说明 ErrorCodeEnum BluetoothControl(SCIBluetoothCMD eCmd) { return Error_NotImpl; }//废弃 //修改配对密码 ErrorCodeEnum BluetoothModifyKey(unsigned char* key) { return Error_NotImpl; }//废弃 //修改蓝牙设备名称 ErrorCodeEnum BluetoothModifyName(unsigned char* name) { return Error_NotImpl; }//废弃 //获取版本信息 ErrorCodeEnum BluetoothGetVersion(char*& version) { return Error_NotImpl; }//废弃 //获取连接设备名称 ErrorCodeEnum BluetoothGetConnectName(unsigned char*& name) { return Error_NotImpl; }//废弃 //获取连接设备信号强度 ErrorCodeEnum BluetoothGetSignalStrength(unsigned char*& signal) { return Error_NotImpl; }//废弃 //蓝牙控制部分 end //控制灯光 //eLight:所控制的灯 ; //bOnOff:true 亮灯;fasle 灭灯 ErrorCodeEnum LightControl(SCILightType eLight, bool bOnOff) { return Error_NotImpl; }//废弃 //以百分比数值返回剩余电量(1-100),例如剩余51%,则bat赋值为51 ErrorCodeEnum QueryBatteryPower(int& bat) { return Error_NotImpl; }//废弃 //oiltest //virtual ErrorCodeEnum EncryptData(TempData ramData, TempData bdk, TempData curksn, TempData &encryptedData) ; //把卡片从读卡器移动到指定卡槽位 ErrorCodeEnum MoveCardToSlot(int slot) ;//使用(卡库,卡机) //把卡片从指定卡槽位移动到读卡器 ErrorCodeEnum MoveCardFromSlot(int slot) ;//使用(卡库,卡机) //读取卡号 //优先从IC卡解析卡号,如果纯磁条卡,则返回磁道解析的卡号 ErrorCodeEnum ReadAccount(CardNo& cardNo) ;//使用(卡库,卡机) //获取总卡槽数 ErrorCodeEnum GetSlotSum(int& sum) ;//使用(卡库,卡机) //获取卡槽状态 ErrorCodeEnum QuerySlotsStatus(SlotStatus& slots, const int slot, bool bFull = false) ;//使用(卡库,卡机) //即时制卡卡库专用接口 ErrorCodeEnum PrintCardFaceRightNow(const KakuPrintInfo printInfo) ;//使用(卡库,卡机) }; #endif //LIBFRAMEWORK_CARDISSUER_IMPL_H