Module_Systex.c 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639
  1. /*
  2. * Module_RFID.c
  3. *
  4. * Created on: 2019-10-24
  5. * Update: 2020-10-19
  6. * Author: Eason Yang
  7. * Version: V0.03
  8. *
  9. * History
  10. * 1. Added : Reyax code.
  11. *
  12. *
  13. *
  14. *
  15. *
  16. */
  17. #include "Module_Systex.h"
  18. #define RequestLength 600
  19. #define ResponseLength 600
  20. //==================================
  21. // PRINT OUT LOG FORMAT
  22. //==================================
  23. #define SystemLogMessage
  24. #define DEBUG_INFO_1(format, args...) StoreLogMessage("[%s:%d][%s][Info] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  25. #define DEBUG_WARN_1(format, args...) StoreLogMessage("[%s:%d][%s][Warn] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  26. #define DEBUG_ERROR_1(format, args...) StoreLogMessage("[%s:%d][%s][Error] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
  27. //==================================
  28. // HOST ID, offset = 0, length = 2 bytes ,
  29. //==================================
  30. unsigned char HOST_ID_Auto[] = {0x30, 0x30};//信用卡/ 電子票證/ 掃碼支付
  31. unsigned char HOST_ID_CreditCard[] = {0x31, 0x30};//信用卡
  32. unsigned char HOST_ID_eTicket_Polling[] = {0x35, 0x30};//電子票證
  33. //==================================
  34. // Transaction Type, offset = 2, length = 2 bytes ,
  35. //==================================
  36. //-------------尋卡---------------
  37. unsigned char TRANS_TYPE_Search[] = {0x37, 0x32}; //讀取卡片卡號 or 條碼資料
  38. //--------------信用卡一般消費---------------
  39. unsigned char TRANS_TYPE_Sale[] = {0x31, 0x31}; //消費交易 : 信用卡,票證,掃碼支付
  40. unsigned char TRANS_TYPE_Void[] = {0x30, 0x35};//取消交易 : 信用卡,
  41. unsigned char TRANS_TYPE_Refund[] = {0x31, 0x32};//退貨交易 : 信用卡,票證,掃碼支付
  42. //--------------信用卡預授權---------------
  43. unsigned char TRANS_TYPE_Pre_Auth[] = {0x31, 0x33}; //預授權交易 : 信用卡
  44. unsigned char TRANS_TYPE_Pre_Auth_Complete[] = {0x33, 0x31}; //預授權完成交易 : 信用卡
  45. unsigned char TRANS_TYPE_Pre_Auth_Cancel[] = {0x33, 0x32}; //取消預授權交易 : 信用卡
  46. //--------------連動結帳---------------
  47. unsigned char TRANS_TYPE_UnionSettlement[] = {0x35, 0x41}; //連動結帳請款
  48. //==================================
  49. // SystemLog message
  50. //==================================
  51. #ifdef SystemLogMessage
  52. int StoreLogMessage(const char *fmt, ...)
  53. {
  54. char Buf[4096 + 256];
  55. char buffer[4096];
  56. time_t CurrentTime;
  57. struct tm *tm;
  58. va_list args;
  59. va_start(args, fmt);
  60. int rc = vsnprintf(buffer, sizeof(buffer), fmt, args);
  61. va_end(args);
  62. memset(Buf, 0, sizeof(Buf));
  63. CurrentTime = time(NULL);
  64. tm = localtime(&CurrentTime);
  65. sprintf(Buf,
  66. "echo \"[%04d.%02d.%02d %02d:%02d:%02d] - %s\" >> /Storage/SystemLog/[%04d.%02d]RFID_SystemLog",
  67. tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday, tm->tm_hour,
  68. tm->tm_min, tm->tm_sec, buffer, tm->tm_year + 1900, tm->tm_mon + 1);
  69. system(Buf);
  70. #ifdef Debug
  71. printf("[%04d.%02d.%02d %02d:%02d:%02d] - %s", tm->tm_year + 1900,
  72. tm->tm_mon + 1, tm->tm_mday, tm->tm_hour, tm->tm_min, tm->tm_sec,
  73. buffer);
  74. #endif
  75. return rc;
  76. }
  77. #endif
  78. //==========================================
  79. // Module's command send/receive
  80. //==========================================
  81. int SendRequest(int uart, unsigned char* cmd, int length)
  82. {
  83. int len, TotalRtn=0, Rtn,i;
  84. unsigned int StartTime;
  85. unsigned char LRC=0;
  86. unsigned char SendBuffer[RequestLength+4];
  87. len=length+3;
  88. memset(SendBuffer,0,RequestLength+4);
  89. SendBuffer[0]=0x02;
  90. memcpy(SendBuffer+1,cmd,length);
  91. SendBuffer[length+1]=0x03;
  92. for(i=1;i<=length+1;i++)
  93. {
  94. LRC^=SendBuffer[i];
  95. }
  96. SendBuffer[length+2]=LRC;
  97. //sleep(2); //required to make flush work, for some reason
  98. //for(int i=0;i<len;i++)
  99. //printf("%x\n",SendBuffer[i]);
  100. //printf("strlen(SendBuffer)=%d\n",strlen(SendBuffer));
  101. //printf("SendBuffer[0]=%x,SendBuffer[601]=%x,SendBuffer[602]=%x \n",SendBuffer[i],SendBuffer[601],SendBuffer[602]);
  102. tcflush(uart, TCIOFLUSH);
  103. sleep(1);
  104. while(1)
  105. {
  106. Rtn=write(uart, SendBuffer+TotalRtn, len-TotalRtn);
  107. if(Rtn>0)
  108. {
  109. TotalRtn+=Rtn;
  110. if(TotalRtn>=len)
  111. {
  112. //printf("Rtn=%d,TotalRtn=%d\n",Rtn,TotalRtn);
  113. break;
  114. }
  115. }
  116. else
  117. {
  118. DEBUG_INFO_1("SendRequest: write fail (%d / %d)\n", TotalRtn,len);
  119. return -1;
  120. }
  121. }
  122. //usleep(100000);
  123. TotalRtn=0;
  124. memset(SendBuffer,0,RequestLength+4);
  125. StartTime = time(NULL);
  126. while(1)
  127. {
  128. Rtn=read(uart, SendBuffer+TotalRtn, 2-TotalRtn);
  129. if(Rtn>0)
  130. {
  131. TotalRtn+=Rtn;
  132. if(TotalRtn>=2)
  133. {
  134. if((SendBuffer[0]==0x06)&&(SendBuffer[1]==0x06))
  135. return TotalRtn;
  136. else
  137. {
  138. DEBUG_INFO_1("SendRequest: not recv ACKACK(%x, %x)\n", SendBuffer[0],SendBuffer[1]);
  139. //read(uart, SendBuffer, RequestLength);
  140. return -1;
  141. }
  142. }
  143. }
  144. else
  145. {
  146. if((time(NULL)-StartTime)>3)
  147. {
  148. DEBUG_INFO_1("SendRequest: read fail (%d / 6)\n", TotalRtn);
  149. return -1;
  150. }
  151. }
  152. }
  153. }
  154. int RecvResponse(int uart, unsigned char* rx)
  155. {
  156. int len, TotalRtn=0, Rtn,i;
  157. unsigned int StartTime;
  158. unsigned char LRC=0, counter=0;
  159. unsigned char RecvBuffer[ResponseLength+4], tmpBuf[16];
  160. reRecv:
  161. len=ResponseLength+3;
  162. memset(RecvBuffer,0,ResponseLength+4);
  163. LRC=0;
  164. TotalRtn=0;
  165. StartTime = time(NULL);
  166. while(1)
  167. {
  168. Rtn=read(uart, RecvBuffer+TotalRtn, len-TotalRtn);
  169. if(Rtn>0)
  170. {
  171. TotalRtn+=Rtn;
  172. //for(int i=0;i<TotalRtn;i++)
  173. //printf("%x",RecvBuffer[i]);
  174. //printf("\n");
  175. if(TotalRtn>=len)
  176. {
  177. if((RecvBuffer[0]!=0x02)||(RecvBuffer[ResponseLength+1]!=0x03))
  178. {
  179. memset(tmpBuf,0,sizeof(tmpBuf));
  180. tmpBuf[0]=tmpBuf[1]=0x06;
  181. Rtn=write(uart, tmpBuf, 2);
  182. DEBUG_INFO_1("RecvResponse: Not Response format (STX=%c , ETX=%c)\n", RecvBuffer[0],RecvBuffer[ResponseLength+1]);
  183. return -1;
  184. }
  185. for(i=1;i<=ResponseLength+1;i++)
  186. {
  187. LRC^=RecvBuffer[i];
  188. }
  189. if(RecvBuffer[ResponseLength+2]!=LRC)
  190. {
  191. if(counter++<2)
  192. {
  193. memset(tmpBuf,0,sizeof(tmpBuf));
  194. tmpBuf[0]=tmpBuf[1]=0x15;
  195. Rtn=write(uart, tmpBuf, 2);
  196. goto reRecv;
  197. }
  198. else
  199. {
  200. memset(tmpBuf,0,sizeof(tmpBuf));
  201. tmpBuf[0]=tmpBuf[1]=0x06;
  202. Rtn=write(uart, tmpBuf, 2);
  203. DEBUG_INFO_1("RecvResponse: 2 times LRC Error (%d / %d)\n", LRC,RecvBuffer[ResponseLength+2]);
  204. return -1;
  205. }
  206. }
  207. memset(tmpBuf,0,sizeof(tmpBuf));
  208. memcpy(tmpBuf,RecvBuffer+1,8 );
  209. if((strstr((char *)tmpBuf,"00000000")==NULL)&&(strstr((char *)tmpBuf,"000000TD")==NULL))
  210. {
  211. DEBUG_INFO_1("RecvResponse: Response Code failed (%s)\n", tmpBuf);
  212. memset(tmpBuf,0,sizeof(tmpBuf));
  213. tmpBuf[0]=tmpBuf[1]=0x06;
  214. Rtn=write(uart, tmpBuf, 2);
  215. return -1;
  216. }
  217. memset(tmpBuf,0,sizeof(tmpBuf));
  218. tmpBuf[0]=tmpBuf[1]=0x06;
  219. Rtn=write(uart, tmpBuf, 2);
  220. memcpy(rx,RecvBuffer+1,ResponseLength);
  221. return ResponseLength;
  222. }
  223. }
  224. else
  225. {
  226. if((time(NULL)-StartTime)>40)//卡機30 seconds timeout
  227. {
  228. DEBUG_INFO_1("RecvResponse: read fail (%d / %d)\n", TotalRtn,len);
  229. return -1;
  230. }
  231. }
  232. }
  233. }
  234. //==========================================
  235. // CreditCardSearch
  236. // Input :
  237. //
  238. // Output :
  239. //==========================================
  240. int CreditCardSearch(int Fd,unsigned char *EVSEID, struct TransInfo *TransInfoReturn)
  241. {
  242. unsigned char Buffer[RequestLength], *ptr;
  243. memset(Buffer,0x20,RequestLength);
  244. ptr=Buffer;
  245. strncpy((char *)ptr,(char *)HOST_ID_Auto,2);//Host ID
  246. ptr+=2;
  247. strncpy((char *)ptr,(char *)TRANS_TYPE_Search,2);//Transaction type
  248. ptr+=2;
  249. /*memset(tmpbuf,0,sizeof(tmpbuf));
  250. sprintf(tmpbuf,"%d", PreCost);
  251. if(strlen(tmpbuf)>12)
  252. {
  253. DEBUG_INFO_1("CreditCardPreAuthCancel: Wrong PreCost (PreCost=%d)\n", PreCost);
  254. return -1;
  255. }
  256. memset(ptr,0x30,12);
  257. strncpy(ptr+12-(strlen(tmpbuf)+2),tmpbuf,strlen(tmpbuf));//Trans Amount
  258. */
  259. ptr+=12;//Trans Amount
  260. //strncpy(ptr,ApprovalNo, strlen(ApprovalNo));
  261. ptr+=12;//Approval No
  262. //strncpy(ptr,CardNum, strlen(CardNum));
  263. ptr+=20;//Card No
  264. strncpy((char *)ptr,(char *)EVSEID, strlen((char *)EVSEID));
  265. ptr+=18;//Store Id
  266. //ptr+=2;//Period
  267. if(SendRequest(Fd, Buffer, RequestLength)>0)
  268. {
  269. memset(Buffer,0,RequestLength);
  270. if(RecvResponse(Fd,Buffer)>0)
  271. {
  272. strncpy((char *)TransInfoReturn->TransDate,(char *)Buffer+56,6);
  273. strncpy((char *)TransInfoReturn->TransTime,(char *)Buffer+62,6);
  274. strncpy((char *)TransInfoReturn->CardNo,(char *)Buffer+24,20);
  275. return 1;
  276. }
  277. else
  278. {
  279. DEBUG_INFO_1("CreditCardUnionSettlement: RecvResponse failed\n");
  280. return -1;
  281. }
  282. }
  283. else
  284. {
  285. DEBUG_INFO_1("CreditCardUnionSettlement: SendRequest failed\n");
  286. return -1;
  287. }
  288. }
  289. //==========================================
  290. // CreditCardPreAuth
  291. // Input :
  292. // PreCost : 預扣金額*100, e.g., $1234 = 123400, $1234.56=123456
  293. // EVSEID: EVSE ID, max length is 18
  294. // Output :
  295. // ApprovalNo : EDC簽單調閱編號或授權碼[信用卡退貨交易, max length is 12
  296. // RRN : 信用卡交易序號, max length is 12
  297. // CardNum: 卡號,max length is 20
  298. // VemData : 無人自助設備交易資訊 交易別31/32 (預授權完成/預授權取消) 必要欄位 資訊來源為交易別13 (預授權)的回傳, max length is 64
  299. //==========================================
  300. int CreditCardPreAuth(int Fd, int PreCost,unsigned char *EVSEID, struct TransInfo *TransInfoReturn)
  301. {
  302. unsigned char Buffer[RequestLength], *ptr, tmpbuf[12];
  303. memset(Buffer,0x20,RequestLength);
  304. ptr=Buffer;
  305. strncpy((char *)ptr,(char *)HOST_ID_CreditCard,2);//Host ID
  306. ptr+=2;
  307. strncpy((char *)ptr,(char *)TRANS_TYPE_Pre_Auth,2);//Transaction type
  308. ptr+=2;
  309. memset(tmpbuf,0,sizeof(tmpbuf));
  310. sprintf((char *)tmpbuf,"%d", PreCost);
  311. if(strlen((char *)tmpbuf)>12)
  312. {
  313. DEBUG_INFO_1("CreditCardPreAuth: Wrong PreCost (PreCost=%d)\n", PreCost);
  314. return -1;
  315. }
  316. memset(ptr,0x30,12);
  317. strncpy((char *)ptr+12-(strlen((char *)tmpbuf)+2),(char *)tmpbuf,strlen((char *)tmpbuf));//Trans Amount
  318. ptr+=12;//Trans Amount
  319. ptr+=12;//Approval No
  320. ptr+=20;//Card No
  321. strncpy((char *)ptr,(char *)EVSEID, strlen((char *)EVSEID));
  322. ptr+=18;//Store Id
  323. //ptr+=2;//Period
  324. if(SendRequest(Fd, Buffer, RequestLength)>0)
  325. {
  326. memset(Buffer,0,RequestLength);
  327. if(RecvResponse(Fd,Buffer)>0)
  328. {
  329. //for(int i=0;i<RequestLength;i++)
  330. //printf("%x, ",Buffer[i] );
  331. strncpy((char *)TransInfoReturn->TransAmount,(char *)Buffer+44,12);
  332. strncpy((char *)TransInfoReturn->TransDate,(char *)Buffer+56,6);
  333. strncpy((char *)TransInfoReturn->TransTime,(char *)Buffer+62,6);
  334. strncpy((char *)TransInfoReturn->StoreId,(char *)Buffer+97,18);
  335. strncpy((char *)TransInfoReturn->ROC,(char *)Buffer+12,12);
  336. strncpy((char *)TransInfoReturn->ApprovalNo,(char *)Buffer+115,9);
  337. strncpy((char *)TransInfoReturn->RRN,(char *)Buffer+124,12);
  338. strncpy((char *)TransInfoReturn->CardNo,(char *)Buffer+24,20);
  339. strncpy((char *)TransInfoReturn->VemData,(char *)Buffer+246,64);
  340. return 1;
  341. }
  342. else
  343. {
  344. DEBUG_INFO_1("CreditCardPreAuth: RecvResponse failed\n");
  345. return -1;
  346. }
  347. }
  348. else
  349. {
  350. DEBUG_INFO_1("CreditCardPreAuth: SendRequest failed\n");
  351. return -1;
  352. }
  353. }
  354. //==========================================
  355. // CreditCardAuthComplete
  356. // Input :
  357. // PreCost : 扣金額*100, e.g., $1234 = 123400, $1234.56=123456
  358. // EVSEID: EVSE ID, max length is 18
  359. // VemData : the VEM data from CreditCardPreAuth, max length is 64
  360. // Output :
  361. //==========================================
  362. int CreditCardPreAuthComplete(int Fd, int PreCost,unsigned char *EVSEID, unsigned char *VemData,struct TransInfo *TransInfoReturn)
  363. {
  364. unsigned char Buffer[RequestLength], *ptr, tmpbuf[12];
  365. memset(Buffer,0x20,RequestLength);
  366. ptr=Buffer;
  367. strncpy((char *)ptr,(char *)HOST_ID_CreditCard,2);//Host ID
  368. ptr+=2;
  369. strncpy((char *)ptr,(char *)TRANS_TYPE_Pre_Auth_Complete,2);//Transaction type
  370. ptr+=2;
  371. memset(tmpbuf,0,sizeof(tmpbuf));
  372. sprintf((char *)tmpbuf,"%d", PreCost);
  373. if(strlen((char *)tmpbuf)>12)
  374. {
  375. DEBUG_INFO_1("CreditCardAuthComplete: Wrong PreCost (PreCost=%d)\n", PreCost);
  376. return -1;
  377. }
  378. memset(ptr,0x30,12);
  379. strncpy((char *)ptr+12-(strlen((char *)tmpbuf)+2),(char *)tmpbuf,strlen((char *)tmpbuf));//Trans Amount
  380. ptr+=12;//Trans Amount
  381. ptr+=12;//Approval No
  382. ptr+=20;//Card No
  383. strncpy((char *)ptr,(char *)EVSEID, strlen((char *)EVSEID));
  384. ptr+=18;//Store Id
  385. //ptr+=2;//Period
  386. strncpy((char *)Buffer+500,(char *)VemData,64);
  387. if(SendRequest(Fd, Buffer, RequestLength)>0)
  388. {
  389. memset(Buffer,0,RequestLength);
  390. if(RecvResponse(Fd,Buffer)>0)
  391. {
  392. strncpy((char *)TransInfoReturn->TransAmount,(char *)Buffer+44,12);
  393. strncpy((char *)TransInfoReturn->TransDate,(char *)Buffer+56,6);
  394. strncpy((char *)TransInfoReturn->TransTime,(char *)Buffer+62,6);
  395. strncpy((char *)TransInfoReturn->StoreId,(char *)Buffer+97,18);
  396. strncpy((char *)TransInfoReturn->ROC,(char *)Buffer+12,12);
  397. strncpy((char *)TransInfoReturn->ApprovalNo,(char *)Buffer+115,9);
  398. strncpy((char *)TransInfoReturn->RRN,(char *)Buffer+124,12);
  399. strncpy((char *)TransInfoReturn->CardNo,(char *)Buffer+24,20);
  400. strncpy((char *)TransInfoReturn->VemData,(char *)Buffer+246,64);
  401. return 1;
  402. }
  403. else
  404. {
  405. DEBUG_INFO_1("CreditCardAuthComplete: RecvResponse failed\n");
  406. return -1;
  407. }
  408. }
  409. else
  410. {
  411. DEBUG_INFO_1("CreditCardAuthComplete: SendRequest failed\n");
  412. return -1;
  413. }
  414. }
  415. //==========================================
  416. // CreditCardPreAuthCancel
  417. // Input :
  418. // PreCost : 預扣金額*100, e.g., $1234 = 123400, $1234.56=123456
  419. // EVSEID: EVSE ID, max length is 18
  420. // ApprovalNo: max length is 12
  421. // CardNum : max length is 20
  422. // Output :
  423. //==========================================
  424. int CreditCardPreAuthCancel(int Fd, int PreCost,unsigned char *EVSEID, unsigned char *ApprovalNo, unsigned char *CardNum,unsigned char *VemData)
  425. {
  426. unsigned char Buffer[RequestLength], *ptr, tmpbuf[12];
  427. memset(Buffer,0x20,RequestLength);
  428. ptr=Buffer;
  429. strncpy((char *)ptr,(char *)HOST_ID_CreditCard,2);//Host ID
  430. ptr+=2;
  431. strncpy((char *)ptr,(char *)TRANS_TYPE_Pre_Auth_Cancel,2);//Transaction type
  432. ptr+=2;
  433. memset(tmpbuf,0,sizeof(tmpbuf));
  434. sprintf((char *)tmpbuf,"%d", PreCost);
  435. if(strlen((char *)tmpbuf)>12)
  436. {
  437. DEBUG_INFO_1("CreditCardPreAuthCancel: Wrong PreCost (PreCost=%d)\n", PreCost);
  438. return -1;
  439. }
  440. memset(ptr,0x30,12);
  441. strncpy((char *)ptr+12-(strlen((char *)tmpbuf)+2),(char *)tmpbuf,strlen((char *)tmpbuf));//Trans Amount
  442. ptr+=12;//Trans Amount
  443. strncpy((char *)ptr,(char *)ApprovalNo, strlen((char *)ApprovalNo));
  444. ptr+=12;//Approval No
  445. strncpy((char *)ptr,(char *)CardNum, strlen((char *)CardNum));
  446. ptr+=20;//Card No
  447. strncpy((char *)ptr,(char *)EVSEID, strlen((char *)EVSEID));
  448. ptr+=18;//Store Id
  449. //ptr+=2;//Period
  450. strncpy((char *)Buffer+500,(char *)VemData,64);
  451. if(SendRequest(Fd, Buffer, RequestLength)>0)
  452. {
  453. memset(Buffer,0,RequestLength);
  454. if(RecvResponse(Fd,Buffer)>0)
  455. {
  456. return 1;
  457. }
  458. else
  459. {
  460. DEBUG_INFO_1("CreditCardPreAuthCancel: RecvResponse failed\n");
  461. return -1;
  462. }
  463. }
  464. else
  465. {
  466. DEBUG_INFO_1("CreditCardPreAuthCancel: SendRequest failed\n");
  467. return -1;
  468. }
  469. }
  470. //==========================================
  471. // CreditCardUnionSettlement
  472. // Input :
  473. //
  474. // Output :
  475. //==========================================
  476. int CreditCardUnionSettlement(int Fd,unsigned char *EVSEID, struct TransInfo *TransInfoReturn)
  477. {
  478. unsigned char Buffer[RequestLength], *ptr;
  479. memset(Buffer,0x20,RequestLength);
  480. ptr=Buffer;
  481. strncpy((char *)ptr,(char *)HOST_ID_CreditCard,2);//Host ID
  482. ptr+=2;
  483. strncpy((char *)ptr,(char *)TRANS_TYPE_UnionSettlement,2);//Transaction type
  484. ptr+=2;
  485. /*memset(tmpbuf,0,sizeof(tmpbuf));
  486. sprintf(tmpbuf,"%d", PreCost);
  487. if(strlen(tmpbuf)>12)
  488. {
  489. DEBUG_INFO_1("CreditCardPreAuthCancel: Wrong PreCost (PreCost=%d)\n", PreCost);
  490. return -1;
  491. }
  492. memset(ptr,0x30,12);
  493. strncpy(ptr+12-(strlen(tmpbuf)+2),tmpbuf,strlen(tmpbuf));//Trans Amount
  494. */
  495. ptr+=12;//Trans Amount
  496. //strncpy(ptr,ApprovalNo, strlen(ApprovalNo));
  497. ptr+=12;//Approval No
  498. //strncpy(ptr,CardNum, strlen(CardNum));
  499. ptr+=20;//Card No
  500. strncpy((char *)ptr,(char *)EVSEID, strlen((char *)EVSEID));
  501. ptr+=18;//Store Id
  502. //ptr+=2;//Period
  503. if(SendRequest(Fd, Buffer, RequestLength)>0)
  504. {
  505. memset(Buffer,0,RequestLength);
  506. if(RecvResponse(Fd,Buffer)>0)
  507. {
  508. strncpy((char *)TransInfoReturn->TransAmount,(char *)Buffer+44,12);
  509. strncpy((char *)TransInfoReturn->TransDate,(char *)Buffer+56,6);
  510. strncpy((char *)TransInfoReturn->TransTime,(char *)Buffer+62,6);
  511. strncpy((char *)TransInfoReturn->StoreId,(char *)Buffer+97,18);
  512. strncpy((char *)TransInfoReturn->ROC,(char *)Buffer+12,12);
  513. strncpy((char *)TransInfoReturn->ApprovalNo,(char *)Buffer+115,9);
  514. strncpy((char *)TransInfoReturn->RRN,(char *)Buffer+124,12);
  515. strncpy((char *)TransInfoReturn->CardNo,(char *)Buffer+24,20);
  516. strncpy((char *)TransInfoReturn->VemData,(char *)Buffer+246,64);
  517. return 1;
  518. }
  519. else
  520. {
  521. DEBUG_INFO_1("CreditCardUnionSettlement: RecvResponse failed\n");
  522. return -1;
  523. }
  524. }
  525. else
  526. {
  527. DEBUG_INFO_1("CreditCardUnionSettlement: SendRequest failed\n");
  528. return -1;
  529. }
  530. }
  531. #if 0
  532. int InitComPort()
  533. {
  534. int fd;
  535. struct termios tios;
  536. fd = open("/dev/ttyS2", O_RDWR);
  537. if(fd<=0)
  538. {
  539. DEBUG_INFO_1("open /dev/ttyS2 NG\n");
  540. return -1;
  541. }
  542. ioctl (fd, TCGETS, &tios);
  543. tios.c_cflag = B115200| CS8 | CLOCAL | CREAD;
  544. tios.c_lflag = 0;
  545. tios.c_iflag = 0;
  546. tios.c_oflag = 0;
  547. tios.c_cc[VMIN]=0;
  548. tios.c_cc[VTIME]=(unsigned char)5; // timeout 500ms
  549. tios.c_lflag=0;
  550. tcflush(fd, TCIFLUSH);
  551. ioctl (fd, TCSETS, &tios);
  552. return fd;
  553. }
  554. int main(int argc, char *argv[])
  555. {
  556. int UartFd;
  557. struct TransInfo ReturnTransInfo;
  558. UartFd=InitComPort();
  559. if(UartFd<0)
  560. {
  561. printf("InitComPort NG\n");
  562. return;
  563. }
  564. //sleep(3);
  565. memset(&ReturnTransInfo,0,sizeof(struct TransInfo));
  566. printf("CreditCardPreAuth......\n");
  567. if(CreditCardPreAuth(UartFd, 1000,"TCC EVSE", &ReturnTransInfo)<=0)
  568. {
  569. printf("CreditCardPreAuth NG\n");
  570. return;
  571. }
  572. printf("ApprovalNo=%s\n",ReturnTransInfo.ApprovalNo);
  573. printf("RRN=%s\n",ReturnTransInfo.RRN);
  574. printf("CardNum=%s\n",ReturnTransInfo.CardNo);
  575. printf("VemData=%s\n",ReturnTransInfo.VemData);
  576. sleep(20);
  577. /*if(CreditCardPreAuthCancel(UartFd, 1000,"TCC EVSE", &ReturnTransInfo.ApprovalNo, &ReturnTransInfo.CardNo,&ReturnTransInfo.VemData)<=0)
  578. {
  579. printf("CreditCardPreAuthCancel NG\n");
  580. //return;
  581. } */
  582. printf("CreditCardPreAuthComplete......\n");
  583. if(CreditCardPreAuthComplete(UartFd, 500,"TCC EVSE", &ReturnTransInfo.VemData, &ReturnTransInfo)<=0)
  584. {
  585. printf("CreditCardPreAuthComplete NG\n");
  586. return;
  587. }
  588. sleep(15);
  589. if(CreditCardUnionSettlement(UartFd,"TCC EVSE",&ReturnTransInfo)<=0)
  590. {
  591. printf("CreditCardUnionSettlement NG\n");
  592. //return;
  593. }
  594. }
  595. #endif