Module_Systex.c 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638
  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. while(1)
  104. {
  105. Rtn=write(uart, SendBuffer+TotalRtn, len-TotalRtn);
  106. if(Rtn>0)
  107. {
  108. TotalRtn+=Rtn;
  109. if(TotalRtn>=len)
  110. {
  111. //printf("Rtn=%d,TotalRtn=%d\n",Rtn,TotalRtn);
  112. break;
  113. }
  114. }
  115. else
  116. {
  117. DEBUG_INFO_1("SendRequest: write fail (%d / %d)\n", TotalRtn,len);
  118. return -1;
  119. }
  120. }
  121. //usleep(100000);
  122. TotalRtn=0;
  123. memset(SendBuffer,0,RequestLength+4);
  124. StartTime = time(NULL);
  125. while(1)
  126. {
  127. Rtn=read(uart, SendBuffer+TotalRtn, 2-TotalRtn);
  128. if(Rtn>0)
  129. {
  130. TotalRtn+=Rtn;
  131. if(TotalRtn>=2)
  132. {
  133. if((SendBuffer[0]==0x06)&&(SendBuffer[1]==0x06))
  134. return TotalRtn;
  135. else
  136. {
  137. DEBUG_INFO_1("SendRequest: not recv ACKACK(%x, %x)\n", SendBuffer[0],SendBuffer[1]);
  138. read(uart, SendBuffer, RequestLength);
  139. return -1;
  140. }
  141. }
  142. }
  143. else
  144. {
  145. if((time(NULL)-StartTime)>3)
  146. {
  147. DEBUG_INFO_1("SendRequest: read fail (%d / 6)\n", TotalRtn);
  148. return -1;
  149. }
  150. }
  151. }
  152. }
  153. int RecvResponse(int uart, unsigned char* rx)
  154. {
  155. int len, TotalRtn=0, Rtn,i;
  156. unsigned int StartTime;
  157. unsigned char LRC=0, counter=0;
  158. unsigned char RecvBuffer[ResponseLength+4], tmpBuf[16];
  159. reRecv:
  160. len=ResponseLength+3;
  161. memset(RecvBuffer,0,ResponseLength+4);
  162. LRC=0;
  163. TotalRtn=0;
  164. StartTime = time(NULL);
  165. while(1)
  166. {
  167. Rtn=read(uart, RecvBuffer+TotalRtn, len-TotalRtn);
  168. if(Rtn>0)
  169. {
  170. TotalRtn+=Rtn;
  171. //for(int i=0;i<TotalRtn;i++)
  172. //printf("%x",RecvBuffer[i]);
  173. //printf("\n");
  174. if(TotalRtn>=len)
  175. {
  176. if((RecvBuffer[0]!=0x02)||(RecvBuffer[ResponseLength+1]!=0x03))
  177. {
  178. memset(tmpBuf,0,sizeof(tmpBuf));
  179. tmpBuf[0]=tmpBuf[1]=0x06;
  180. Rtn=write(uart, tmpBuf, 2);
  181. DEBUG_INFO_1("RecvResponse: Not Response format (STX=%c , ETX=%c)\n", RecvBuffer[0],RecvBuffer[ResponseLength+1]);
  182. return -1;
  183. }
  184. for(i=1;i<=ResponseLength+1;i++)
  185. {
  186. LRC^=RecvBuffer[i];
  187. }
  188. if(RecvBuffer[ResponseLength+2]!=LRC)
  189. {
  190. if(counter++<2)
  191. {
  192. memset(tmpBuf,0,sizeof(tmpBuf));
  193. tmpBuf[0]=tmpBuf[1]=0x15;
  194. Rtn=write(uart, tmpBuf, 2);
  195. goto reRecv;
  196. }
  197. else
  198. {
  199. memset(tmpBuf,0,sizeof(tmpBuf));
  200. tmpBuf[0]=tmpBuf[1]=0x06;
  201. Rtn=write(uart, tmpBuf, 2);
  202. DEBUG_INFO_1("RecvResponse: 2 times LRC Error (%d / %d)\n", LRC,RecvBuffer[ResponseLength+2]);
  203. return -1;
  204. }
  205. }
  206. memset(tmpBuf,0,sizeof(tmpBuf));
  207. memcpy(tmpBuf,RecvBuffer+1,8 );
  208. if((strstr((char *)tmpBuf,"00000000")==NULL)&&(strstr((char *)tmpBuf,"000000TD")==NULL))
  209. {
  210. DEBUG_INFO_1("RecvResponse: Response Code failed (%s)\n", tmpBuf);
  211. memset(tmpBuf,0,sizeof(tmpBuf));
  212. tmpBuf[0]=tmpBuf[1]=0x06;
  213. Rtn=write(uart, tmpBuf, 2);
  214. return -1;
  215. }
  216. memset(tmpBuf,0,sizeof(tmpBuf));
  217. tmpBuf[0]=tmpBuf[1]=0x06;
  218. Rtn=write(uart, tmpBuf, 2);
  219. memcpy(rx,RecvBuffer+1,ResponseLength);
  220. return ResponseLength;
  221. }
  222. }
  223. else
  224. {
  225. if((time(NULL)-StartTime)>40)//卡機30 seconds timeout
  226. {
  227. DEBUG_INFO_1("RecvResponse: read fail (%d / %d)\n", TotalRtn,len);
  228. return -1;
  229. }
  230. }
  231. }
  232. }
  233. //==========================================
  234. // CreditCardSearch
  235. // Input :
  236. //
  237. // Output :
  238. //==========================================
  239. int CreditCardSearch(int Fd,unsigned char *EVSEID, struct TransInfo *TransInfoReturn)
  240. {
  241. unsigned char Buffer[RequestLength], *ptr;
  242. memset(Buffer,0x20,RequestLength);
  243. ptr=Buffer;
  244. strncpy((char *)ptr,(char *)HOST_ID_Auto,2);//Host ID
  245. ptr+=2;
  246. strncpy((char *)ptr,(char *)TRANS_TYPE_Search,2);//Transaction type
  247. ptr+=2;
  248. /*memset(tmpbuf,0,sizeof(tmpbuf));
  249. sprintf(tmpbuf,"%d", PreCost);
  250. if(strlen(tmpbuf)>12)
  251. {
  252. DEBUG_INFO_1("CreditCardPreAuthCancel: Wrong PreCost (PreCost=%d)\n", PreCost);
  253. return -1;
  254. }
  255. memset(ptr,0x30,12);
  256. strncpy(ptr+12-(strlen(tmpbuf)+2),tmpbuf,strlen(tmpbuf));//Trans Amount
  257. */
  258. ptr+=12;//Trans Amount
  259. //strncpy(ptr,ApprovalNo, strlen(ApprovalNo));
  260. ptr+=12;//Approval No
  261. //strncpy(ptr,CardNum, strlen(CardNum));
  262. ptr+=20;//Card No
  263. strncpy((char *)ptr,(char *)EVSEID, strlen((char *)EVSEID));
  264. ptr+=18;//Store Id
  265. //ptr+=2;//Period
  266. if(SendRequest(Fd, Buffer, RequestLength)>0)
  267. {
  268. memset(Buffer,0,RequestLength);
  269. if(RecvResponse(Fd,Buffer)>0)
  270. {
  271. strncpy((char *)TransInfoReturn->TransDate,(char *)Buffer+56,6);
  272. strncpy((char *)TransInfoReturn->TransTime,(char *)Buffer+62,6);
  273. strncpy((char *)TransInfoReturn->CardNo,(char *)Buffer+24,20);
  274. return 1;
  275. }
  276. else
  277. {
  278. DEBUG_INFO_1("CreditCardUnionSettlement: RecvResponse failed\n");
  279. return -1;
  280. }
  281. }
  282. else
  283. {
  284. DEBUG_INFO_1("CreditCardUnionSettlement: SendRequest failed\n");
  285. return -1;
  286. }
  287. }
  288. //==========================================
  289. // CreditCardPreAuth
  290. // Input :
  291. // PreCost : 預扣金額*100, e.g., $1234 = 123400, $1234.56=123456
  292. // EVSEID: EVSE ID, max length is 18
  293. // Output :
  294. // ApprovalNo : EDC簽單調閱編號或授權碼[信用卡退貨交易, max length is 12
  295. // RRN : 信用卡交易序號, max length is 12
  296. // CardNum: 卡號,max length is 20
  297. // VemData : 無人自助設備交易資訊 交易別31/32 (預授權完成/預授權取消) 必要欄位 資訊來源為交易別13 (預授權)的回傳, max length is 64
  298. //==========================================
  299. int CreditCardPreAuth(int Fd, int PreCost,unsigned char *EVSEID, struct TransInfo *TransInfoReturn)
  300. {
  301. unsigned char Buffer[RequestLength], *ptr, tmpbuf[12];
  302. memset(Buffer,0x20,RequestLength);
  303. ptr=Buffer;
  304. strncpy((char *)ptr,(char *)HOST_ID_CreditCard,2);//Host ID
  305. ptr+=2;
  306. strncpy((char *)ptr,(char *)TRANS_TYPE_Pre_Auth,2);//Transaction type
  307. ptr+=2;
  308. memset(tmpbuf,0,sizeof(tmpbuf));
  309. sprintf((char *)tmpbuf,"%d", PreCost);
  310. if(strlen((char *)tmpbuf)>12)
  311. {
  312. DEBUG_INFO_1("CreditCardPreAuth: Wrong PreCost (PreCost=%d)\n", PreCost);
  313. return -1;
  314. }
  315. memset(ptr,0x30,12);
  316. strncpy((char *)ptr+12-(strlen((char *)tmpbuf)+2),(char *)tmpbuf,strlen((char *)tmpbuf));//Trans Amount
  317. ptr+=12;//Trans Amount
  318. ptr+=12;//Approval No
  319. ptr+=20;//Card No
  320. strncpy((char *)ptr,(char *)EVSEID, strlen((char *)EVSEID));
  321. ptr+=18;//Store Id
  322. //ptr+=2;//Period
  323. if(SendRequest(Fd, Buffer, RequestLength)>0)
  324. {
  325. memset(Buffer,0,RequestLength);
  326. if(RecvResponse(Fd,Buffer)>0)
  327. {
  328. //for(int i=0;i<RequestLength;i++)
  329. //printf("%x, ",Buffer[i] );
  330. strncpy((char *)TransInfoReturn->TransAmount,(char *)Buffer+44,12);
  331. strncpy((char *)TransInfoReturn->TransDate,(char *)Buffer+56,6);
  332. strncpy((char *)TransInfoReturn->TransTime,(char *)Buffer+62,6);
  333. strncpy((char *)TransInfoReturn->StoreId,(char *)Buffer+97,18);
  334. strncpy((char *)TransInfoReturn->ROC,(char *)Buffer+12,12);
  335. strncpy((char *)TransInfoReturn->ApprovalNo,(char *)Buffer+115,9);
  336. strncpy((char *)TransInfoReturn->RRN,(char *)Buffer+124,12);
  337. strncpy((char *)TransInfoReturn->CardNo,(char *)Buffer+24,20);
  338. strncpy((char *)TransInfoReturn->VemData,(char *)Buffer+246,64);
  339. return 1;
  340. }
  341. else
  342. {
  343. DEBUG_INFO_1("CreditCardPreAuth: RecvResponse failed\n");
  344. return -1;
  345. }
  346. }
  347. else
  348. {
  349. DEBUG_INFO_1("CreditCardPreAuth: SendRequest failed\n");
  350. return -1;
  351. }
  352. }
  353. //==========================================
  354. // CreditCardAuthComplete
  355. // Input :
  356. // PreCost : 扣金額*100, e.g., $1234 = 123400, $1234.56=123456
  357. // EVSEID: EVSE ID, max length is 18
  358. // VemData : the VEM data from CreditCardPreAuth, max length is 64
  359. // Output :
  360. //==========================================
  361. int CreditCardPreAuthComplete(int Fd, int PreCost,unsigned char *EVSEID, unsigned char *VemData,struct TransInfo *TransInfoReturn)
  362. {
  363. unsigned char Buffer[RequestLength], *ptr, tmpbuf[12];
  364. memset(Buffer,0x20,RequestLength);
  365. ptr=Buffer;
  366. strncpy((char *)ptr,(char *)HOST_ID_CreditCard,2);//Host ID
  367. ptr+=2;
  368. strncpy((char *)ptr,(char *)TRANS_TYPE_Pre_Auth_Complete,2);//Transaction type
  369. ptr+=2;
  370. memset(tmpbuf,0,sizeof(tmpbuf));
  371. sprintf((char *)tmpbuf,"%d", PreCost);
  372. if(strlen((char *)tmpbuf)>12)
  373. {
  374. DEBUG_INFO_1("CreditCardAuthComplete: Wrong PreCost (PreCost=%d)\n", PreCost);
  375. return -1;
  376. }
  377. memset(ptr,0x30,12);
  378. strncpy((char *)ptr+12-(strlen((char *)tmpbuf)+2),(char *)tmpbuf,strlen((char *)tmpbuf));//Trans Amount
  379. ptr+=12;//Trans Amount
  380. ptr+=12;//Approval No
  381. ptr+=20;//Card No
  382. strncpy((char *)ptr,(char *)EVSEID, strlen((char *)EVSEID));
  383. ptr+=18;//Store Id
  384. //ptr+=2;//Period
  385. strncpy((char *)Buffer+500,(char *)VemData,64);
  386. if(SendRequest(Fd, Buffer, RequestLength)>0)
  387. {
  388. memset(Buffer,0,RequestLength);
  389. if(RecvResponse(Fd,Buffer)>0)
  390. {
  391. strncpy((char *)TransInfoReturn->TransAmount,(char *)Buffer+44,12);
  392. strncpy((char *)TransInfoReturn->TransDate,(char *)Buffer+56,6);
  393. strncpy((char *)TransInfoReturn->TransTime,(char *)Buffer+62,6);
  394. strncpy((char *)TransInfoReturn->StoreId,(char *)Buffer+97,18);
  395. strncpy((char *)TransInfoReturn->ROC,(char *)Buffer+12,12);
  396. strncpy((char *)TransInfoReturn->ApprovalNo,(char *)Buffer+115,9);
  397. strncpy((char *)TransInfoReturn->RRN,(char *)Buffer+124,12);
  398. strncpy((char *)TransInfoReturn->CardNo,(char *)Buffer+24,20);
  399. strncpy((char *)TransInfoReturn->VemData,(char *)Buffer+246,64);
  400. return 1;
  401. }
  402. else
  403. {
  404. DEBUG_INFO_1("CreditCardAuthComplete: RecvResponse failed\n");
  405. return -1;
  406. }
  407. }
  408. else
  409. {
  410. DEBUG_INFO_1("CreditCardAuthComplete: SendRequest failed\n");
  411. return -1;
  412. }
  413. }
  414. //==========================================
  415. // CreditCardPreAuthCancel
  416. // Input :
  417. // PreCost : 預扣金額*100, e.g., $1234 = 123400, $1234.56=123456
  418. // EVSEID: EVSE ID, max length is 18
  419. // ApprovalNo: max length is 12
  420. // CardNum : max length is 20
  421. // Output :
  422. //==========================================
  423. int CreditCardPreAuthCancel(int Fd, int PreCost,unsigned char *EVSEID, unsigned char *ApprovalNo, unsigned char *CardNum,unsigned char *VemData)
  424. {
  425. unsigned char Buffer[RequestLength], *ptr, tmpbuf[12];
  426. memset(Buffer,0x20,RequestLength);
  427. ptr=Buffer;
  428. strncpy((char *)ptr,(char *)HOST_ID_CreditCard,2);//Host ID
  429. ptr+=2;
  430. strncpy((char *)ptr,(char *)TRANS_TYPE_Pre_Auth_Cancel,2);//Transaction type
  431. ptr+=2;
  432. memset(tmpbuf,0,sizeof(tmpbuf));
  433. sprintf((char *)tmpbuf,"%d", PreCost);
  434. if(strlen((char *)tmpbuf)>12)
  435. {
  436. DEBUG_INFO_1("CreditCardPreAuthCancel: Wrong PreCost (PreCost=%d)\n", PreCost);
  437. return -1;
  438. }
  439. memset(ptr,0x30,12);
  440. strncpy((char *)ptr+12-(strlen((char *)tmpbuf)+2),(char *)tmpbuf,strlen((char *)tmpbuf));//Trans Amount
  441. ptr+=12;//Trans Amount
  442. strncpy((char *)ptr,(char *)ApprovalNo, strlen((char *)ApprovalNo));
  443. ptr+=12;//Approval No
  444. strncpy((char *)ptr,(char *)CardNum, strlen((char *)CardNum));
  445. ptr+=20;//Card No
  446. strncpy((char *)ptr,(char *)EVSEID, strlen((char *)EVSEID));
  447. ptr+=18;//Store Id
  448. //ptr+=2;//Period
  449. strncpy((char *)Buffer+500,(char *)VemData,64);
  450. if(SendRequest(Fd, Buffer, RequestLength)>0)
  451. {
  452. memset(Buffer,0,RequestLength);
  453. if(RecvResponse(Fd,Buffer)>0)
  454. {
  455. return 1;
  456. }
  457. else
  458. {
  459. DEBUG_INFO_1("CreditCardPreAuthCancel: RecvResponse failed\n");
  460. return -1;
  461. }
  462. }
  463. else
  464. {
  465. DEBUG_INFO_1("CreditCardPreAuthCancel: SendRequest failed\n");
  466. return -1;
  467. }
  468. }
  469. //==========================================
  470. // CreditCardUnionSettlement
  471. // Input :
  472. //
  473. // Output :
  474. //==========================================
  475. int CreditCardUnionSettlement(int Fd,unsigned char *EVSEID, struct TransInfo *TransInfoReturn)
  476. {
  477. unsigned char Buffer[RequestLength], *ptr;
  478. memset(Buffer,0x20,RequestLength);
  479. ptr=Buffer;
  480. strncpy((char *)ptr,(char *)HOST_ID_CreditCard,2);//Host ID
  481. ptr+=2;
  482. strncpy((char *)ptr,(char *)TRANS_TYPE_UnionSettlement,2);//Transaction type
  483. ptr+=2;
  484. /*memset(tmpbuf,0,sizeof(tmpbuf));
  485. sprintf(tmpbuf,"%d", PreCost);
  486. if(strlen(tmpbuf)>12)
  487. {
  488. DEBUG_INFO_1("CreditCardPreAuthCancel: Wrong PreCost (PreCost=%d)\n", PreCost);
  489. return -1;
  490. }
  491. memset(ptr,0x30,12);
  492. strncpy(ptr+12-(strlen(tmpbuf)+2),tmpbuf,strlen(tmpbuf));//Trans Amount
  493. */
  494. ptr+=12;//Trans Amount
  495. //strncpy(ptr,ApprovalNo, strlen(ApprovalNo));
  496. ptr+=12;//Approval No
  497. //strncpy(ptr,CardNum, strlen(CardNum));
  498. ptr+=20;//Card No
  499. strncpy((char *)ptr,(char *)EVSEID, strlen((char *)EVSEID));
  500. ptr+=18;//Store Id
  501. //ptr+=2;//Period
  502. if(SendRequest(Fd, Buffer, RequestLength)>0)
  503. {
  504. memset(Buffer,0,RequestLength);
  505. if(RecvResponse(Fd,Buffer)>0)
  506. {
  507. strncpy((char *)TransInfoReturn->TransAmount,(char *)Buffer+44,12);
  508. strncpy((char *)TransInfoReturn->TransDate,(char *)Buffer+56,6);
  509. strncpy((char *)TransInfoReturn->TransTime,(char *)Buffer+62,6);
  510. strncpy((char *)TransInfoReturn->StoreId,(char *)Buffer+97,18);
  511. strncpy((char *)TransInfoReturn->ROC,(char *)Buffer+12,12);
  512. strncpy((char *)TransInfoReturn->ApprovalNo,(char *)Buffer+115,9);
  513. strncpy((char *)TransInfoReturn->RRN,(char *)Buffer+124,12);
  514. strncpy((char *)TransInfoReturn->CardNo,(char *)Buffer+24,20);
  515. strncpy((char *)TransInfoReturn->VemData,(char *)Buffer+246,64);
  516. return 1;
  517. }
  518. else
  519. {
  520. DEBUG_INFO_1("CreditCardUnionSettlement: RecvResponse failed\n");
  521. return -1;
  522. }
  523. }
  524. else
  525. {
  526. DEBUG_INFO_1("CreditCardUnionSettlement: SendRequest failed\n");
  527. return -1;
  528. }
  529. }
  530. #if 0
  531. int InitComPort()
  532. {
  533. int fd;
  534. struct termios tios;
  535. fd = open("/dev/ttyS2", O_RDWR);
  536. if(fd<=0)
  537. {
  538. DEBUG_INFO_1("open /dev/ttyS2 NG\n");
  539. return -1;
  540. }
  541. ioctl (fd, TCGETS, &tios);
  542. tios.c_cflag = B115200| CS8 | CLOCAL | CREAD;
  543. tios.c_lflag = 0;
  544. tios.c_iflag = 0;
  545. tios.c_oflag = 0;
  546. tios.c_cc[VMIN]=0;
  547. tios.c_cc[VTIME]=(unsigned char)5; // timeout 500ms
  548. tios.c_lflag=0;
  549. tcflush(fd, TCIFLUSH);
  550. ioctl (fd, TCSETS, &tios);
  551. return fd;
  552. }
  553. int main(int argc, char *argv[])
  554. {
  555. int UartFd;
  556. struct TransInfo ReturnTransInfo;
  557. UartFd=InitComPort();
  558. if(UartFd<0)
  559. {
  560. printf("InitComPort NG\n");
  561. return;
  562. }
  563. //sleep(3);
  564. memset(&ReturnTransInfo,0,sizeof(struct TransInfo));
  565. printf("CreditCardPreAuth......\n");
  566. if(CreditCardPreAuth(UartFd, 1000,"TCC EVSE", &ReturnTransInfo)<=0)
  567. {
  568. printf("CreditCardPreAuth NG\n");
  569. return;
  570. }
  571. printf("ApprovalNo=%s\n",ReturnTransInfo.ApprovalNo);
  572. printf("RRN=%s\n",ReturnTransInfo.RRN);
  573. printf("CardNum=%s\n",ReturnTransInfo.CardNo);
  574. printf("VemData=%s\n",ReturnTransInfo.VemData);
  575. sleep(20);
  576. /*if(CreditCardPreAuthCancel(UartFd, 1000,"TCC EVSE", &ReturnTransInfo.ApprovalNo, &ReturnTransInfo.CardNo,&ReturnTransInfo.VemData)<=0)
  577. {
  578. printf("CreditCardPreAuthCancel NG\n");
  579. //return;
  580. } */
  581. printf("CreditCardPreAuthComplete......\n");
  582. if(CreditCardPreAuthComplete(UartFd, 500,"TCC EVSE", &ReturnTransInfo.VemData, &ReturnTransInfo)<=0)
  583. {
  584. printf("CreditCardPreAuthComplete NG\n");
  585. return;
  586. }
  587. sleep(15);
  588. if(CreditCardUnionSettlement(UartFd,"TCC EVSE",&ReturnTransInfo)<=0)
  589. {
  590. printf("CreditCardUnionSettlement NG\n");
  591. //return;
  592. }
  593. }
  594. #endif