CardIssuerClassPrivate.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  1. /////////////////////////////////////////////////////////////////////////////////
  2. /// Copyright (c) 2012 China Merchants Bank, all rights reserved ///
  3. /// Adapter Interface for Card Issuer. ///
  4. /// ///
  5. /// ///
  6. /////////////////////////////////////////////////////////////////////////////////
  7. #ifndef __CARD_ISSUER_CLASS_H
  8. #define __CARD_ISSUER_CLASS_H
  9. #pragma once
  10. #include "DeviceBaseClass.h"
  11. #include "CardMix.h"
  12. //卡库平面、凹、凸(金,银)色带的状态
  13. enum KakuPrintStatusEnum
  14. {
  15. //平面印刷色带的状态
  16. CI_KAKU_PLAIN_COLOR_TAPE_FULL, //
  17. CI_KAKU_PLAIN_COLOR_TAPE_LOW, //
  18. CI_KAKU_PLAIN_COLOR_TAPE_EMPTY, //
  19. //凹字印刷色带的状态
  20. CI_KAKU_CONCAVE_COLOR_TAPE_FULL, //
  21. CI_KAKU_CONCAVE_COLOR_TAPE_LOW, //
  22. CI_KAKU_CONCAVE_COLOR_TAPE_EMPTY, //
  23. //凸字色带的状态(金色)
  24. CI_KAKU_CONVEX_COLOR_TAPE_GOLD_FULL, //
  25. CI_KAKU_CONVEX_COLOR_TAPE_GOLD_LOW, //
  26. CI_KAKU_CONVEX_COLOR_TAPE_GOLD_EMPTY, //
  27. //凸字色带的状态(银色)
  28. CI_KAKU_CONVEX_COLOR_TAPE_SILVER_FULL, //
  29. CI_KAKU_CONVEX_COLOR_TAPE_SILVER_LOW, //
  30. CI_KAKU_CONVEX_COLOR_TAPE_SILVER_EMPTY, //
  31. };
  32. struct CardIssuerStatus
  33. {
  34. CardStatusEnum eMedia; //state about card
  35. RtBinStatusEnum eRetainBin;
  36. DWORD dwRetainCount; //回收箱容量
  37. //根据实际的卡箱数量对相关字段进行赋值
  38. IssHopperStatusEnum eIssuerBin[12];//0,1,2,... => hopper 1,2,3,... 需要对1,2,3,...三个卡箱进行对应赋值
  39. DWORD dwIssuerCount[12]; //发卡箱容量,0,1,2,... => 1,2,3,...
  40. KakuPrintStatusEnum eKakuTape[8];//eKakuTape[0],eKakuTape[1],eKakuTape[2],eKakuTape[3]分别存放平面,凹,凸(金),凸(银)的状态
  41. };
  42. struct SAMStatus
  43. {
  44. int isActive;//0:Inactive; 1:acitve
  45. int chosenOfSAM;//the selected sam number:1,2,...
  46. };
  47. /** 该文件存在的意义是因为下面这个字段的定义与密码键盘头文件定义有冲突且值不一样
  48. 为了保证密码键盘和发卡器的头文件能同时在一个编译单元中引用,所以特意拷贝了一份并修改了该参数的命名
  49. [Gifur@20211019]*/
  50. const int MAX_WORKING_KEY_SIZE_PRIVATE = 64;
  51. const int MAX_CHECK_CODE_SIZE = 16;
  52. const int MAX_TEMP_DATA_SIZE = 64;
  53. const int MAX_KAKU_FILE_SIZE = 256;
  54. const int MAX_KAKU_FIELDS_SIZE = 1024;
  55. //SCI:SplitCardIssuer
  56. struct SCIKeyInfo
  57. {
  58. BYTE key[MAX_WORKING_KEY_SIZE_PRIVATE];
  59. DWORD dwSize;
  60. };
  61. struct SCICheckCode
  62. {
  63. BYTE code[MAX_CHECK_CODE_SIZE];
  64. DWORD dwSize;
  65. };
  66. struct SCITempData
  67. {
  68. BYTE data[MAX_TEMP_DATA_SIZE];
  69. DWORD dwSize;
  70. };
  71. enum SCIParamType
  72. {
  73. ParamBeep,
  74. ParamLed,
  75. ParamLevelTime,
  76. };
  77. enum SCILightType
  78. {
  79. SCILight_EjectCard,
  80. SCILight_CMBLogo,
  81. };
  82. enum SCIBluetoothCMD
  83. {
  84. SCIBluetooth_Open, //打开蓝牙
  85. SCIBluetooth_Close, //关闭蓝牙
  86. SCIBluetooth_Hide, //隐藏蓝牙信号
  87. SCIBluetooth_Show, //显示蓝牙信号
  88. };
  89. struct KakuPrintInfo
  90. {
  91. char formPath[MAX_KAKU_FILE_SIZE]; //存储form文件绝对路径
  92. char fields[MAX_KAKU_FIELDS_SIZE]; //存储打印内容参数
  93. };
  94. class CardIssuerClass : public DeviceBaseClass
  95. {
  96. public:
  97. //
  98. // 本接口几乎废弃不用。连接卡机,请使用DevOpenEx替代本接口
  99. // Connect to device and do initialization.
  100. // In case of power off or initialization,if the card is held in CardIssuer,move card
  101. // to Mag read/write position or doing nothing.
  102. // Retract counter will work.
  103. // Make preparations for controlling the device.
  104. // Arguments:
  105. // - dwPort[in] com port number
  106. // - dwBaudRate[in] Baud rate
  107. //
  108. virtual ErrorCodeEnum DevOpen(DWORD dwPort,DWORD dwBaudRate) = 0;
  109. //
  110. // Get card issuer status
  111. //
  112. virtual ErrorCodeEnum GetDevStatus(CardIssuerStatus &devStatus) = 0;
  113. //
  114. // Get device serial number.
  115. // 设备唯一标识,且需贴在设备外壳上
  116. virtual ErrorCodeEnum GetDeviceSN(char *&pDevSN) = 0;
  117. //
  118. // Move card to specified position.
  119. // hopperNo:多卡箱发卡时指定发卡箱号(面对发卡机,从左往右依次是1,2,3,...号卡箱)
  120. // 卡库:卡片从卡库加卡箱移动到读卡器,eCardPos为CI_MOVECARD_FROM_HOPPER,hopperNo固定传入99
  121. //
  122. virtual ErrorCodeEnum MoveCard(CardPosEnum eCardPos, int hopperNo = 1) = 0;
  123. //
  124. // Set card entry
  125. //
  126. virtual ErrorCodeEnum SetCardInType(CardInEnum eCardIn) = 0;
  127. //
  128. // Read data from magnetic track.
  129. //
  130. virtual ErrorCodeEnum MagRead(MagTracks &magTracks) = 0;
  131. //
  132. // Write data to magnetic track.
  133. //
  134. virtual ErrorCodeEnum MagWrite(MagTracks magTracks,MagWriteModeEnum eWriteMode) = 0;
  135. //
  136. // Set retract counter
  137. //
  138. virtual ErrorCodeEnum SetRetractCounter(DWORD dwCount) = 0;
  139. //
  140. // Set issuer counter
  141. // hopperNo:多卡箱发卡时指定发卡箱号(面对发卡机,从左往右依次是1,2,3,...号卡箱)
  142. //
  143. virtual ErrorCodeEnum SetIssuerCounter(DWORD dwCount,int hopperNo=1) = 0;
  144. //
  145. // Active contact IC card
  146. //
  147. virtual ErrorCodeEnum ActiveICCard() = 0;
  148. //
  149. // Move IC card to contact position
  150. //
  151. virtual ErrorCodeEnum ContactIC() = 0;
  152. //
  153. // Release IC contact
  154. //
  155. virtual ErrorCodeEnum ReleaseIC() = 0;
  156. //
  157. // Warm reset card(IC)
  158. //
  159. virtual ErrorCodeEnum WarmReset() = 0;
  160. //
  161. // APDU:Application Protocol Data Unit
  162. // CmdSend.lpCmd:Command-APDU
  163. // CmdRecv.lpData:Response-APDU
  164. //
  165. virtual ErrorCodeEnum ICCommand(CmdInfo sendBuf,CmdInfo &recvBuf) = 0;
  166. //////////////////SAM 卡操作部分////////////////////
  167. virtual ErrorCodeEnum SAMActive(BYTE vcc=0x30){ return Error_NotImpl; };
  168. virtual ErrorCodeEnum SAMDeactivate(){ return Error_NotImpl; };
  169. virtual ErrorCodeEnum SAMWarmReset(){ return Error_NotImpl; };
  170. virtual ErrorCodeEnum SAMQueryStatus(SAMStatus &samStatus){ return Error_NotImpl; };
  171. virtual ErrorCodeEnum SAMSelect(const int sn){ return Error_NotImpl; };
  172. //即时制卡卡库需要实现SAMCommand,用来执行apdu指令
  173. virtual ErrorCodeEnum SAMCommand(CmdInfo sendBuf, CmdInfo &recvBuf){ return Error_NotImpl; };
  174. //即时制卡卡库需要实现ActiveICCardATR,用来激活卡片,返回ATR
  175. virtual ErrorCodeEnum ActiveICCardATR(CmdInfo &atrBuf){return Error_NotImpl;}
  176. ////////////////卡面打印部分(非即时制卡的卡面印刷,即时制卡的卡面打印接口为PrintCardFaceRightNow),部分机型(例如合肥分行大机)有此功能//////////////////
  177. virtual ErrorCodeEnum Print(BYTE *&data, const int dataSize,const int side){ return Error_NotImpl; };
  178. virtual ErrorCodeEnum QueryPrinterStatus(){ return Error_NotImpl;};
  179. ////////////////////////////////////////////////////////////////////////////
  180. ////////非接(IC)部分 start,没有此部分,在接口实现中直接返回Error_NotImpl///////////////
  181. ////////////////////////////////////////////////////////////////////////////
  182. // Active contactless IC card(Type A,B,Mifare)
  183. // The first,second,third activation order decided by fstType,scdType,thdType respectively
  184. // fstType,scdType,thdType can be one of 'A','B','M','0'(30H,no type)
  185. // outType indicates the type of activation result
  186. //
  187. virtual ErrorCodeEnum ActiveContactlessICCard(char fstType, char scdType, char thdType, char &outType) = 0;
  188. //
  189. // Deactivate contact IC card
  190. //
  191. virtual ErrorCodeEnum DeactivateICCard() = 0;
  192. //
  193. // Deactivate contactless IC card
  194. //
  195. virtual ErrorCodeEnum DeactContactlessICCard() = 0;
  196. //
  197. // RF Mifare Classic protocol operation
  198. // Arguments:
  199. // - eFunType:function type as load key,authentication and so on
  200. // - sendBuf:[parameter][data]
  201. // - recvBuf:[status(1byte)][return data]
  202. //
  203. virtual ErrorCodeEnum MifareCommand(MifareFuctionEnum eFunType, CmdInfo sendBuf, CmdInfo &recvBuf) = 0;
  204. //
  205. // RF Type A,B command.
  206. // APDU:Application Protocol Data Unit
  207. // Arguments:
  208. // - CmdSend.lpCmd:Command-APDU
  209. // - CmdRecv.lpData:Response-APDU
  210. //
  211. virtual ErrorCodeEnum RFTypeABCommand(CmdInfo sendBuf, CmdInfo &recvBuf) = 0;
  212. ////////非接(IC)部分 end/////////////////////////////////////////////////////////
  213. // 发卡机调用打开设备
  214. // 1. btOpenType:设定通过哪种方式连接设备,由DevOpenType的枚举值组合。usb及蓝牙设备连接可忽略dwPort,dwBaudRate
  215. // 2.通过pDevSN来指定连接对应设备号的蓝牙发卡机(考虑存在多台发卡机的情况)
  216. // 例如通过蓝牙或者usb连接设备,则btOpenType = (DEV_OPEN_TYPE_USB|DEV_OPEN_TYPE_BLUETOOTH)
  217. // 3. btType返回设备实际通过哪种方式相连,返回值参考DevOpenType(大机,卡库参考下一条)
  218. // 4.对于大机(柜式可视柜台,卡库)dwPort,dwBaudRate传入端口,波特率,btOpenType为DEV_OPEN_TYPE_COM,pDevSN为""
  219. // ,btType返回值表示卡槽数量(例如目前存在单卡槽1,双卡槽2,三卡槽3的机型)
  220. //
  221. virtual ErrorCodeEnum DevOpenEx(DWORD dwPort, DWORD dwBaudRate, BYTE btOpenType,const char *pDevSN, BYTE &btType) = 0;
  222. /////////////////////////////////////////////////////////////////////////
  223. ///以下是便携式卡机特有API,接口实现中其他机型直接返回Error_NotImpl即可//
  224. /////////////////////////////////////////////////////////////////////////
  225. // 返回值Error_Succeed表示成功,其他值表示失败
  226. // iStatus 0:成功 -1:银行公钥不存在 -2:产生设备密钥故障 -x:其他厂商自定义故障
  227. // Cr1:随机数r1的密文; Cr3:随机数r3的密文,dKey:用银行公钥加密的设备公钥密文
  228. // r1,r3第16字节为数据完整性校验字节,例如r1为B1B2...B15B16,则B16=B1^B2^...^B15
  229. virtual ErrorCodeEnum TransferEnInit(int &iStatus, BYTE *&Cr1, int &lenR1, BYTE *&Cr3, int &lenR3, BYTE *&dKey, int &lenKey) = 0;
  230. // 返回值Error_Succeed表示成功,其他值表示失败
  231. // iStatus 0:成功 -x:厂商自定义故障
  232. // r2第16字节为数据完整性校验字节,例如r2为B1B2...B15B16,则B16=B1^B2^...^B15
  233. virtual ErrorCodeEnum SetR2(int &iStatus, BYTE *pCr2, int lenR2) = 0;
  234. //
  235. // 设置会话密钥
  236. // pWorkingKey:会话密钥,传递16进制的字符形式,例如0x123456FFAB --> "123456FFAB"
  237. virtual ErrorCodeEnum SendWorkingKey(const char *pWorkingKey) = 0;
  238. //安全锁接口部分 begin
  239. virtual ErrorCodeEnum SLLoadKey(const SCIKeyInfo key) = 0;
  240. //case ParamBeep: value:0,close beep;value:1,open beep
  241. //case ParamLed: value:0,close led;value:1,open led
  242. //case ParamLevelTime: value:the duration of level,100ms per unit
  243. // ex. the value 10 means duration time is 1 second
  244. virtual ErrorCodeEnum SLSetParam(SCIParamType eType, int value) = 0;
  245. virtual ErrorCodeEnum SLLock() = 0;
  246. virtual ErrorCodeEnum SLUnLock(const SCICheckCode checkCode, bool bTemp = true) = 0;
  247. virtual ErrorCodeEnum SLGetTempData(SCITempData &ksnData, SCITempData &ramData) = 0;
  248. virtual ErrorCodeEnum SLOpenDoor(const SCITempData data) = 0;
  249. //安全锁接口部分 end
  250. //蓝牙控制部分 start
  251. //蓝牙指令控制,命令参看SCIBluetoothCMD说明
  252. virtual ErrorCodeEnum BluetoothControl(SCIBluetoothCMD eCmd) = 0;
  253. //修改配对密码
  254. virtual ErrorCodeEnum BluetoothModifyKey(unsigned char *key) = 0;
  255. //修改蓝牙设备名称
  256. virtual ErrorCodeEnum BluetoothModifyName(unsigned char *name) = 0;
  257. //获取版本信息
  258. virtual ErrorCodeEnum BluetoothGetVersion(char *&version) = 0;
  259. //获取连接设备名称
  260. virtual ErrorCodeEnum BluetoothGetConnectName(unsigned char *&name) = 0;
  261. //获取连接设备信号强度
  262. virtual ErrorCodeEnum BluetoothGetSignalStrength(unsigned char *&signal) = 0;
  263. //蓝牙控制部分 end
  264. //控制灯光
  265. //eLight:所控制的灯 ;
  266. //bOnOff:true 亮灯;fasle 灭灯
  267. virtual ErrorCodeEnum LightControl(SCILightType eLight, bool bOnOff) = 0;
  268. //以百分比数值返回剩余电量(1-100),例如剩余51%,则bat赋值为51
  269. virtual ErrorCodeEnum QueryBatteryPower(int &bat) = 0;
  270. //oiltest
  271. //virtual ErrorCodeEnum EncryptData(TempData ramData, TempData bdk, TempData curksn, TempData &encryptedData) = 0;
  272. //把卡片从读卡器移动到指定卡槽位
  273. virtual ErrorCodeEnum MoveCardToSlot(int slot){return Error_NotImpl;}
  274. //把卡片从指定卡槽位移动到读卡器
  275. virtual ErrorCodeEnum MoveCardFromSlot(int slot){return Error_NotImpl;}
  276. //读取卡号
  277. //优先从IC卡解析卡号,如果纯磁条卡,则返回磁道解析的卡号
  278. virtual ErrorCodeEnum ReadAccount(CardNo &cardNo){return Error_NotImpl;}
  279. //获取总卡槽数
  280. virtual ErrorCodeEnum GetSlotSum(int &sum){return Error_NotImpl;}
  281. //获取卡槽状态
  282. virtual ErrorCodeEnum QuerySlotsStatus(SlotStatus &slots,const int slot,bool bFull=false){return Error_NotImpl;}
  283. //即时制卡卡库专用接口
  284. virtual ErrorCodeEnum PrintCardFaceRightNow(const KakuPrintInfo printInfo){return Error_NotImpl;}
  285. };
  286. #endif //__CARD_ISSUER_CLASS_H