Эх сурвалжийг харах

Merge remote-tracking branch 'origin/DD360Tcci'

FolusWen 3 жил өмнө
parent
commit
735bae93e6
25 өөрчлөгдсөн 878 нэмэгдсэн , 583 устгасан
  1. 6 2
      EVSE/Projects/DD360Tcci/Apps/CSU/Module_Systex.h
  2. 204 141
      EVSE/Projects/DD360Tcci/Apps/CSU/RFID.c
  3. 161 81
      EVSE/Projects/DD360Tcci/Apps/CSU/main.c
  4. 1 0
      EVSE/Projects/DD360Tcci/Apps/CSU/main.h
  5. 23 16
      EVSE/Projects/DD360Tcci/Apps/Config.h
  6. 150 66
      EVSE/Projects/DD360Tcci/Apps/DataBase/DataBase.c
  7. 1 0
      EVSE/Projects/DD360Tcci/Apps/ModuleChkSysTask/Module_ChkSysTask.c
  8. 128 106
      EVSE/Projects/DD360Tcci/Apps/ModuleDoComm/DoComm.c
  9. 1 1
      EVSE/Projects/DD360Tcci/Apps/ModuleDoComm/DoComm.h
  10. 179 168
      EVSE/Projects/DD360Tcci/Apps/ModuleLcmCtrl/Module_LcmControl.c
  11. 8 2
      EVSE/Projects/DD360Tcci/Apps/ReadCmdline.c
  12. 1 0
      EVSE/Projects/DD360Tcci/Apps/timeout.h
  13. BIN
      EVSE/Projects/DD360Tcci/Images/ramdisk.gz
  14. BIN
      EVSE/Projects/DD360Tcci/output/FactoryConfig
  15. BIN
      EVSE/Projects/DD360Tcci/output/Module_ChkSysTask
  16. BIN
      EVSE/Projects/DD360Tcci/output/Module_DoComm
  17. BIN
      EVSE/Projects/DD360Tcci/output/Module_EvComm
  18. BIN
      EVSE/Projects/DD360Tcci/output/Module_EventLogging
  19. BIN
      EVSE/Projects/DD360Tcci/output/Module_InternalComm
  20. BIN
      EVSE/Projects/DD360Tcci/output/Module_LcmControl
  21. BIN
      EVSE/Projects/DD360Tcci/output/Module_PrimaryComm
  22. BIN
      EVSE/Projects/DD360Tcci/output/Module_UpdateFW
  23. BIN
      EVSE/Projects/DD360Tcci/output/ReadCmdline
  24. BIN
      EVSE/Projects/DD360Tcci/output/main
  25. 15 0
      build_rootfs_copy.sh

+ 6 - 2
EVSE/Projects/DD360Tcci/Apps/CSU/Module_Systex.h

@@ -53,7 +53,8 @@ struct TransInfo
 {
 	unsigned char TransDate[6];	//交易日期
 	unsigned char TransTime[6];	//交易時間
-	unsigned char ApprovalNo[12];		//EDC簽單調閱編號或授權碼[信用卡退貨交易] (左靠右補空白)
+	unsigned char ROC[12];		//EDC簽單調閱編號 (左靠右補空白)
+	unsigned char ApprovalNo[9];		//授權碼[信用卡退貨交易] (左靠右補空白)
 	unsigned char StoreId[18];		//櫃號,機號,發票號碼(左靠右補空白)
 	unsigned char RRN[12];		//信用卡交易序號
 	unsigned char CardNo[20];		//卡號(左靠右補空白),卡號部份隱藏
@@ -61,7 +62,10 @@ struct TransInfo
 	unsigned char VemData[64];		//無人自助設備交易資訊 交易別31/32 (預授權完成/預授權取消) 必要欄位 資訊來源為交易別13 (預授權)的回傳
 };
 
+int CreditCardSearch(int Fd,unsigned char *EVSEID, struct TransInfo *TransInfoReturn);
 int CreditCardPreAuth(int Fd, int PreCost,unsigned char *EVSEID, struct TransInfo *TransInfoReturn);
 int CreditCardPreAuthComplete(int Fd, int PreCost,unsigned char *EVSEID, unsigned char *VemData,struct TransInfo *TransInfoReturn);
-int CreditCardPreAuthCancel(int Fd, int PreCost,unsigned char *EVSEID, unsigned char *ApprovalNo, unsigned char *CardNum);
+int CreditCardPreAuthCancel(int Fd, int PreCost,unsigned char *EVSEID, unsigned char *ApprovalNo, unsigned char *CardNum,unsigned char *VemData);
+int CreditCardUnionSettlement(int Fd,unsigned char *EVSEID,struct TransInfo *TransInfoReturn);
+
 #endif

+ 204 - 141
EVSE/Projects/DD360Tcci/Apps/CSU/RFID.c

@@ -15,7 +15,7 @@
 static DcCommonInfo *ShmDcCommonData 			= NULL;
 static SelectGunInfo *ShmSelectGunInfo          = NULL;
 static struct SysInfoData *pSysInfo 			= NULL;
-#define PREAUTHMONEY	1000
+#define PREAUTHMONEY	888
 bool isDeductDb_ready;
 static RecordTransactionInfo LocalTransactionInfo;
 //------------------------------------------------------------------------------
@@ -81,7 +81,7 @@ bool isAutorCompleteHandle(/*uint8_t *authorizeIndex*/)
 
         ClearAuthorizedFlag();
 
-    } /*else if (pSysConfig->OfflinePolicy == _OFFLINE_POLICY_LOCAL_LIST) {
+    } else if (pSysConfig->OfflinePolicy == _OFFLINE_POLICY_LOCAL_LIST) {
         // 白名單驗證
         for (i = 0; i < 10; i++) {
             if (strcmp((char *)pSysConfig->LocalWhiteCard[i], "") == EQUAL) {
@@ -130,16 +130,16 @@ bool RfidStopCharging(void)
 }
 static void UserScanFunction(void)
 {
-    bool idleReq = false;
-    uint8_t i = 0;
-    uint8_t stopReq = NO_DEFINE;
-    char value[32] = {0};
-    static uint8_t _authorizeIndex = NO_DEFINE;
+   // bool idleReq = false;
+    //uint8_t i = 0;
+    //uint8_t stopReq = NO_DEFINE;
+    //char value[32] = {0};
+    //static uint8_t _authorizeIndex = NO_DEFINE;
     struct SysConfigData *pSysConfig = (struct SysConfigData *)GetShmSysConfigData();
     struct SysInfoData *pSysInfo = (struct SysInfoData *)GetShmSysInfoData();
-    struct ChargingInfoData *pAcChargingInfo =  (struct ChargingInfoData *)GetAcChargingInfoData(0);
+    //struct ChargingInfoData *pAcChargingInfo =  (struct ChargingInfoData *)GetAcChargingInfoData(0);
     struct ChargingInfoData *pDcChargingInfo = NULL;
-    GunIndexInfo *pGunIndexInfo = (GunIndexInfo *)GetGunIndexInfo();
+    //GunIndexInfo *pGunIndexInfo = (GunIndexInfo *)GetGunIndexInfo();
 
     // 當前非驗證的狀態
     if (IsAuthorizingMode()) {
@@ -271,9 +271,9 @@ void AuthorizeToCharge()
 {
     struct SysConfigData *pSysConfig = (struct SysConfigData *)GetShmSysConfigData();
     struct SysInfoData *pSysInfo = (struct SysInfoData *)GetShmSysInfoData();
-    SelectGunInfo *ShmSelectGunInfo = (SelectGunInfo *)GetShmSelectGunInfo();
-    struct ChargingInfoData *pDcChargingInfo = NULL;
-    pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(pSysInfo->CurGunSelected);
+   // SelectGunInfo *ShmSelectGunInfo = (SelectGunInfo *)GetShmSelectGunInfo();
+   // struct ChargingInfoData *pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(pSysInfo->CurGunSelected);;
+
     ShmDcCommonData = (DcCommonInfo *)GetShmDcCommonData();
     if(isAuthorizedComplete())
     {
@@ -295,7 +295,7 @@ void AuthorizeToCharge()
 }
 void ScannerCardProcess(void)
 {
-    struct SysConfigData *pSysConfig = (struct SysConfigData *)GetShmSysConfigData();
+    //struct SysConfigData *pSysConfig = (struct SysConfigData *)GetShmSysConfigData();
     struct SysInfoData *pSysInfo = (struct SysInfoData *)GetShmSysInfoData();
     struct WARNING_CODE_INFO *pSysWarning = (struct WARNING_CODE_INFO *)GetShmSysWarningInfo();
     struct ChargingInfoData *pDcChargingInfo = NULL;
@@ -324,13 +324,11 @@ void ScannerCardProcess(void)
 
 void WritePayResult(int result ,uint8_t gunIndex)
 {
-	ShmDcCommonData->TransactionInfo[gunIndex].Amount = LocalTransactionInfo.Amount;
-	memcpy(ShmDcCommonData->TransactionInfo[gunIndex].ApprovalNo , LocalTransactionInfo.ApprovalNo,9);
-	memcpy(ShmDcCommonData->TransactionInfo[gunIndex].CardNo , LocalTransactionInfo.CardNo,20);
-	ShmDcCommonData->TransactionInfo[gunIndex].DeductResult = result;
-	ShmDcCommonData->TransactionInfo[gunIndex].IsDonateInvoice = LocalTransactionInfo.IsDonateInvoice;
-	ShmDcCommonData->TransactionInfo[gunIndex].TransactionId = LocalTransactionInfo.TransactionId;
-	memcpy(ShmDcCommonData->TransactionInfo[gunIndex].VemData, LocalTransactionInfo.VemData,64);
+    memcpy(&ShmDcCommonData->TransactionInfo[gunIndex], &LocalTransactionInfo, sizeof(RecordTransactionInfo));
+    if (result == TRUE)
+        ShmDcCommonData->TransactionInfo[gunIndex].DeductResult = _DEDUCT_COMPLETE_PASS;
+    else
+        ShmDcCommonData->TransactionInfo[gunIndex].DeductResult = _DEDUCT_COMPLETE_FAIL;
 
     log_info("Gun[%d] TransactionId:%d DeductResult:%d IsDonateInvoice:%d Amount:%f",
         gunIndex, ShmDcCommonData->TransactionInfo[gunIndex].TransactionId,
@@ -341,44 +339,125 @@ void WritePayResult(int result ,uint8_t gunIndex)
 void storePayResult(uint8_t gunIndex)
 {
     memset(&LocalTransactionInfo, 0, sizeof(RecordTransactionInfo));
-    LocalTransactionInfo.Amount = ShmDcCommonData->finalcost[gunIndex];
-    memcpy(LocalTransactionInfo.ApprovalNo, ShmDcCommonData->pCreditCard[gunIndex].ApprovalNo, 9);
-    memcpy(LocalTransactionInfo.CardNo, ShmDcCommonData->pCreditCard[gunIndex].CardNo, 20);
-    LocalTransactionInfo.IsDonateInvoice = ShmDcCommonData->donate_flag[gunIndex];
-    LocalTransactionInfo.TransactionId = ShmSelectGunInfo->PricesInfo[gunIndex].TransactionId;
-    memcpy(LocalTransactionInfo.VemData, ShmDcCommonData->pCreditCard[gunIndex].VemData, 64);
+    memcpy(&LocalTransactionInfo, &ShmDcCommonData->TransactionInfo[gunIndex] ,sizeof(RecordTransactionInfo));
+    //LocalTransactionInfo.Amount = ShmDcCommonData->finalcost[gunIndex];
 }
 void PreAuthCompleteToCardReader(int fd,uint8_t gunIndex)
 {
+    struct SysConfigData* pSysConfig = (struct SysConfigData*)GetShmSysConfigData();
 	int result = 0;
 
-    if (ShmDcCommonData->finalcost[gunIndex] > 0 && ShmDcCommonData->finalcost[gunIndex] < 1) {
-        log_info("final cost less 1 : %f", ShmDcCommonData->finalcost[gunIndex]);
-        ShmDcCommonData->finalcost[gunIndex] = 1;
+    if (ShmDcCommonData->TransactionInfo[gunIndex].Amount > 0 && ShmDcCommonData->TransactionInfo[gunIndex].Amount < 1) {
+        log_info("final cost less 1 : %f", ShmDcCommonData->TransactionInfo[gunIndex].Amount);
+        ShmDcCommonData->TransactionInfo[gunIndex].Amount = 1;
     }
     storePayResult(gunIndex);
 
-	result = CreditCardPreAuthComplete(fd,(int)ShmDcCommonData->finalcost[gunIndex], "TCC Test",
-											&ShmDcCommonData->pCreditCard[gunIndex].VemData[0],
-											&ShmDcCommonData->pCreditCard[gunIndex]);
-
-	//result = 1;
+	result = CreditCardPreAuthComplete(fd,(int)ShmDcCommonData->TransactionInfo[gunIndex].Amount, &pSysConfig->ModelName[0],
+											&ShmDcCommonData->TransactionInfo[gunIndex].pCreditCard.VemData[0],
+											&ShmDcCommonData->TransactionInfo[gunIndex].pCreditCard);
     sleep(10);
-    ShmDcCommonData->PayFinish[gunIndex] = TRUE;
 	if (result > 0 ) {
 		log_info("Credit Card Spend Money:%.1f", LocalTransactionInfo.Amount);
 		pSysInfo->SystemPage = _PAGE_COMPLETE;
+        LocalTransactionInfo.DeductResult = _DEDUCT_COMPLETE_PASS;
 		WritePayResult(TRUE,gunIndex);
         ShmDcCommonData->PayPass_flag[gunIndex] = TRUE;
 	} else {
 		log_info("PAYING FAIL");
 		ShmDcCommonData->PayPass_flag[gunIndex] = FALSE;
 		pSysInfo->SystemPage = _PAGE_PAYFAIL;
+        LocalTransactionInfo.DeductResult = _DEDUCT_COMPLETE_FAIL;
 		WritePayResult(FALSE,gunIndex);
 	}
-	if (isDeductDb_ready == TRUE) {
-		InsertDeductInfo(gunIndex,&ShmDcCommonData->TransactionInfo[gunIndex]);
-	}
+    ShmDcCommonData->TransactionInfo[gunIndex].IsUpload = FALSE;
+    UpdateDeductInfoStatus(gunIndex, &ShmDcCommonData->TransactionInfo[gunIndex]);
+
+}
+int CreditCardCancelPreAuth(int fd, uint8_t gunIndex)
+{
+    struct SysConfigData* pSysConfig = (struct SysConfigData*)GetShmSysConfigData();
+    ShmDcCommonData->PreAuth_Result = CreditCardPreAuthCancel(fd, PREAUTHMONEY, &pSysConfig->ModelName[0],
+        &ShmDcCommonData->TransactionInfo[gunIndex].pCreditCard.ApprovalNo[0],
+        &ShmDcCommonData->TransactionInfo[gunIndex].pCreditCard.CardNo[0],
+        &ShmDcCommonData->TransactionInfo[gunIndex].pCreditCard.VemData[0]);
+    sleep(10);
+    if (ShmDcCommonData->PreAuth_Result >= 0) {
+        strcpy((char*)pSysConfig->UserId, "");
+        //ShmDcCommonData->PayFinish[gunIndex] = TRUE;
+        log_info("Card Reader PreAuth Cancel Success");
+        ShmDcCommonData->TransactionInfo[gunIndex].DeductResult = _DEDUCT_CANCEL;
+    } else if (ShmDcCommonData->PreAuth_Result < 0) {
+        log_info("Card Reader PreAuth Cancel Failure");
+        ShmDcCommonData->TransactionInfo[gunIndex].DeductResult = _DEDUCT_PREAUTH;
+    }
+    ShmDcCommonData->TransactionInfo[gunIndex].IsUpload = FALSE;
+    UpdateDeductInfoStatus(gunIndex, &ShmDcCommonData->TransactionInfo[gunIndex]);
+    memset(&ShmDcCommonData->TransactionInfo[gunIndex], 0x00, sizeof(RecordTransactionInfo));
+    ShmDcCommonData->PreAuth_Config = _CREDITCARD_IDLE;
+    return ShmDcCommonData->PreAuth_Result;
+}
+
+void ReDeductProcess(int fd)
+{
+    struct SysConfigData* pSysConfig = (struct SysConfigData*)GetShmSysConfigData();
+    int j;
+    int result;
+    int rededuct_gunIndex[128];
+    RecordTransactionInfo deductInfo[128];
+    int rededuct_num = 0;
+    rededuct_num = DB_GetMultiReDeductInfo(&rededuct_gunIndex[0], &deductInfo[0]);
+
+    if (rededuct_num == 0)
+        log_info("No Rededuct Information");
+    else {
+        log_info("Rededuct Total Number:%d", rededuct_num);
+        for (j = 0; j < rededuct_num; j++) {
+            if (pSysInfo->SystemPage != _PAGE_IDLE && !ShmDcCommonData->Exe_ReDeduct) {
+                ShmDcCommonData->RoutineReduct = FALSE;
+                break;
+            }
+            log_info("Start Rededuct item [%d]",j);
+            if (deductInfo[j].isIntoCharge == FALSE || deductInfo[j].Energy == 0) {
+                // 未進入充電或度數等於零
+                result = CreditCardPreAuthCancel(fd, PREAUTHMONEY, &pSysConfig->ModelName[0],
+                    &deductInfo[j].pCreditCard.ApprovalNo[0],
+                    &deductInfo[j].pCreditCard.CardNo[0],
+                    &deductInfo[j].pCreditCard.VemData[0]);
+                sleep(10);
+                if (result > 0) {
+                    deductInfo[j].DeductResult = _DEDUCT_CANCEL;
+                    log_info("Backgroud PreAuthCancel OK");
+                }
+            } else {
+                // 度數大於零
+                if (deductInfo[j].Amount == 0 && deductInfo[j].Energy > 0) {
+                    deductInfo[j].Amount = deductInfo[j].Energy * ShmDcCommonData->ChargingRate;
+                    if (deductInfo[j].Amount < 1)
+                        deductInfo[j].Amount = 1;
+                    log_info("Error Close Charging recount amount:%.1f",deductInfo[j].Amount);
+                }
+                result = CreditCardPreAuthComplete(fd, (int)deductInfo[j].Amount, &pSysConfig->ModelName[0],
+                    &deductInfo[j].pCreditCard.VemData[0],
+                    &ShmDcCommonData->TransactionInfo[0].pCreditCard);
+                sleep(10);
+                if (result > 0) {
+                    deductInfo[j].DeductResult = _DEDUCT_COMPLETE_PASS;
+                    log_info("Backgroud PreAuthComplete OK");
+                } else if (result < 0) {
+                    deductInfo[j].DeductResult = _DEDUCT_COMPLETE_FAIL;
+                    log_info("Backgroud ID:%d Amount:%d VemData:%s PreAuthComplete fail",
+                        deductInfo[j].TransactionId,
+                        (int)deductInfo[j].Amount,
+                        deductInfo[j].pCreditCard.VemData);
+                }
+            }
+            deductInfo[j].IsUpload = FALSE;
+            deductInfo[j].RedeductTime++;
+            UpdateDeductInfoStatus(rededuct_gunIndex[j], &deductInfo[j]);
+        }
+    }
+    ShmDcCommonData->RoutineReduct = TRUE;
 }
 static int InitialRfidPort(void)
 {
@@ -405,63 +484,39 @@ static int InitialRfidPort(void)
 
     return fd;
 }
-int CreditCardCancelPreAuth(int fd,uint8_t gunIndex)
-{
-
-    struct SysConfigData* pSysConfig = (struct SysConfigData*)GetShmSysConfigData();
-    ShmDcCommonData->PreAuth_Result = CreditCardPreAuthCancel(fd, PREAUTHMONEY, "TCC Test",
-        &ShmDcCommonData->pCreditCard[gunIndex].ApprovalNo[0],
-        &ShmDcCommonData->pCreditCard[gunIndex].CardNo[0],
-        &ShmDcCommonData->pCreditCard[gunIndex].VemData[0]);
-    sleep(10);
-    ShmDcCommonData->PayFinish[gunIndex] = TRUE;
-    if (ShmDcCommonData->PreAuth_Result >= 0) {
-        strcpy((char*)pSysConfig->UserId, "");
-        //ShmDcCommonData->PayFinish[gunIndex] = TRUE;
-        log_info("Card Reader PreAuth Cancel Success");
-        memset(&ShmDcCommonData->pCreditCard[gunIndex], 0, sizeof(TransInfo));
 
-    }
-    else if (ShmDcCommonData->PreAuth_Result < 0) {
-        log_info("Card Reader PreAuth Cancel Failure");
-    }
-    ShmDcCommonData->PreAuth_Config = _CREDITCARD_IDLE;
-    return ShmDcCommonData->PreAuth_Result;
-}
 void CreateRfidFork(void)
 {
     pid_t rfidRecPid;
     int rededuct_gunIndex[128];
     RecordTransactionInfo deductInfo[128];
     int rededuct_num = 0;
-
+    int donate = 0;
     rfidRecPid = fork();
     int j = 0;
     if (rfidRecPid == 0) {
-        char localTime[128] = {0};
+        //char localTime[128] = {0};
         struct timeb SeqEndTime;
         struct tm *tm;
         pSysInfo = (struct SysInfoData *)GetShmSysInfoData();
         int fd = -1;
         int isContinue = 1;
-        RFID rfid = {0};
-        RecordTransactionInfo deduct;
+        //RFID rfid = {0};
+        //RecordTransactionInfo deduct;
         fd = InitialRfidPort();
         struct SysConfigData *pSysConfig = (struct SysConfigData *)GetShmSysConfigData();
         ShmDcCommonData = (DcCommonInfo *)GetShmDcCommonData();
         ShmSelectGunInfo = (SelectGunInfo *)GetShmSelectGunInfo();
         struct ChargingInfoData *pDcChargingInfo = NULL;
+        if (DeductDB_Open() != PASS) {
+            isDeductDb_ready = false;
+        } else {
+            isDeductDb_ready = true;
+            //InsertDeductInfo(0, &ShmDcCommonData->TransactionInfo);
+        }
         int gunIndex;
-        int uploadIndex = 0;
+        //int uploadIndex = 0;
         int ReAuthComplete_Index = 0;
-        if(DeductDB_Open() != PASS)
-        {
-        	isDeductDb_ready = false;
-        }
-        else
-        {
-        	isDeductDb_ready = true;
-        }
         //log_info("RFID fork Child's PID is %d", getpid());
         int result;
         int is_idle = TRUE;
@@ -472,71 +527,97 @@ void CreateRfidFork(void)
             SeqEndTime.time = time(NULL);
             tm = localtime(&SeqEndTime.time);
 
-            if (ShmDcCommonData->DebugFlag == TRUE) {
+            if (ShmDcCommonData->DebugFlag == TRUE ||
+                ShmDcCommonData->is_RemoteStart[pSysInfo->CurGunSelected] == TRUE ||
+                ShmDcCommonData->is_AutoStart[pSysInfo->CurGunSelected] == TRUE) {
                 ShmDcCommonData->PreAuth_Config = _CREDITCARD_IDLE;
                 ShmDcCommonData->PreAuth_Result = 0;
-                continue;
             }
 
-            if (ShmDcCommonData->UnionSettlement) {
-                ShmDcCommonData->UnionSettlement = 0;
-                result = CreditCardUnionSettlement(fd, "TCC Test", &ShmDcCommonData->pCreditCard[0]);
-                if (result > 0) {
-                    log_info("CreditCardUnionSettlement OK");
-                }
-                else
-                    log_info("CreditCardUnionSettlement FAIL");
-            }
             is_idle = TRUE;
 			for (gunIndex = 0; gunIndex < pSysConfig->TotalConnectorCount; gunIndex++) {
 				pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(gunIndex);
 				if (pDcChargingInfo->SystemStatus != S_IDLE) {
 					is_idle = FALSE;
 				}
-				if (ShmDcCommonData->StopCharge[gunIndex] == TRUE && ShmDcCommonData->finalcost_flag[gunIndex]) {
+                if (ShmDcCommonData->StopCharge[gunIndex] == TRUE && pDcChargingInfo->Replug_flag == TRUE) {
                     ShmDcCommonData->StopCharge[gunIndex] = FALSE;
-                    pSysInfo->SystemPage = _PAGE_PAYING;
-                    StopGunInfoTimeoutDet(gunIndex); //Timeout_FinalCost
-					if (ShmDcCommonData->finalcost[gunIndex] == 0) {
-                        log_info("Final Cost less 1 , Cancel Trade!!");
-                        if (CreditCardCancelPreAuth(fd, gunIndex) > 0) {
+                    log_info("Not Into Charging cancel Trade");
+                    StopGunInfoTimeoutDet(gunIndex);
+                    ShmDcCommonData->TradeCancel = TRUE;
+                    pSysInfo->SystemPage = _PAGE_SENSING;
+                    StartSystemTimeoutDet(Timeout_TradeCancel);
+                    CreditCardCancelPreAuth(fd, gunIndex);
+                    pSysInfo->SystemPage = _PAGE_PLUGOUT;
+                    StopSystemTimeoutDet();
+                } else {
+                    if (ShmDcCommonData->StopCharge[gunIndex] == TRUE && ShmDcCommonData->finalcost_flag[gunIndex]) {
+                        ShmDcCommonData->StopCharge[gunIndex] = FALSE;
+                        if (pDcChargingInfo->Replug_flag == TRUE) {
+                            log_info("Not Into Charging cancel Trade");
+                            ShmDcCommonData->TradeCancel = TRUE;
+                            pSysInfo->SystemPage = _PAGE_SENSING;
+                            StartSystemTimeoutDet(Timeout_TradeCancel);
+                        } else
+                            pSysInfo->SystemPage = _PAGE_PAYING;
+                        StopGunInfoTimeoutDet(gunIndex); //Timeout_FinalCost
+
+                        // Remote Start of AutoStart ByPass Credit Card Reader
+                        if (ShmDcCommonData->DebugFlag == TRUE ||
+                            ShmDcCommonData->is_RemoteStart[gunIndex] == TRUE ||
+                            ShmDcCommonData->is_AutoStart[gunIndex] == TRUE) {
                             pSysInfo->SystemPage = _PAGE_COMPLETE;
                             ShmDcCommonData->PayPass_flag[gunIndex] = TRUE;
+                            continue;
                         }
-                        else {
-                            pSysInfo->SystemPage = _PAGE_PAYFAIL;
-                            ShmDcCommonData->PayPass_flag[gunIndex] = FALSE;
+                        // 實際扣款
+                        if (ShmDcCommonData->TransactionInfo[gunIndex].Amount < 1) {
+                            log_info("Final Cost less 1 , Cancel Trade!!");
+                            if (CreditCardCancelPreAuth(fd, gunIndex) > 0) {
+                                pSysInfo->SystemPage = _PAGE_COMPLETE;
+                                ShmDcCommonData->PayPass_flag[gunIndex] = TRUE;
+                            } else {
+                                pSysInfo->SystemPage = _PAGE_PAYFAIL;
+                                ShmDcCommonData->PayPass_flag[gunIndex] = FALSE;
+                            }
+                        } else {
+                            PreAuthCompleteToCardReader(fd, gunIndex);
                         }
-					} else {                        		
-						PreAuthCompleteToCardReader(fd,gunIndex);
-					}
-				}
+                    }
+                }
 			} // for
-
+            // 取消預授權
             if(ShmDcCommonData->PreAuth_Config == _CREDITCARD_CANCEL) {
                 CreditCardCancelPreAuth(fd,pSysInfo->CurGunSelected);
-            } else if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_PREAUTH /* && ShmDcCommonData->GetCardNo[pSysInfo->CurGunSelected]*/) {                
-        		result = CreditCardPreAuth(fd, PREAUTHMONEY,"TCC Test", &ShmDcCommonData->pCreditCard[pSysInfo->CurGunSelected]);
+            // 預授權
+            } else if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_PREAUTH /* && ShmDcCommonData->GetCardNo[pSysInfo->CurGunSelected]*/) {
+                donate = (int)ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].IsDonateInvoice;
+                memset(&ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected], 0x00, sizeof(RecordTransactionInfo));
+                ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].IsDonateInvoice = (unsigned char)donate;
+        		result = CreditCardPreAuth(fd, PREAUTHMONEY,&pSysConfig->ModelName[0], &ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].pCreditCard);
+                if (!ShmDcCommonData->TradeCancel)
+                    StopSystemTimeoutDet();
                 if (ShmDcCommonData->TradeCancel == FALSE && result > 0) {
                     pSysInfo->SystemPage = _PAGE_SENSING;
-                    sleep(10);
                 }
-                StopSystemTimeoutDet();
-                
+                sleep(10);
+
                 ShmDcCommonData->PreAuth_Result = result;
 				//result = 1;
-				if (result > 0) {
+				if (result > 0 && strcmp(ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].pCreditCard.CardNo,"") != 0 ) {
+
 					ShmDcCommonData->AuthPass_flag[pSysInfo->CurGunSelected] = TRUE;
-                    strncpy((char*)pSysConfig->UserId, ShmDcCommonData->pCreditCard[pSysInfo->CurGunSelected].CardNo, 20);
+                    strncpy((char*)pSysConfig->UserId, (char *)ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].pCreditCard.CardNo, 20);
                     log_info("Authorize card:%s", pSysConfig->UserId);
-                    ShmDcCommonData->GetCardNo[pSysInfo->CurGunSelected] = TRUE;
+                    ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].DeductResult = _DEDUCT_PREAUTH;
+                    ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].IsUpload = FALSE;
+                    InsertDeductInfo(ShmDcCommonData->ConnectorID[pSysInfo->CurGunSelected], &ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected]);
 					log_info("PreAuth OK");
 				} else if (result < 0) {
-				    struct ChargingInfoData *pDcChargingInfo = NULL;
                     if (ShmDcCommonData->TradeCancel == FALSE)
 					    pSysInfo->SystemPage = _PAGE_AUTHORIZE_FAIL;
 					ShmDcCommonData->AuthPass_flag[pSysInfo->CurGunSelected] = FALSE;
-					memset(&ShmDcCommonData->pCreditCard[pSysInfo->CurGunSelected], 0, sizeof(TransInfo));
+					memset(&ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].pCreditCard, 0, sizeof(TransInfo));
 					log_info("PreAuth Fail");
 				}
 				ShmDcCommonData->PreAuth_Config = _CREDITCARD_IDLE;
@@ -546,47 +627,29 @@ void CreateRfidFork(void)
             if ((is_idle == TRUE && (tm->tm_hour == 15 && tm->tm_min < 30) &&
                 pSysInfo->SystemPage == _PAGE_IDLE &&
                 ShmDcCommonData->RoutineReduct == FALSE) || ShmDcCommonData->Exe_ReDeduct) {
+                ReDeductProcess(fd);
                 ShmDcCommonData->Exe_ReDeduct = 0;
-                rededuct_num = DB_GetMultiReDeductInfo(&rededuct_gunIndex, &deductInfo);
-                ShmDcCommonData->RoutineReduct = TRUE;
-                if (rededuct_num == 0)
-                    log_info("No Rededuct Information");
-                else {
-                    for (j = 0; j < rededuct_num; j++) {
-                        if (pSysInfo->SystemPage != _PAGE_IDLE) {
-                            ShmDcCommonData->RoutineReduct = FALSE;
-                            break;
-                        }
-                        result = CreditCardPreAuthComplete(fd, (int)deductInfo[j].Amount, "TCC Test",
-                            &deductInfo[j].VemData[0],
-                            &ShmDcCommonData->pCreditCard[0]);
-                        sleep(10);
-                        if (result > 0) {
-                            deductInfo[j].DeductResult = YES;
-                            deductInfo[j].IsUpload = NO;
-                            UpdateDeductInfoStatus(&ReAuthComplete_Index, &deductInfo[j]);
-                            log_info("Backgroud PreAuthComplete OK");
-                        }
-                        else if (result < 0) {
-                            log_info("Backgroud ID:%d Amount:%d VemData:%s PreAuthComplete fail",
-                                deductInfo[j].TransactionId,
-                                (int)deductInfo[j].Amount,
-                                deductInfo[j].VemData);
-                        }
-
-                    }
-                }
             }
+
             // 每日晚上11點30分結帳
-            if (is_idle == TRUE && tm->tm_hour == 15 && tm->tm_min > 30 && tm->tm_sec == 0 &&
-                ShmDcCommonData->RoutineSettlement == FALSE) {
-                ShmDcCommonData->RoutineSettlement = TRUE;
-                result = CreditCardUnionSettlement(fd, "TCC Test", &ShmDcCommonData->pCreditCard[0]);
+            if (is_idle == TRUE && pSysInfo->SystemPage == _PAGE_IDLE && 
+                ((tm->tm_hour == 15 && tm->tm_min > 30  && ShmDcCommonData->RoutineSettlement == FALSE) ||
+                    ShmDcCommonData->UnionSettlement)) {
+                StopSystemTimeoutDet();
+                if (ShmDcCommonData->UnionSettlement)
+                    ShmDcCommonData->UnionSettlement = 0;
+                else
+                    ShmDcCommonData->RoutineSettlement = TRUE;
+                pSysInfo->SystemPage = _PAGE_MAINTAIN;
+                 
+                result = CreditCardUnionSettlement(fd, &pSysConfig->ModelName[0], &LocalTransactionInfo.pCreditCard);
                 if (result > 0) {
                     log_info("CreditCardUnionSettlement OK");
                 }
                 else
                     log_info("CreditCardUnionSettlement FAIL");
+                sleep(90);
+                pSysInfo->SystemPage = _PAGE_IDLE;
             }
             if (tm->tm_hour == 16 && tm->tm_min == 0) {
                 ShmDcCommonData->RoutineSettlement = FALSE;

+ 161 - 81
EVSE/Projects/DD360Tcci/Apps/CSU/main.c

@@ -81,8 +81,8 @@ uint8_t bd0_2_status = 0;
 uint8_t bd1_1_status = 0;
 uint8_t bd1_2_status = 0;
 
-char *fwVersion = "V2.07.00.0000.00"; // Phihong version
-char* DebugVersion = "v2.07.00";      // Software debug version
+char *fwVersion = "V2.08.00.0000.00"; // Phihong version
+char* DebugVersion = "v2.08.03";      // Software debug version
 //sqlite3 *localDb;
 bool isDb_ready;
 
@@ -1492,18 +1492,32 @@ void _SelfTestTimeout(void)
 
 void _AuthorizedTimeout(void)
 {
+    int i;
     //if (IsAuthorizingMode()) {
         log_info("*********** _AuthorizedTimeout *********** ");
         StopSystemTimeoutDet();
         //isCardScan = false;
         SetIsCardScan(false);
 
-        pSysInfo->SystemPage = _PAGE_SELECT_GUN;
+        //StopSystemTimeoutDet();
+        StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
+        ShmDcCommonData->TradeCancel = TRUE;
         ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
         ShmDcCommonData->PreAuth_Result = 0;
-        //ChangeLcmByIndex(_LCM_AUTHORIZ_FAIL);
-        strcpy((char *)pSysConfig->UserId, "");
+        pSysInfo->SystemPage = _PAGE_SENSING;
+        StartSystemTimeoutDet(Timeout_TradeCancel);
+        for (i = 0; i <= 30; i++) {
+            if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE)
+                break;
+            sleep(1);
+        }
+        ShmDcCommonData->PreAuth_Result = 0;
+
+        StopSystemTimeoutDet();
+        ClearDetectPluginFlag();
+        strcpy((char*)pSysConfig->UserId, "");
         ClearAuthorizedFlag();
+        setChargerMode(pSysInfo->CurGunSelected, S_IDLE);
      //   StartSystemTimeoutDet(Timeout_ReturnViewPage);
     //}
 }
@@ -1515,11 +1529,13 @@ void _DetectPlugInTimeout(uint8_t gunIndex)
     strcpy((char *)pSysConfig->UserId, "");
     //StopSystemTimeoutDet();
     StopGunInfoTimeoutDet(gunIndex);
-
+    ShmDcCommonData->TradeCancel = TRUE;
 	ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
 	ShmDcCommonData->PreAuth_Result = 0;
+    pSysInfo->SystemPage = _PAGE_SENSING;
+    StartSystemTimeoutDet(Timeout_TradeCancel);
 	for(i=0;i<=30;i++) {
-		if(ShmDcCommonData->PreAuth_Result != 0)
+		if(ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE)
 			break;
 		sleep(1);
 	}
@@ -1527,6 +1543,7 @@ void _DetectPlugInTimeout(uint8_t gunIndex)
 
     if (pSysInfo->CurGunSelected == gunIndex)
     	pSysInfo->SystemPage = _PAGE_IDLE;
+    StopSystemTimeoutDet();
     ClearDetectPluginFlag();
     strcpy((char *)pSysConfig->UserId, "");
 	setChargerMode(gunIndex, S_IDLE);
@@ -1753,16 +1770,16 @@ void ReleaseAlarmCode(uint8_t gunIndex)
 void ChargingTerminalProcess(uint8_t gunIndex)
 {
     pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(gunIndex);
-    if (pDcChargingInfo->SystemStatus == S_CHARGING)
-        ShmDcCommonData->StopCharge[gunIndex] = TRUE;
+    //if (pDcChargingInfo->SystemStatus == S_CHARGING)
+    ShmDcCommonData->StopCharge[gunIndex] = TRUE;
     setChargerMode(gunIndex, MODE_TERMINATING);
 }
 
 void ChargingAlarmProcess(uint8_t gunIndex)
 {
     pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(gunIndex);
-    if (pDcChargingInfo->SystemStatus == S_CHARGING)
-        ShmDcCommonData->StopCharge[gunIndex] = TRUE;
+    //if (pDcChargingInfo->SystemStatus == S_CHARGING)
+    ShmDcCommonData->StopCharge[gunIndex] = TRUE;
     UpdateErrorCodeToOcpp(gunIndex);
     setChargerMode(gunIndex, MODE_ALARM);
 }
@@ -2510,12 +2527,13 @@ void CreateTimeoutFork(void)
             	break;
             case Timeout_Authorizing:
                 if (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL >= AUTHORIZE_TIMEOUT) {
-                    //log_error("Authorizing Timeout");
+                    log_error("Authorizing Timeout");
                     _AuthorizedTimeout();
                     if (ShmSelectGunInfo->AuthorStateFromCabinet[pSysInfo->CurGunSelected] == YES) { //DoComm no ask cabinet balance
                         ShmSelectGunInfo->AuthorStateFromCabinet[pSysInfo->CurGunSelected] = NO;
                         pAlarmCode->AlarmEvents.bits.DisconnectedFromDo = ABNORMAL;
                         log_error("Author timeout restart DoComm");
+                        system("killall Module_DoComm");
                     }
                 }
                 break;
@@ -2534,6 +2552,7 @@ void CreateTimeoutFork(void)
             case Timeout_VerifyFail:
 
                 if (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL >= AUTHORIZE_FAIL_TIMEOUT) {
+                    log_info("Timeout_VerifyFail");
                     /*if (pSysInfo->SystemPage ==_LCM_START_AUTHORIZE_FAIL ) {
                         StopSystemTimeoutDet();
                         _AutoReturnTimeout();
@@ -2579,6 +2598,7 @@ void CreateTimeoutFork(void)
 
             case Timeout_AuthorizingForStop:
                 if (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL >= AUTHORIZE_STOP_TIMEOUT) {
+                    log_info("Timeout_AuthorizingForStop");
                     strcpy((char *)pSysConfig->UserId, "");
                     ClearAuthorizedFlag();
                     StopSystemTimeoutDet();
@@ -2587,6 +2607,7 @@ void CreateTimeoutFork(void)
                 break;
             case Timeout_ScanCard:
 				if (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL >= TCC_SCANCARD_TIMEOUT) {
+                    log_info("Timeout_ScanCard");
 					strcpy((char *)pSysConfig->UserId, "");
 					ClearAuthorizedFlag();
 					StopSystemTimeoutDet();
@@ -2606,6 +2627,7 @@ void CreateTimeoutFork(void)
                 break;
             case Timeout_AddLine:
             	if (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL >= TCC_ADDLINE_TIMEOUT) {
+                    log_info("Timeout_AddLine");
             		StopSystemTimeoutDet();
             		pSysInfo->SystemPage = _PAGE_SELECT_GUN;
                     ShmDcCommonData->OperateIDLE[pSysInfo->CurGunSelected] = 1;
@@ -2614,12 +2636,14 @@ void CreateTimeoutFork(void)
 
             case Timeout_DonateComfirm:
             	if (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL >= TCC_DONATECOMFIRM_TIMEOUT) {
+                    log_info("Timeout_DonateComfirm");
             		StopSystemTimeoutDet();
             		pSysInfo->SystemPage = _PAGE_SELECT_GUN;
             	}
             	break;
             case Timeout_SelectPayMode:
             	if (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL >= TCC_SELECTPAY_TIMEOUT) {
+                    log_info("Timeout_SelectPayMode");
             		StopSystemTimeoutDet();
             		pSysInfo->SystemPage = _PAGE_SELECT_GUN;
                     ShmDcCommonData->OperateIDLE[pSysInfo->CurGunSelected] = 1;
@@ -2627,6 +2651,7 @@ void CreateTimeoutFork(void)
             	break;
             case Timeout_TradeCancel:
                 if (GetClockTimeoutValue(pSysInfo->SystemTimeoutTimer) / uSEC_VAL >= TCC_TRADECANCEL_TIMEOUT) {
+                    log_info("Timeout_TradeCancel");
                     StopSystemTimeoutDet();
                     pDcChargingInfo = (struct ChargingInfoData*)GetDcChargingInfoData(pSysInfo->CurGunSelected);
                     setChargerMode(pSysInfo->CurGunSelected, MODE_IDLE);
@@ -2703,6 +2728,7 @@ void CreateTimeoutFork(void)
                     break;
                 case Timeout_PlugOutGun:
                     if (GetTimeoutValue(pDcChargingInfo->TimeoutTimer) / uSEC_VAL >= PLUGOUTGUN_TIMEOUT) {
+                        log_info("Gun[%d] Timeout_PlugOutGun",gunIndex);
                         setChargerMode(gunIndex, MODE_IDLE);
                         destroySelGun(gunIndex); //Jerry add
                         StopGunInfoTimeoutDet(gunIndex);
@@ -2711,21 +2737,32 @@ void CreateTimeoutFork(void)
                     break;
                 case Timeout_FinalCost:
                 	if (GetTimeoutValue(pDcChargingInfo->TimeoutTimer) / uSEC_VAL >= TCC_FINALCOST_TIMEOUT) {
+                        log_info("Gun[%d] Timeout_FinalCost",gunIndex);
                 		StopGunInfoTimeoutDet(gunIndex);
                 		if (ShmDcCommonData->finalcost_flag[gunIndex] == FALSE) {
-                			ShmDcCommonData->finalcost[gunIndex] = pDcChargingInfo->PresentChargedEnergy * ShmDcCommonData->ChargingRate;
+                			ShmDcCommonData->TransactionInfo[gunIndex].Amount = pDcChargingInfo->PresentChargedEnergy * ShmDcCommonData->ChargingRate;
                 			ShmDcCommonData->finalcost_flag[gunIndex] = TRUE;
                 		}
                 	}
                 	break;
                 case Timeout_LineReigster:
                 	if (GetTimeoutValue(pDcChargingInfo->TimeoutTimer) / uSEC_VAL >= TCC_LINEREGISTER_TIMEOUT) {
+                        log_info("Gun[%d] Timeout_LineReigster",gunIndex);
                 		StopGunInfoTimeoutDet(gunIndex);
                 		pSysInfo->SystemPage = _PAGE_SELECT_GUN;
-                		ShmDcCommonData->donate_flag[gunIndex] = FALSE;
+                		ShmDcCommonData->TransactionInfo[gunIndex].IsDonateInvoice = FALSE;
                         ShmDcCommonData->OperateIDLE[gunIndex] = 1;
                 	}
                 	break;
+                case Timeout_ExitPage:
+                    if (GetTimeoutValue(pDcChargingInfo->TimeoutTimer) / uSEC_VAL >= TCC_EXITPAGE_TIMEOUT) {
+                        log_info("Gun[%d] Timeout_ExitPage", gunIndex);
+                        StopGunInfoTimeoutDet(gunIndex);
+                        ShmDcCommonData->is_exit[gunIndex] = TRUE;
+                        pSysInfo->SystemPage = _PAGE_EXIT;
+                        StartGunInfoTimeoutDet(gunIndex, Timeout_PlugOutGun);
+                    }
+                    break;
                     /*
                 case Timeout_SelectGun: //Jerry add 
                     if (GetTimeoutValue(pDcChargingInfo->TimeoutTimer) / uSEC_VAL >= SEL_GUN_TIMEOUT) {
@@ -2968,6 +3005,7 @@ void OcppRemoteStartChk()
             		pDcChargingInfo->SystemStatus == S_AUTHORIZING ||
                     pDcChargingInfo->SystemStatus == S_RESERVATION) {
                 pDcChargingInfo->RemoteStartFlag = YES;
+                ShmDcCommonData->is_RemoteStart[dcIndex] = TRUE;
                 pSysInfo->OrderCharging = YES;
                 //pDcChargingInfo->SystemStatus = S_AUTHORIZING;
                 //pSysInfo->OrderCharging = gunIndex;
@@ -3463,13 +3501,13 @@ void ResetDetAlarmStatus(uint8_t gun)
         }
     }
 }
-#if 0
+
 static void autoStartCharging(uint8_t gunIndex)
 {
     pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(gunIndex);
 
     if ( (pSysInfo->SystemPage >= _PAGE_AUTHORIZE && pSysInfo->SystemPage <= _PAGE_SENSING) ||
-        pDcChargingInfo->isEVCCIDVerify && strcmp( (char *)pSysConfig->UserId , "" ) != EQUAL) {
+        (pDcChargingInfo->isEVCCIDVerify && strcmp( (char *)pSysConfig->UserId , "" ) != EQUAL)) {
             return;
     }
 
@@ -3505,13 +3543,15 @@ static void autoStartCharging(uint8_t gunIndex)
             strcpy((char *)&pSysConfig->UserId, "AutoStartCharging");
             ChangeGunSelectByIndex(gunIndex);
             confirmSelGun(gunIndex);
-            pSysInfo->SystemPage = _LCM_START_AUTHORIZING;
-            setChargerMode(gunIndex, MODE_AUTHORIZING);
+            ShmDcCommonData->is_AutoStart[gunIndex] = TRUE;
+            pSysInfo->SystemPage = _PAGE_SENSING;
+            ShmDcCommonData->AuthPass_flag[gunIndex] = TRUE;
+            //setChargerMode(gunIndex, MODE_AUTHORIZING);
             log_info("Get User(%d) ID:%s",gunIndex,pSysConfig->UserId);
         }
     }
 }
-#endif
+
 static bool PrecheckIsPass(uint8_t gunIndex)
 {
     bool result = true;
@@ -3549,6 +3589,7 @@ static void ReviewCriticalAlarm(void)
             pSysWarning->Level = WARN_LV_NL;
             return;
         }
+
         pSysWarning->Level = WARN_LV_ER;
     } else {
         pSysWarning->Level = WARN_LV_NL;
@@ -3877,15 +3918,16 @@ void ResetIdleData(uint8_t gunIndex)
     ClearDetectPluginFlag();
     //Jerry add
     memset(&ShmSelectGunInfo->PricesInfo[gunIndex], 0, sizeof(PricesInfo));
-    memset(&ShmDcCommonData->pCreditCard[gunIndex], 0, sizeof(TransInfo));
     memset(&ShmDcCommonData->TransactionInfo[gunIndex], 0, sizeof(RecordTransactionInfo));
     ShmDcCommonData->finalcost_flag[gunIndex] = FALSE;
-    ShmDcCommonData->finalcost[gunIndex] = 0;
     ShmDcCommonData->AuthPass_flag[gunIndex] = FALSE;
     ShmDcCommonData->PayPass_flag[gunIndex] = FALSE;
-    ShmDcCommonData->GetCardNo[gunIndex] = FALSE;
     ShmDcCommonData->LineStatus[gunIndex] = 0;
     ShmDcCommonData->OperateIDLE[gunIndex] = 1;
+    ShmDcCommonData->is_RemoteStart[gunIndex] = FALSE;
+    ShmDcCommonData->is_AutoStart[gunIndex] = FALSE;
+    ShmDcCommonData->is_exit[gunIndex] = FALSE;
+    ShmDcCommonData->StopCharge[gunIndex] = FALSE;
 
     ShmSelectGunInfo->PricesInfo[gunIndex].Balance = FAIL_BALANCE_PRICES;
     destroySelGun(gunIndex);
@@ -4007,7 +4049,7 @@ int main(void)
     log_info(" ********************************************************");
     log_info(" ******************  Project:DD360Tcc   *****************");
     log_info(" ********************************************************");
-    int is_plugout[2];
+
     if (!InitialSystemDefaultConfig()) {
         log_error("InitialSystemDefaultConfig NG ");
         //StopProcessingLoop();
@@ -4088,7 +4130,7 @@ int main(void)
     //AdjustChargerCurrent();
     gettimeofday(&_cmdMainPriority_time, NULL);
 
-    GunIndexInfo *pGunIndexInfo = (GunIndexInfo *)GetGunIndexInfo();
+   // GunIndexInfo *pGunIndexInfo = (GunIndexInfo *)GetGunIndexInfo();
 
     CheckTaskAlive();
 
@@ -4178,7 +4220,6 @@ int main(void)
                 if (isModeChange(gunIndex)) {
                     log_info("============================= S_IDLE(%x) ============================= ", gunIndex);
                     ResetIdleData(gunIndex);
-                    is_plugout[gunIndex] = FALSE;
                 }
                 isChargingAverageState();
                 // For RemoteStart Using
@@ -4189,9 +4230,11 @@ int main(void)
 					setChargerMode(gunIndex, MODE_AUTHORIZING);
 					break;
                 }
+                autoStartCharging(gunIndex);
                 cancelcount = 0;
                 // 讀卡邏輯
-                ScannerCardProcess();
+                if (!ShmDcCommonData->TradeCancel)
+                    ScannerCardProcess();
                 if (pSysInfo->SystemPage == _PAGE_SELECT_GUN) {
                 	ShmDcCommonData->LineStatus[gunIndex] = 0;
                 	StopGunInfoTimeoutDet(gunIndex);
@@ -4211,13 +4254,13 @@ int main(void)
                 		if (ShmDcCommonData->LineStatus[gunIndex] == 3)  {
                             StopGunInfoTimeoutDet(gunIndex);
                 			pSysInfo->SystemPage =_PAGE_SELECT_PAY;
-                			ShmDcCommonData->donate_flag[gunIndex] = FALSE;
+                			ShmDcCommonData->TransactionInfo[gunIndex].IsDonateInvoice = FALSE;
                             log_info("Change to Select Pay Page");
                 		}
 						if (ShmDcCommonData->LineStatus[gunIndex] == 4 ) {
                             StopGunInfoTimeoutDet(gunIndex);
                 			pSysInfo->SystemPage =_PAGE_SELECT_PAY;
-                			ShmDcCommonData->donate_flag[gunIndex] = TRUE;
+                			ShmDcCommonData->TransactionInfo[gunIndex].IsDonateInvoice = TRUE;
                             log_info("Change to Select Pay Page");
                 		}
                 	}
@@ -4275,7 +4318,7 @@ CheckStatus:
                 }
 				ScannerCardProcess();
                 // 隨插即充
-                //autoStartCharging(gunIndex);
+
                 if (pSysInfo->SystemPage == _PAGE_PLUGIN && ShmDcCommonData->TradeCancel == FALSE) {
                 	pDcChargingInfo->Replug_flag = TRUE;
                 	StopSystemTimeoutDet();
@@ -4292,6 +4335,7 @@ CheckStatus:
                             log_info("-------- S_AUTHORIZING Remote Start(%d) --------", gunIndex);
                             pDcChargingInfo->RemoteStartFlag = NO;
                             pDcChargingInfo->isRemoteStart = YES; //DS60-120
+                            
                             ChangeGunSelectByIndex(gunIndex);
                             //AddPlugInTimes(gunIndex);
                             setChargerMode(gunIndex, MODE_REASSIGN_CHECK);
@@ -4483,7 +4527,7 @@ CheckStatus:
                 // 切換 D+ Relay to Precharge Relay
                 if (pDcChargingInfo->RelayK1K2Status == YES || pDcChargingInfo->PantographFlag == YES) {
                     pDcChargingInfo->PrechargeStatus = PRECHARGE_READY;
-                    pSysInfo->CurGunSelected = gunIndex;
+                   // pSysInfo->CurGunSelected = gunIndex;
                     setChargerMode(gunIndex, MODE_CHARGING);
                 }
                 if (pSysInfo->CurGunSelected == gunIndex) {
@@ -4500,7 +4544,9 @@ CheckStatus:
                     ChangeStartOrStopDateTime(YES, gunIndex);
                     pDcChargingInfo->Replug_flag = FALSE;
                     ShmDcCommonData->finalcost_flag[gunIndex] = FALSE;
-                    ShmDcCommonData->StopCharge[gunIndex] = FALSE;
+                    ShmDcCommonData->TransactionInfo[gunIndex].isIntoCharge = TRUE;
+                    ShmDcCommonData->RecordEnergyTime[gunIndex] = time((time_t*)NULL);
+                    UpdateDeductInfoStatus(gunIndex, &ShmDcCommonData->TransactionInfo[gunIndex]);
                 }
 
                 if (ShmOCPP16Data->CpMsg.bits[gunIndex].StartTransactionConf) {
@@ -4508,6 +4554,13 @@ CheckStatus:
                 }
                 ftime(&endChargingTime[gunIndex]);
                 pDcChargingInfo->PresentChargedDuration = DiffTimeb(startChargingTime[gunIndex], endChargingTime[gunIndex]);
+                ShmDcCommonData->TransactionInfo[gunIndex].Energy = pDcChargingInfo->PresentChargedEnergy;
+
+                // 每秒紀錄使用電量到資料庫內
+                if ((time((time_t*)NULL) - ShmDcCommonData->RecordEnergyTime[gunIndex]) >= 1) {
+                    ShmDcCommonData->RecordEnergyTime[gunIndex] = time((time_t*)NULL);
+                    UpdateDeductInfoStatus(gunIndex, &ShmDcCommonData->TransactionInfo[gunIndex]);
+                }
 
                 checkPileEndGfdResult(gunIndex, pDcChargingInfo->Type, pDcChargingInfo->SystemStatus);
 
@@ -4534,8 +4587,15 @@ CheckStatus:
                     StopGunInfoTimeoutDet(gunIndex);
                     StartGunInfoTimeoutDet(gunIndex, Timeout_FinalCost);
                     StartSystemTimeoutDet(Timeout_Terminating);
-                    pSysInfo->CurGunSelected = gunIndex;
-                    pSysInfo->SystemPage = _PAGE_PAYING;
+                    //pSysInfo->CurGunSelected = gunIndex;
+                    /*
+                    if (pDcChargingInfo->Replug_flag == TRUE) {
+                        ShmDcCommonData->TradeCancel = TRUE;
+                        StartSystemTimeoutDet(Timeout_TradeCancel);
+                        ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
+                        ShmDcCommonData->PreAuth_Result = 0;
+                        pSysInfo->SystemPage = _PAGE_SENSING;
+                    }*/
                 }
                 // For Precharging timeout
 
@@ -4563,12 +4623,16 @@ CheckStatus:
                 if (pSysInfo->SystemPage == _PAGE_MAINTAIN) {
 					break;
                 }
-                if (pSysInfo->CurGunSelected == gunIndex && pSysInfo->SystemPage != _PAGE_PAYING &&
-                    ShmDcCommonData->finalcost_flag[gunIndex]) {
-                	if (ShmDcCommonData->PayPass_flag[pSysInfo->CurGunSelected] == TRUE)
-                		pSysInfo->SystemPage = _PAGE_COMPLETE;
-                	else
-                		pSysInfo->SystemPage = _PAGE_PAYFAIL;
+                if (pSysInfo->CurGunSelected == gunIndex && 
+                    pSysInfo->SystemPage != _PAGE_PAYING && pSysInfo->SystemPage != _PAGE_SENSING) {
+                    if (pDcChargingInfo->Replug_flag == TRUE)
+                        pSysInfo->SystemPage = _PAGE_PLUGOUT;
+                    else {
+                        if (ShmDcCommonData->PayPass_flag[pSysInfo->CurGunSelected] == TRUE)
+                            pSysInfo->SystemPage = _PAGE_COMPLETE;
+                        else
+                            pSysInfo->SystemPage = _PAGE_PAYFAIL;
+                    }
                 }
                 break;
 
@@ -4577,36 +4641,45 @@ CheckStatus:
                     log_info ("============================= S_COMPLETE(%x) ============================= ", gunIndex);
                     if (strcmp((char *)pDcChargingInfo->StartDateTime, "") != EQUAL) {
                         OcppStopTransation(gunIndex);
-
                     }
                     TheEndCharging(gunIndex);
-                    StopSystemTimeoutDet();
+                    if (pDcChargingInfo->Replug_flag != TRUE && pSysInfo->SystemPage != _PAGE_PLUGOUT)
+                        StopSystemTimeoutDet();
+                    if (ShmDcCommonData->is_AutoStart[gunIndex] == TRUE && pSysInfo->CurGunSelected == gunIndex)
+                        pSysInfo->SystemPage = _PAGE_COMPLETE;
                 }
-
+                /*
+                if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_CANCEL &&
+                    ShmDcCommonData->PreAuth_Result != 0 && cancelcount < 30) {
+                    sleep(1);
+                    cancelcount++;
+                    log_info("Cancel Not Complete yet");
+                    break;
+                }
+                */
                 //if (pSysInfo->SystemPage == _LCM_ERROR) {
                 if (pSysInfo->SystemPage == _PAGE_MAINTAIN) {
                     break;
                 }
-                if (pSysInfo->CurGunSelected == gunIndex && is_plugout[gunIndex] == TRUE) {
-                    StartGunInfoTimeoutDet(gunIndex, Timeout_PlugOutGun);
+                if (pSysInfo->CurGunSelected == gunIndex && ShmDcCommonData->is_exit[gunIndex]) {
                 	pSysInfo->SystemPage = _PAGE_EXIT;
                 	break;
                 }
-                if (pSysInfo->CurGunSelected == gunIndex &&     pDcChargingInfo->ConnectorPlugIn == NO) {
-                	is_plugout[gunIndex] = TRUE;
-                    StartGunInfoTimeoutDet(gunIndex, Timeout_PlugOutGun);
-                    if (pSysInfo->CurGunSelected == gunIndex) {
-                        sleep(10);
-                    	pSysInfo->SystemPage = _PAGE_EXIT;
-                    	break;
-                    }
+                if (pSysInfo->CurGunSelected == gunIndex &&  pDcChargingInfo->ConnectorPlugIn == NO &&
+                    (pSysInfo->SystemPage != _PAGE_PAYING || pSysInfo->SystemPage != _PAGE_SENSING)) {
+                    StartGunInfoTimeoutDet(gunIndex, Timeout_ExitPage);
                 }
 
-                if (pSysInfo->CurGunSelected == gunIndex && pSysInfo->SystemPage != _PAGE_PAYING ) {
-                	if (ShmDcCommonData->PayPass_flag[pSysInfo->CurGunSelected] == TRUE)
-						pSysInfo->SystemPage = _PAGE_COMPLETE;
-					else
-						pSysInfo->SystemPage = _PAGE_PAYFAIL;
+                if (pSysInfo->CurGunSelected == gunIndex && 
+                    pSysInfo->SystemPage != _PAGE_PAYING && pSysInfo->SystemPage != _PAGE_SENSING) {
+                    if (pDcChargingInfo->Replug_flag == TRUE)
+                        pSysInfo->SystemPage = _PAGE_PLUGOUT;
+                    else {
+                        if (ShmDcCommonData->PayPass_flag[pSysInfo->CurGunSelected] == TRUE)
+                            pSysInfo->SystemPage = _PAGE_COMPLETE;
+                        else
+                            pSysInfo->SystemPage = _PAGE_PAYFAIL;
+                    }
                 }
 
                 break;
@@ -4623,17 +4696,23 @@ CheckStatus:
                     }
                     TheEndCharging(gunIndex);
                     StopGunInfoTimeoutDet(gunIndex);
-                    StartGunInfoTimeoutDet(gunIndex, Timeout_FinalCost);
+                    
                     if (pDcChargingInfo->Replug_flag == TRUE) {
+                        /*
+                        ShmDcCommonData->TradeCancel = TRUE;
+                        StartSystemTimeoutDet(Timeout_TradeCancel);
                 		ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
                 		ShmDcCommonData->PreAuth_Result = 0;
-                        pSysInfo->SystemPage = _PAGE_PLUGOUT;
+                        pSysInfo->SystemPage = _PAGE_SENSING;
+                        */
                     } else {
+                        StartGunInfoTimeoutDet(gunIndex, Timeout_FinalCost);
 						if(ShmDcCommonData->finalcost_flag[gunIndex] == FALSE) {
 							pSysInfo->SystemPage = _PAGE_PAYING;
 						}
                     }
                 }
+                /*
                 if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_CANCEL && 
                     ShmDcCommonData->PreAuth_Result != 0 && cancelcount < 30) {
                     sleep(1);
@@ -4641,30 +4720,21 @@ CheckStatus:
                     //log_info("Cancel Not Complete yet");
                     break;
                 }
+                */
                 if (pSysWarning->Level == WARN_LV_ER) {
 					pSysInfo->SystemPage = _PAGE_MAINTAIN;
 
 					continue;
 				}
-                if (pSysInfo->CurGunSelected == gunIndex && is_plugout[gunIndex] == TRUE) {
-                    StartGunInfoTimeoutDet(gunIndex, Timeout_PlugOutGun);
-                	pSysInfo->SystemPage = _PAGE_EXIT;
-                	break;
+                if (pSysInfo->CurGunSelected == gunIndex && ShmDcCommonData->is_exit[gunIndex]) {
+                    pSysInfo->SystemPage = _PAGE_EXIT;
+                    break;
                 }
 
-                if (pSysInfo->CurGunSelected == gunIndex && pDcChargingInfo->ConnectorPlugIn == NO) {
-                	is_plugout[gunIndex] = TRUE;
-					if (pDcChargingInfo->Replug_flag == TRUE) {
-						pSysInfo->SystemPage = _PAGE_SELECT_GUN;
-						pDcChargingInfo->SystemStatus = S_IDLE;
-					} else {
-						StartGunInfoTimeoutDet(gunIndex, Timeout_PlugOutGun);
-						pSysInfo->SystemPage = _PAGE_EXIT;
-					}
-					break;
-				}
-                //if (pSysInfo->SystemPage == _PAGE_PAYING)
-                //	break;
+                if (pSysInfo->CurGunSelected == gunIndex && pDcChargingInfo->ConnectorPlugIn == NO &&
+                    (pSysInfo->SystemPage != _PAGE_PAYING || pSysInfo->SystemPage != _PAGE_SENSING)) {
+                    StartGunInfoTimeoutDet(gunIndex, Timeout_ExitPage);
+                }
 
                 if (pSysInfo->CurGunSelected == gunIndex && pSysInfo->SystemPage != _PAGE_PAYING ) {
                 	if (pDcChargingInfo->Replug_flag == TRUE)
@@ -4684,11 +4754,10 @@ CheckStatus:
                         pSysInfo->SystemPage = _PAGE_MAINTAIN;
                         continue;
                     }
-
-                    if (pSysInfo->CurGunSelected == gunIndex) {
-                    	pSysInfo->SystemPage = _PAGE_MAINTAIN;
+                    if (ShmDcCommonData->RoutineSettlement == TRUE) {
+                        pSysInfo->SystemPage = _PAGE_MAINTAIN;
+                        continue;
                     }
-
                     if (pDcChargingInfo->IsAvailable == NO )
                         break;
 
@@ -4710,7 +4779,18 @@ CheckStatus:
                     if (pSysInfo->SelfTestSeq == _STEST_FAIL)
                         StopProcessingLoop();
                 }
-
+                /*
+                if (pDcChargingInfo->IsAvailable == TRUE) {
+                    log_info("Gun[%d] set Available",gunIndex);
+                    setChargerMode(gunIndex, MODE_IDLE);
+                    break;
+                }
+                */
+                if (pSysInfo->CurGunSelected == gunIndex) {
+                    StopSystemTimeoutDet();
+                    StopGunInfoTimeoutDet(gunIndex);
+                    pSysInfo->SystemPage = _PAGE_MAINTAIN;
+                }
 
                 break;
             case S_UPDATE:

+ 1 - 0
EVSE/Projects/DD360Tcci/Apps/CSU/main.h

@@ -53,6 +53,7 @@
 #define TCC_FINALCOST_TIMEOUT					(30)
 #define TCC_SCANCARD_TIMEOUT					(30)
 #define TCC_TRADECANCEL_TIMEOUT                 (60)
+#define TCC_EXITPAGE_TIMEOUT                    (10)
 
 //#define log_info(format, args...) StoreLogMsg_1("[%s:%d][%s][Info] "format, __FILE__, __LINE__, __FUNCTION__, ##args)
 //#define log_warn(format, args...) StoreLogMsg_1("[%s:%d][%s][Warn] "format, __FILE__, __LINE__, __FUNCTION__, ##args)

+ 23 - 16
EVSE/Projects/DD360Tcci/Apps/Config.h

@@ -9,7 +9,7 @@
 
 //------------------------------------------------------------------------------
 #include <stdint.h>
-
+#include <time.h>
 //------------------------------------------------------------------------------
 //Dispenser simulation ev signal
 //------------------------------------------------------------------------------
@@ -298,6 +298,12 @@ enum _CREDITCARD_STATUS {
 	_CREDITCARD_SETTLEMENT,
 	_CREDITCARD_START,
 };
+enum _CREDIT_DEDUCT_STATUS {
+    _DEDUCT_COMPLETE_FAIL = 0,
+    _DEDUCT_COMPLETE_PASS = 1,
+    _DEDUCT_CANCEL,
+    _DEDUCT_PREAUTH,
+};
 //------------------------------------------------------------------------------
 //struct StructMeter {
 //    float curMeterValue;
@@ -420,15 +426,18 @@ typedef struct stTransInfo
 
 typedef struct stRecordTransactionInfo
 {
+    int ConnectorID;
 	int TransactionId;
-    unsigned char DeductResult;                     // 0: Fail, 1: Pass
-    unsigned char IsDonateInvoice;                  // 0: Do not donate, 1: Donate
-    unsigned char ApprovalNo[9];
-    unsigned char CardNo[20];		//卡號(左靠右補空白),卡號部份隱藏
-    unsigned char VemData[64];
     float Amount;
-    unsigned char IsUpload; // 0: not upload, 1: uploaded
-    unsigned char res;
+    char DeductResult;                     // 0: Fail, 1: Pass , -1: Cancel , 99:Rededuct fail
+    unsigned char IsDonateInvoice;         // 0: Do not donate, 1: Donate
+    unsigned char LineSn[20];
+    unsigned char isIntoCharge;
+    unsigned char IsUpload;                // 0: not upload, 1: uploaded
+    TransInfo pCreditCard;
+    float Energy;
+    float prices;
+    int RedeductTime;
 }RecordTransactionInfo;
 
 typedef struct StDcCommonInfo {
@@ -469,25 +478,19 @@ typedef struct StDcCommonInfo {
     float Temperature;
     int Location;
     char PresentTime[128];
-    TransInfo pCreditCard[2];
+    //TransInfo pCreditCard[2];
     int runningcost[2];
-    float finalcost[2];
     unsigned int finalcost_flag[2];
     float ChargingRate;
     int PreAuth_Config;
     int PreAuth_Result;
     int LineStatus[2];
-    int donate_flag[2];
-    int ConnectorID[2];
     unsigned int AuthPass_flag[2];
     unsigned int PayPass_flag[2];
-    unsigned int PayFinish[2];
     unsigned int StopCharge[2];
-    unsigned int GetCardNo[2];
     unsigned int TradeCancel;
+    int ConnectorID[2];
     RecordTransactionInfo TransactionInfo[2];
-    RecordTransactionInfo UploadRedectInfo;
-    RecordTransactionInfo ReAuthComplete;
     int UnionSettlement;
     int Exe_ReDeduct;
     unsigned int OperateIDLE[2];
@@ -498,6 +501,10 @@ typedef struct StDcCommonInfo {
     int ClearServiceQR;
     int DebugFlag;
     int chillerCtrl;
+    int is_RemoteStart[2];
+    int is_AutoStart[2];
+    time_t RecordEnergyTime[2];
+    int is_exit[2];
 } DcCommonInfo;
 
 #endif /* CONFIG_H_ */

+ 150 - 66
EVSE/Projects/DD360Tcci/Apps/DataBase/DataBase.c

@@ -11,7 +11,7 @@
 
 //------------------------------------------------------------------------------
 #define DB_FILE                                 "/Storage/ChargeLog/localCgargingRecord.db"
-#define DEDUCT_FILE                 			"/Storage/ChargeLog/localDeductRecord.db"
+#define DEDUCT_FILE                 			"/Storage/ChargeLog/CreditCardRecord.db"
 
 //------------------------------------------------------------------------------
 static sqlite3 *localDb;
@@ -326,23 +326,53 @@ int InsertEventRecord(uint8_t *statusCode)
 
     return result;
 }
-
+void CreditCardTimeSet(char *_time, RecordTransactionInfo* deductInfo)
+{
+    _time[0] = '2';
+    _time[1] = '0';
+    _time[2] = (char)deductInfo->pCreditCard.TransDate[0];
+    _time[3] = (char)deductInfo->pCreditCard.TransDate[1];
+    _time[4] = '-';
+    _time[5] = (char)deductInfo->pCreditCard.TransDate[2];
+    _time[6] = (char)deductInfo->pCreditCard.TransDate[3];
+    _time[7] = '-';
+    _time[8] = (char)deductInfo->pCreditCard.TransDate[4];
+    _time[9] = (char)deductInfo->pCreditCard.TransDate[5];
+    _time[10] = ' ';
+    _time[11] = (char)deductInfo->pCreditCard.TransTime[0];
+    _time[12] = (char)deductInfo->pCreditCard.TransTime[1];
+    _time[13] = ':';
+    _time[14] = (char)deductInfo->pCreditCard.TransTime[2];
+    _time[15] = (char)deductInfo->pCreditCard.TransTime[3];
+    _time[16] = ':';
+    _time[17] = (char)deductInfo->pCreditCard.TransTime[4];
+    _time[18] = (char)deductInfo->pCreditCard.TransTime[5];
+    _time[19] = '\0';
+}
 
 int DeductDB_Open(void)
 {
 	int result = PASS;
 	char* errMsg = NULL;
-	char* createDeductInfoSql="CREATE TABLE IF NOT EXISTS deduct_record("
+	char* createDeductInfoSql="CREATE TABLE IF NOT EXISTS report_credit_deduct("
 					      	  "idx integer primary key AUTOINCREMENT, "
-							  "gunIndex text, "
-						  	  "transactionId text, "
-						  	  "deductResult text, "
-						  	  "isDonate text, "
-						  	  "approvalNo text, "
-						  	  "cardNo text,"
-						  	  "vemData text, "
-						  	  "amount text, "
-						  	  "isUpload text"
+							  "gun_index text, "
+                              "reportDate text, "
+                              "vemData text, "
+                              "txId text, "
+                              "creditNo text, "
+                              "amount text, "
+                              "storeId text, "
+                              "approvalNo text, "
+                              "RRN text, "
+                              "ROC text, "
+                              "isDonateInvoice text, "
+                              "isDeductResult text, "
+                              "isIntoCharge text, "
+                              "isUpload text, "
+                              "lineSn text, "
+                              "Energy text, "
+                              "RedeductTime "
 						  	  ");";
 
 	if(sqlite3_open(DEDUCT_FILE, &deductDb))
@@ -354,7 +384,6 @@ int DeductDB_Open(void)
 	else
 	{
 		log_info("Deduct database open successfully.");
-
 		if (sqlite3_exec(deductDb, createDeductInfoSql, 0, 0, &errMsg) != SQLITE_OK)
 		{
 			result = FAIL;
@@ -364,7 +393,7 @@ int DeductDB_Open(void)
 		{
 			log_info("Opened deduct info table successfully");
 		}
-
+       
 		sqlite3_close(deductDb);
 	}
 
@@ -379,26 +408,50 @@ int InsertDeductInfo(int gunIndex, RecordTransactionInfo *deductInfo)
     char approNo[13];
     char carNo[21];
     char vemData[65];
-
-    memset(approNo, 0x00, sizeof(approNo));
-    memset(carNo, 0x00, sizeof(carNo));
-    memset(vemData, 0x00, sizeof(vemData));
-
-    memcpy(approNo, (char *)&deductInfo->ApprovalNo, sizeof(deductInfo->ApprovalNo));
-    memcpy(carNo, (char *)&deductInfo->CardNo, sizeof(deductInfo->CardNo));
-    memcpy(vemData, (char *)&deductInfo->VemData, sizeof(deductInfo->VemData));
-
-	sprintf(sqlStr, "insert into deduct_record(gunIndex, transactionId, deductResult, isDonate, approvalNo, cardNo, vemData, amount, isUpload) "
-				    "values('%d', '%d', '%d', '%d', '%s', '%s', '%s', '%f', '%d');",
-				    gunIndex,
-				    deductInfo->TransactionId,
-				    deductInfo->DeductResult,
-				    deductInfo->IsDonateInvoice,
-					approNo,
-					carNo,
-					vemData,
-				    deductInfo->Amount,
-				    deductInfo->IsUpload);
+    char storeId[18];
+    char RRN[12];
+    char ROC[12];
+    char lineSn[20];
+    char _time[20];
+
+    memset(approNo, '\0', sizeof(approNo));
+    memset(carNo, '\0', sizeof(carNo));
+    memset(vemData, '\0', sizeof(vemData));
+    memset(storeId, '\0', sizeof(storeId));
+    memset(RRN, '\0', sizeof(RRN));
+    memset(ROC, '\0', sizeof(ROC));
+    memset(lineSn, '\0', sizeof(lineSn));
+
+    strncpy(approNo, (char *)&deductInfo->pCreditCard.ApprovalNo,9);
+    strncpy(carNo, (char *)&deductInfo->pCreditCard.CardNo,20);
+    strncpy(vemData, (char *)&deductInfo->pCreditCard.VemData,64);
+    strncpy(storeId, (char *)&deductInfo->pCreditCard.StoreId,18 );
+    strncpy(RRN,(char *)&deductInfo->pCreditCard.RRN,12);
+    strncpy(ROC,(char *)&deductInfo->pCreditCard.ROC,12);
+    CreditCardTimeSet(&_time, deductInfo);
+    //sprintf(reportDate, "%s%s", deductInfo->pCreditCard.TransDate, deductInfo->pCreditCard.TransTime);
+
+	sprintf(sqlStr, "insert into report_credit_deduct(gun_index, reportDate, vemData, txId, creditNo, amount, storeId, approvalNo, RRN, ROC, isDonateInvoice, isDeductResult, isIntoCharge, isUpload, lineSn, Energy, RedeductTime) "
+				    "values('%d', '%s', '%s', '%d', '%s', '%.1f', '%s', '%s', '%s', '%s', '%d', '%d', '%d' , '%d', '%s', '%.4f', '%d');",
+                    gunIndex,
+                    _time,
+				    vemData,
+                    deductInfo->TransactionId,
+                    carNo,
+                    deductInfo->Amount,
+					storeId,
+                    approNo,
+				    RRN,
+				    ROC,
+                    (int)deductInfo->IsDonateInvoice,
+                    (int)deductInfo->DeductResult,
+                    (int)deductInfo->isIntoCharge,
+                    (int)deductInfo->IsUpload,
+                    lineSn,
+                    deductInfo->Energy,
+                    deductInfo->RedeductTime);
+
+    //log_info("%s",sqlStr);
 
     if (sqlite3_open(DEDUCT_FILE, &deductDb))
     {
@@ -420,7 +473,7 @@ int InsertDeductInfo(int gunIndex, RecordTransactionInfo *deductInfo)
         }
 
 
-        sprintf(sqlStr, "delete from deduct_record where idx < (select idx from deduct_record order by idx desc limit 1)-10000;");
+        sprintf(sqlStr, "delete from report_credit_deduct where idx < (select idx from report_credit_deduct order by idx desc limit 1)-10000;");
         if (sqlite3_exec(deductDb, sqlStr, 0, 0, &errMsg) != SQLITE_OK)
         {
             result = FAIL;
@@ -442,11 +495,22 @@ int UpdateDeductInfoStatus(int gunIndex, RecordTransactionInfo *deductInfo)
     int result = PASS;
     char *errMsg = NULL;
     char sqlStr[1024] = {0};
-
-    sprintf(sqlStr, "update deduct_record set deductResult = %d, isUpload = %d where transactionId = %d;",
-                    deductInfo->DeductResult,
-                    deductInfo->IsUpload,
-                    deductInfo->TransactionId);
+    char vemData[65] = {0};
+    char _time[20] = { 0 };
+    memset(vemData, '\0', 65);
+    strncpy(vemData, (char*)&deductInfo->pCreditCard.VemData,64);
+
+    sprintf(sqlStr, "update report_credit_deduct set isUpload = %d , isIntoCharge = %d, amount = %.1f, txId = %d, isDeductResult = %d, Energy = %.4f, RedeductTime = %d where vemData = '%s'; ",
+                    (int)deductInfo->IsUpload,
+                    (int)deductInfo->isIntoCharge,
+                    deductInfo->Amount,
+                    deductInfo->TransactionId,
+                    (int)deductInfo->DeductResult,
+                    deductInfo->Energy,
+                    deductInfo->RedeductTime,
+                    vemData);
+
+    //log_info("%s",sqlStr);
 
     if (sqlite3_open(DEDUCT_FILE, &deductDb))
     {
@@ -460,7 +524,7 @@ int UpdateDeductInfoStatus(int gunIndex, RecordTransactionInfo *deductInfo)
         if (sqlite3_exec(deductDb, sqlStr, 0, 0, &errMsg) != SQLITE_OK)
         {
             result = FAIL;
-            log_info( "update deduct record error message: %s", errMsg);
+            log_info( "update deduct record error message: %s!", errMsg);
         }
         else
         {
@@ -483,19 +547,19 @@ int DB_GetDeductInfo(int deductResult, int uploadState, int *gunIndex, RecordTra
 
     if(deductResult >= 0 && uploadState >= 0)
     {
-        sprintf(sqlStr, "select * from deduct_record where deductResult = %d and isUpload = %d;", deductResult > 0 ? 1 : 0, uploadState > 0 ? 1 : 0);
+        sprintf(sqlStr, "select * from report_credit_deduct where isDeductResult = %d and isUpload = %d;", deductResult > 0 ? 1 : 0, uploadState > 0 ? 1 : 0);
     }
     else if(deductResult >= 0 && uploadState < 0)
     {
-        sprintf(sqlStr, "select * from deduct_record where deductResult = %d;", deductResult > 0 ? 1 : 0);
+        sprintf(sqlStr, "select * from report_credit_deduct where isDeductResult = 0 OR isDeductResult = 3;");
     }
     else if(deductResult < 0 && uploadState >= 0)
     {
-        sprintf(sqlStr, "select * from deduct_record where isUpload = %d;", uploadState > 0 ? 1 : 0);
+        sprintf(sqlStr, "select * from report_credit_deduct where isUpload = %d;", uploadState > 0 ? 1 : 0);
     }
     else
     {
-        sprintf(sqlStr, "select * from deduct_record;");
+        sprintf(sqlStr, "select * from report_credit_deduct;");
     }
 
     if (sqlite3_open(DEDUCT_FILE, &deductDb))
@@ -516,9 +580,9 @@ int DB_GetDeductInfo(int deductResult, int uploadState, int *gunIndex, RecordTra
                 deductInfo->TransactionId = atoi(rs[(idxRow * cols) + 2]);
                 deductInfo->DeductResult = atoi(rs[(idxRow * cols) + 3]);
                 deductInfo->IsDonateInvoice = atoi(rs[(idxRow * cols) + 4]);
-                strcpy((char *)&deductInfo->ApprovalNo, rs[(idxRow * cols) + 5]);
-                strcpy((char *)&deductInfo->CardNo, rs[(idxRow * cols) + 6]);
-                strcpy((char *)&deductInfo->VemData, rs[(idxRow * cols) + 7]);
+                strcpy((char *)&deductInfo->pCreditCard.ApprovalNo, rs[(idxRow * cols) + 5]);
+                strcpy((char *)&deductInfo->pCreditCard.CardNo, rs[(idxRow * cols) + 6]);
+                strcpy((char *)&deductInfo->pCreditCard.VemData, rs[(idxRow * cols) + 7]);
                 deductInfo->Amount = atoi(rs[(idxRow * cols) + 8]);
                 deductInfo->IsUpload = atoi(rs[(idxRow * cols) + 9]);
                 break;
@@ -568,7 +632,23 @@ int DB_GetReUploadDeduct(int *gunIndex, RecordTransactionInfo *deductInfo)
 
     return result;
 }
+void GetDeductTime(char* _time,RecordTransactionInfo* deductInfo)
+{
+    deductInfo->pCreditCard.TransDate[0] = (unsigned char)_time[2];
+    deductInfo->pCreditCard.TransDate[1] = (unsigned char)_time[3];
+    deductInfo->pCreditCard.TransDate[2] = (unsigned char)_time[5];
+    deductInfo->pCreditCard.TransDate[3] = (unsigned char)_time[6];
+    deductInfo->pCreditCard.TransDate[4] = (unsigned char)_time[8];
+    deductInfo->pCreditCard.TransDate[5] = (unsigned char)_time[9];
+
+    deductInfo->pCreditCard.TransTime[0] = (unsigned char)_time[11];
+    deductInfo->pCreditCard.TransTime[1] = (unsigned char)_time[12];
+    deductInfo->pCreditCard.TransTime[2] = (unsigned char)_time[14];
+    deductInfo->pCreditCard.TransTime[3] = (unsigned char)_time[15];
+    deductInfo->pCreditCard.TransTime[4] = (unsigned char)_time[17];
+    deductInfo->pCreditCard.TransTime[5] = (unsigned char)_time[18];
 
+}
 // return quantity of DeductInfo
 int DB_GetMultiDeductInfo(int deductResult, int uploadState, int *gunIndex, RecordTransactionInfo *deductInfo)
 {
@@ -579,19 +659,19 @@ int DB_GetMultiDeductInfo(int deductResult, int uploadState, int *gunIndex, Reco
 
     if(deductResult >= 0 && uploadState >= 0)
     {
-        sprintf(sqlStr, "select * from deduct_record where deductResult = %d and isUpload = %d;", deductResult > 0 ? 1 : 0, uploadState > 0 ? 1 : 0);
+        sprintf(sqlStr, "select * from report_credit_deduct where isDeductResult = %d and isUpload = %d;", deductResult > 0 ? 1 : 0, uploadState > 0 ? 1 : 0);
     }
     else if(deductResult >= 0 && uploadState < 0)
     {
-        sprintf(sqlStr, "select * from deduct_record where deductResult = %d;", deductResult > 0 ? 1 : 0);
+        sprintf(sqlStr, "select * from report_credit_deduct where isDeductResult IN (0,3) AND RedeductTime < 3;");
     }
     else if(deductResult < 0 && uploadState >= 0)
     {
-        sprintf(sqlStr, "select * from deduct_record where isUpload = %d;", uploadState > 0 ? 1 : 0);
+        sprintf(sqlStr, "select * from report_credit_deduct where isUpload = %d;", uploadState > 0 ? 1 : 0);
     }
     else
     {
-        sprintf(sqlStr, "select * from deduct_record;");
+        sprintf(sqlStr, "select * from report_credit_deduct;");
     }
 
     if (sqlite3_open(DEDUCT_FILE, &deductDb))
@@ -607,16 +687,22 @@ int DB_GetMultiDeductInfo(int deductResult, int uploadState, int *gunIndex, Reco
         {
             for (int idxRow = 1; idxRow <= rows; idxRow++)
             {
-                gunIndex[idxRow - 1] = atoi(rs[(idxRow * cols) + 1]);
-                deductInfo[idxRow - 1].TransactionId = atoi(rs[(idxRow * cols) + 2]);
-                deductInfo[idxRow - 1].DeductResult = atoi(rs[(idxRow * cols) + 3]);
-                deductInfo[idxRow - 1].IsDonateInvoice = atoi(rs[(idxRow * cols) + 4]);
-                strcpy((char *)&deductInfo[idxRow - 1].ApprovalNo, rs[(idxRow * cols) + 5]);
-                strcpy((char *)&deductInfo[idxRow - 1].CardNo, rs[(idxRow * cols) + 6]);
-                strcpy((char *)&deductInfo[idxRow - 1].VemData, rs[(idxRow * cols) + 7]);
-                deductInfo[idxRow - 1].Amount = atoi(rs[(idxRow * cols) + 8]);
-                deductInfo[idxRow - 1].IsUpload = atoi(rs[(idxRow * cols) + 9]);
-
+                //gunIndex[idxRow - 1] = atoi(rs[(idxRow * cols) + 1]);
+                deductInfo[idxRow - 1].ConnectorID = atoi(rs[(idxRow * cols) + 1]);
+               // GetDeductTime(rs[(idxRow * cols) + 1], deductInfo);
+                memcpy((char*)&deductInfo[idxRow - 1].pCreditCard.VemData, rs[(idxRow * cols) + 3],64);
+                deductInfo[idxRow - 1].TransactionId = atoi(rs[(idxRow * cols) + 4]);
+                memcpy((char*)&deductInfo[idxRow - 1].pCreditCard.CardNo, rs[(idxRow * cols) + 5],20);
+                deductInfo[idxRow - 1].Amount = atoi(rs[(idxRow * cols) + 6]);
+                memcpy((char*)&deductInfo[idxRow - 1].pCreditCard.StoreId, rs[(idxRow * cols) + 7],18);
+                memcpy((char*)&deductInfo[idxRow - 1].pCreditCard.ApprovalNo, rs[(idxRow * cols) + 8],9);
+                memcpy((char*)&deductInfo[idxRow - 1].pCreditCard.RRN, rs[(idxRow * cols) + 9],12);
+                memcpy((char*)&deductInfo[idxRow - 1].pCreditCard.ROC, rs[(idxRow * cols) + 10],12);
+                deductInfo[idxRow - 1].IsDonateInvoice = atoi(rs[(idxRow * cols) + 11]);
+                deductInfo[idxRow - 1].DeductResult = atoi(rs[(idxRow * cols) + 12]);
+                deductInfo[idxRow - 1].isIntoCharge = atoi(rs[(idxRow * cols) + 13]);
+                deductInfo[idxRow - 1].IsUpload = atoi(rs[(idxRow * cols) + 14]);
+                deductInfo[idxRow - 1].RedeductTime = atoi(rs[(idxRow * cols) + 15]);
                 if(idxRow >= 128)
                 {
                 	rows = 128;
@@ -662,9 +748,7 @@ void ReDeductTest()
 	{
 		for(int i = 0; i < quantity; i++)
 		{
-			printf("Gun %d Rededuct CardNo: %s", gunList[i], deductInfo[i].CardNo);
+			printf("Gun %d Rededuct CardNo: %s", gunList[i], deductInfo[i].pCreditCard.VemData);
 		}
 	}
-}
-
-
+}

+ 1 - 0
EVSE/Projects/DD360Tcci/Apps/ModuleChkSysTask/Module_ChkSysTask.c

@@ -247,4 +247,5 @@ void main(void)
 		}
 		CheckSystemTaskAlive();
     }
+	return;
 }

+ 128 - 106
EVSE/Projects/DD360Tcci/Apps/ModuleDoComm/DoComm.c

@@ -55,7 +55,7 @@ char old_Hexdump[10240];
 static uint8_t RemoteStartNoIDState = NO;
 static uint8_t ReservationState[2] = {0};
 static char ReservationIdTag[2][32];
-static uint8_t DeductResultReq[2] = {0};
+//static uint8_t DeductResultReq[2] = {0};
 static int LineStatusCode[2] = {0};
 static unsigned int LedIntensity = 0;
 static int TimeZoneOffset = 0;
@@ -634,6 +634,10 @@ static int miscCommandHandle(uint8_t dataLen, uint8_t plugNum, uint8_t *data)
 
         case MISC_CMD_BACKEND_STATUS :
             ShmSelectGunInfo->EthDevStatus.Backend = value;
+            if (ShmSelectGunInfo->EthDevStatus.Backend == 0 ||
+                ShmSelectGunInfo->EthDevStatus.Backend == 2) {
+                log_info("!!!!!!!!!!!!!! Backend Disconnect !!!!!!!!!!!!!!");
+            }
             break;
 
         case MISC_CMD_ETHERNET_STATUS :
@@ -936,16 +940,21 @@ static int chargingcapabilityHandle(uint8_t *data, uint8_t plugNum)
         pricesInfo[plugNum].Balance = ShmSelectGunInfo->PricesInfo[plugNum].Balance;
         pricesInfo[plugNum].Discount = ShmSelectGunInfo->PricesInfo[plugNum].Discount;
         pricesInfo[plugNum].TransactionId = ShmSelectGunInfo->PricesInfo[plugNum].TransactionId;
+        if (ShmSelectGunInfo->PricesInfo[plugNum].TransactionId != 0) {
+
+            ShmDcCommonData->TransactionInfo[plugNum].TransactionId = ShmSelectGunInfo->PricesInfo[plugNum].TransactionId;
+            UpdateDeductInfoStatus(plugNum, &ShmDcCommonData->TransactionInfo[plugNum]);
 
-        log_info("id = %d, transaction id = %d, user prices = %.2f, Discount = %.2f, Total cost = %.2f, Account balances = %.2f, currency = %s",
-                 plugNum,
-				 ShmSelectGunInfo->PricesInfo[plugNum].TransactionId,
-                 ShmSelectGunInfo->PricesInfo[plugNum].UserPrices,
-				 ShmSelectGunInfo->PricesInfo[plugNum].Discount,
-                 pDcChargingInfo->ChargingFee,
-                 ShmSelectGunInfo->PricesInfo[plugNum].Balance,
-                 (uint8_t *)GetCurrency(pSysConfig->BillingData.Currency)
-                );
+            log_info("id = %d, transaction id = %d, user prices = %.2f, Discount = %.2f, Total cost = %.2f, Account balances = %.2f, currency = %s",
+                plugNum,
+                ShmSelectGunInfo->PricesInfo[plugNum].TransactionId,
+                ShmSelectGunInfo->PricesInfo[plugNum].UserPrices,
+                ShmSelectGunInfo->PricesInfo[plugNum].Discount,
+                pDcChargingInfo->ChargingFee,
+                ShmSelectGunInfo->PricesInfo[plugNum].Balance,
+                (uint8_t*)GetCurrency(pSysConfig->BillingData.Currency)
+            );
+        }
     }
 
     return PASS;
@@ -1166,7 +1175,6 @@ static int responsePackeHandle(int fd, uint8_t *pResult, uint8_t plugNum, uint8_
                  pCsuResult->Data.Data[1]);
         ShmDcCommonData->ConnectorID[0] = pCsuResult->Data.Data[0];
         ShmDcCommonData->ConnectorID[1] = pCsuResult->Data.Data[1];
-
         break;
 
     case REG_POWER_CABINET_STATUS:
@@ -1501,8 +1509,8 @@ static int readChargerStationInfo(int fd)
 static int writeDeductInfo(int fd, uint8_t id,uint8_t gunIndex, RecordTransactionInfo *transactionInfo)
 {
     int ret = PASS;
-    uint8_t dataBuf[22] = {0};
-    int i;
+    uint8_t dataBuf[104] = {0};
+    //int i;
 
     memset((char *)dataBuf, 0x00, sizeof(dataBuf));
     dataBuf[0] = transactionInfo->DeductResult;
@@ -1518,21 +1526,30 @@ static int writeDeductInfo(int fd, uint8_t id,uint8_t gunIndex, RecordTransactio
     dataBuf[7] = (amount >> 16) & 0xFF;
     dataBuf[8] = (amount >> 8) & 0xFF;
     dataBuf[9] = (amount & 0xFF);
-    memcpy((char *)&dataBuf[10], transactionInfo->ApprovalNo,9);
+    memcpy((char *)&dataBuf[10], transactionInfo->pCreditCard.ApprovalNo,9);
+    memcpy((char *)&dataBuf[19], transactionInfo->pCreditCard.VemData, 64);
+    memcpy((char*)&dataBuf[83], transactionInfo->pCreditCard.CardNo, 20);
     /*
     for(i=0;i<22;i++) {
     	log_info("dataBuf[%d]:0x%x",i,dataBuf[i]);
     }
     */
-    log_info("Gun[%d] TransactionId:%d DeductResult:%d IsDonateInvoice:%d Amount:%f",
-    		gunIndex,transactionInfo->TransactionId,transactionInfo->DeductResult,transactionInfo->IsDonateInvoice,transactionInfo->Amount);
+    log_info("Gun[%d] TransactionId:%d DeductResult:%d IsDonateInvoice:%d Amount:%f Approva Num:'%s' VemData:'%s' CardNo:'%s'",
+    		transactionInfo->ConnectorID,
+            transactionInfo->TransactionId,
+            transactionInfo->DeductResult,
+            transactionInfo->IsDonateInvoice,
+            transactionInfo->Amount,
+            transactionInfo->pCreditCard.ApprovalNo,
+            transactionInfo->pCreditCard.VemData,
+            transactionInfo->pCreditCard.CardNo);
     // copy deduct result to dataBuf here
 
     if ((ret = composeSocketData(fd,
                                  id,
                                  OP_WRITE_DATA,
                                  REG_DEDUCT_INFO,
-                                 22,
+                                 104,
                                  &dataBuf[0])) == FAIL) {
         return ret;
     }
@@ -2112,7 +2129,7 @@ static int messageTrigger(int fd, uint8_t plugNum, uint8_t gunID, uint8_t curReg
                 if (readChargingCapability(fd, gunID) == PASS) {
 					gMoreInfoReq[plugNum].bits.FinalCostReq = false;
 					pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(plugNum);
-					ShmDcCommonData->finalcost[plugNum] = pDcChargingInfo->ChargingFee;
+					ShmDcCommonData->TransactionInfo[plugNum].Amount = pDcChargingInfo->ChargingFee;
 					ShmDcCommonData->finalcost_flag[plugNum] = TRUE;
 					log_info("Gun %d get final cost %f", plugNum, pDcChargingInfo->ChargingFee);
                 }
@@ -2160,7 +2177,47 @@ static int messageTrigger(int fd, uint8_t plugNum, uint8_t gunID, uint8_t curReg
             }
             curReg = REG_DISPENSER_REQUEST;
             break;
+        case REG_DISPENSER_REQUEST:
+            gConnectorActReq[plugNum].bits.ChargingCancel = ShmDcCommonData->OperateIDLE[plugNum];
+            if (gConnectorActReq[plugNum].Value != 0)
+            {
+                if (DiffTimeb(gRegTimeUp[plugNum][curReg], NowTime) > LOOP_RETRY_TIME ||
+                    DiffTimeb(gRegTimeUp[plugNum][curReg], NowTime) < 0) {
+
+                    if (writeDispenserRequest(fd, gunID, plugNum) == PASS)
+                    {
+                        gConnectorActReq[plugNum].Value = 0;
+                        log_info("Gun %d CHARGING_CANCEL OK", plugNum);
+                        ShmDcCommonData->OperateIDLE[plugNum] = 0;
+                    }
+                    ftime(&gRegTimeUp[plugNum][curReg]);
+                }
+            }
+            curReg = REG_QRCODE_URL_INFO;
+            break;
+        case REG_QRCODE_URL_INFO:
+            if (gunID == 1) {
+                if (DiffTimeb(gRegTimeUp[plugNum][curReg], NowTime) > (LOOP_RETRY_TIME * 10) ||
+                    DiffTimeb(gRegTimeUp[plugNum][curReg], NowTime) < 0
+                    ) {
+                    readQRcodeURLAndSystemDate(fd);
+                    ftime(&gRegTimeUp[plugNum][curReg]);
+                }
+            }
 
+            //check misc command from power cabinet
+            if (gDoCommGblData.MiscCmd != 0) {
+                if (gDoCommGblData.MiscCmd != REG_MISC_CONTROL) {
+                    log_error("misc command failed = %x", gDoCommGblData.MiscCmd);
+                }
+                curReg = gDoCommGblData.MiscCmd;
+            } else if (gMoreInfoReq[plugNum].Value != 0) {
+                curReg = REG_RESERVATION_IDTAG;
+            } else {
+                isContinue = 0;
+            }
+            //curReg = REG_SOFTWARE_UPDATE;
+            break;
         //case REG_USER_ID:
         //    writeUserID(fd, gunID, uint8_t *pUserID);
         //    break;
@@ -2204,29 +2261,7 @@ static int messageTrigger(int fd, uint8_t plugNum, uint8_t gunID, uint8_t curReg
         //case REG_PRESENT_CHARGING_INFO:
         //    break;
 
-        case REG_QRCODE_URL_INFO:
-            if (gunID == 1) {
-                if (DiffTimeb(gRegTimeUp[plugNum][curReg], NowTime) > (LOOP_RETRY_TIME * 10) ||
-                        DiffTimeb(gRegTimeUp[plugNum][curReg], NowTime) < 0
-                   ) {
-                    readQRcodeURLAndSystemDate(fd);
-                    ftime(&gRegTimeUp[plugNum][curReg]);
-                }
-            }
 
-            //check misc command from power cabinet
-            if (gDoCommGblData.MiscCmd != 0) {
-                if (gDoCommGblData.MiscCmd != REG_MISC_CONTROL) {
-                    log_error("misc command failed = %x", gDoCommGblData.MiscCmd);
-                }
-                curReg = gDoCommGblData.MiscCmd;
-            } else if (gMoreInfoReq[plugNum].Value != 0) {
-                curReg = REG_RESERVATION_IDTAG;
-            } else {
-                isContinue = 0;
-            }
-            //curReg = REG_SOFTWARE_UPDATE;
-            break;
 
         //case REG_WAIT_PLUG_IT_STATE:
         //    if (DiffTimeb(gRegTimeUp[plugNum][curReg], NowTime) > (LOOP_RETRY_TIME / 10)) {
@@ -2265,24 +2300,7 @@ static int messageTrigger(int fd, uint8_t plugNum, uint8_t gunID, uint8_t curReg
 
         //case REG_DISPENSER_REQUEST:
         //    break;
-            case REG_DISPENSER_REQUEST:
-                gConnectorActReq[plugNum].bits.ChargingCancel = ShmDcCommonData->OperateIDLE[plugNum];
-                if (gConnectorActReq[plugNum].Value != 0)
-                {
-                    if (DiffTimeb(gRegTimeUp[plugNum][curReg], NowTime) > LOOP_RETRY_TIME ||
-                        DiffTimeb(gRegTimeUp[plugNum][curReg], NowTime) < 0) {
 
-                        if (writeDispenserRequest(fd, gunID, plugNum) == PASS)
-                        {
-                            gConnectorActReq[plugNum].Value = 0;
-                            log_info("Gun %d CHARGING_CANCEL OK",plugNum);
-                            ShmDcCommonData->OperateIDLE[plugNum] = 0;
-                        }
-                        ftime(&gRegTimeUp[plugNum][curReg]);
-                    }
-                }
-                curReg = REG_QRCODE_URL_INFO;
-                break;
         case REG_REMOTE_START_NO_ID:
             if(gMoreInfoReq[plugNum].bits.RemoteStartNoID)
             {
@@ -2354,7 +2372,6 @@ static int messageTrigger(int fd, uint8_t plugNum, uint8_t gunID, uint8_t curReg
 //
 //    return NO;
 //}
-
 static void systemStatusProcess(int fd, uint8_t totalGun, uint8_t plugNum, uint8_t gunID)
 {
     uint8_t i = 0;
@@ -2366,49 +2383,63 @@ static void systemStatusProcess(int fd, uint8_t totalGun, uint8_t plugNum, uint8
     int reupload_num = 0;
     struct timeb SeqEndTime;
     struct tm* tm;
+
     switch (pDcChargingInfo->SystemStatus) {
     case S_IDLE:
     case S_RESERVATION:
     case S_MAINTAIN:
     case S_ALARM:
     case S_AUTHORIZING:
+        /*
         if(pDcChargingInfo->SystemStatus != S_ALARM)
         {
             DeductResultReq[plugNum] = NO;
         }
+        */
         checkAuthorProcess(fd, plugNum);
 
         //authorization complete, write wait plug it state
         if (ShmSelectGunInfo->PricesInfo[plugNum].Balance == FAIL_BALANCE_PRICES) {
             break;
         }
+
         ftime(&SeqEndTime);
         SeqEndTime.time = time(NULL);
         tm = localtime(&SeqEndTime.time);
 
-        if (tm->tm_min % 2 == 0 && pSysInfo->SystemPage == _PAGE_IDLE) {
+        if (pSysInfo->SystemPage == _PAGE_IDLE || pSysInfo->SystemPage == _PAGE_SELECT_GUN) {
+            ftime(&AuthNowTime);
+            if (DiffTimeb(gRegTimeUp[plugNum][REG_DEDUCT_INFO], AuthNowTime) > LOOP_RETRY_TIME ||
+                DiffTimeb(gRegTimeUp[plugNum][REG_DEDUCT_INFO], AuthNowTime) < 0
+                ) {
+                reupload_num = DB_GetMultiReUploadDeduct(&reupload_gunIndex[0], &reuploadInfo[0]);
+                if (reupload_num >= 1) {
+
+                    if (writeDeductInfo(fd, reuploadInfo[0].ConnectorID, reupload_gunIndex[0], &reuploadInfo[0]) == PASS) {
+                        log_info("Reupload Success");
+                        reuploadInfo[0].IsUpload = YES;
+                        UpdateDeductInfoStatus(reupload_gunIndex[0], &reuploadInfo[0]);
+                    } else
+                        log_info("Reupload fail");
+
+                }
+                ftime(&gRegTimeUp[plugNum][REG_DEDUCT_INFO]);
+            }
+        }
+        /*
+        if (pSysInfo->SystemPage == _PAGE_IDLE || pSysInfo->SystemPage == _PAGE_SELECT_GUN) {
+            reupload_num = DB_GetMultiReUploadDeduct(&reupload_gunIndex[0], &reuploadInfo[0]);
+            log_info("ReUpload number:%d", reupload_num);
 
-            reupload_num = DB_GetMultiReUploadDeduct(&reupload_gunIndex, &reuploadInfo);
-            //log_info("ReUpload number:%d", reupload_num);
             for (j = 0; j < reupload_num; j++) {
-                log_info("Card No:%s", reuploadInfo[j].CardNo);
-                if (writeDeductInfo(fd, 0xff, reupload_gunIndex[j], &reuploadInfo[j]) == PASS) {
+                log_info("Connector ID:%d Card No:%s", reuploadInfo[j].ConnectorID, reuploadInfo[j].pCreditCard.CardNo);
+
+                if (writeDeductInfo(fd, reuploadInfo[j].ConnectorID, reupload_gunIndex[j], &reuploadInfo[j]) == PASS) {
                     log_info("Reupload Success");
                     reuploadInfo[j].IsUpload = YES;
                     UpdateDeductInfoStatus(reupload_gunIndex[j], &reuploadInfo[j]);
                 } else
-                    log_info("writeDeductInfo fail");
-            }
-
-        }
-
-        /*
-        if (ShmDcCommonData->reupload_deduct_status == 1) {
-            log_info("Reupload Deduct");
-        	if (writeDeductInfo(fd, 0xff,plugNum, &ShmDcCommonData->UploadRedectInfo) == PASS) {
-        		ShmDcCommonData->UploadRedectInfo.IsUpload = YES;
-            } else {
-                log_info("Reupload Deduct Failure!");
+                    log_info("Reupload fail");
             }
         }*/
 
@@ -2437,21 +2468,7 @@ static void systemStatusProcess(int fd, uint8_t totalGun, uint8_t plugNum, uint8
 				writeGroundFaultDetection(fd, 0, gunID);
             ftime(&gRegTimeUp[plugNum][REG_CHARGING_CAP]);
         }
-        if(!DeductResultReq[plugNum] && pDcChargingInfo->SystemStatus == S_ALARM &&
-        		ShmDcCommonData->PayFinish[plugNum] == TRUE)
-        {
-            DeductResultReq[plugNum] = YES;
-            log_info("Write Gun %d Deduct Result", plugNum);
-            if (writeDeductInfo(fd, gunID, plugNum, &ShmDcCommonData->TransactionInfo[plugNum]) == PASS) {                
-                ShmDcCommonData->finalcost_flag[plugNum] = FALSE;
-                ShmDcCommonData->PayFinish[plugNum] = FALSE;
-                ShmDcCommonData->TransactionInfo[plugNum].IsUpload = YES;
-                UpdateDeductInfoStatus(plugNum, &ShmDcCommonData->TransactionInfo[plugNum]);
-                log_info("writeDeductInfo finish");
-            } else {
-                log_info("Write Deduct fail");
-            }
-        }
+
         break;
 
     case S_PREPARNING: //get permission
@@ -2617,22 +2634,7 @@ static void systemStatusProcess(int fd, uint8_t totalGun, uint8_t plugNum, uint8
 				writeGroundFaultDetection(fd, 0, gunID);
             ftime(&gRegTimeUp[plugNum][REG_CHARGING_CAP]);
         }
-        if(!DeductResultReq[plugNum] &&
-				ShmDcCommonData->PayFinish[plugNum] == TRUE)
-        {
-            DeductResultReq[plugNum] = YES;
-            log_info("Write Gun %d Deduct Result", plugNum);
-            if (writeDeductInfo(fd, gunID, plugNum, &ShmDcCommonData->TransactionInfo[plugNum]) == PASS) {
-                ShmDcCommonData->finalcost_flag[plugNum] = FALSE;
-                ShmDcCommonData->PayFinish[plugNum] = FALSE;
-                ShmDcCommonData->TransactionInfo[plugNum].IsUpload = YES;
-                UpdateDeductInfoStatus(plugNum, &ShmDcCommonData->TransactionInfo[plugNum]);
-                log_info("writeDeductInfo finish");
-            }
-            else {
-                log_info("Write Deduct fail");
-            }
-        }
+
         break;
 
     default:
@@ -2695,7 +2697,25 @@ static int networkCreatePorcess(void)
 
     return fd;
 }
+void CreditCardProcess(int fd,int plugNum,int gunID, RecordTransactionInfo *pInfo)
+{
+    if (pInfo->IsUpload == TRUE || (strcmp(pInfo->pCreditCard.VemData,"") == 0) ||
+        pSysInfo->SystemPage == _PAGE_SENSING)
+        return;
+
+    if (writeDeductInfo(fd, gunID, plugNum, &ShmDcCommonData->TransactionInfo[plugNum]) == PASS) {
+        ShmDcCommonData->TransactionInfo[plugNum].IsUpload = YES;
+        UpdateDeductInfoStatus(plugNum, &ShmDcCommonData->TransactionInfo[plugNum]);
 
+        if (ShmDcCommonData->TransactionInfo[plugNum].DeductResult == _DEDUCT_CANCEL) {
+            memset(&ShmDcCommonData->TransactionInfo[plugNum].pCreditCard, 0x00, sizeof(TransInfo));
+        }
+
+        log_info("writeDeductInfo finish");
+    } else {
+        log_info("Write Deduct fail");
+    }
+}
 int main(int argc, char *argv[])
 {
     uint8_t plugNum = 0, gunID = 0;
@@ -2759,6 +2779,8 @@ int main(int argc, char *argv[])
                 gunID = gDoCommGblData.ConnectorID[plugNum];
                 systemStatusProcess(fd, totalConnCount, plugNum, gunID);
 
+                CreditCardProcess(fd, plugNum,gunID, &ShmDcCommonData->TransactionInfo[plugNum]);
+
                 initDone = messageTrigger(fd,
                                           plugNum,
                                           gunID,

+ 1 - 1
EVSE/Projects/DD360Tcci/Apps/ModuleDoComm/DoComm.h

@@ -16,7 +16,7 @@
 #define TFTP_PULL_CMD                           "tftp"
 #define SIGTERM_MSG                             "SegmentFault.~~~~\n"
 
-#define MAX_REGISTER_NUM                        30
+#define MAX_REGISTER_NUM                        40
 
 #define CHECK_NETWORK_FAIL_COUNT                10//10
 #define CONNECT_SERVER_FAIL_COUNT               3//5

+ 179 - 168
EVSE/Projects/DD360Tcci/Apps/ModuleLcmCtrl/Module_LcmControl.c

@@ -166,6 +166,92 @@ void confirmSelGun(uint8_t selGun)
     //StartGunInfoTimeoutDet(selGun, Timeout_SelectGun);
     //StartSystemTimeoutDet(Timeout_ReturnViewPage);
 }
+
+void WriteCmdToLcm(uint8_t *cmd, uint8_t cmdLen)
+{
+    int len = write(_port, cmd, cmdLen);
+    if (len < sizeof(cmd)) {
+        log_error("Write cmd to LCM Failure. ");
+    }
+}
+void ReadMsgFromLcm(uint8_t* msg, uint8_t readLen)
+{
+    read(_port, msg, readLen);
+
+    //  5a : CMD_TITLE_1
+    //  a5 : CMD_TITLE_2
+    //  5
+    //  81 : CMD_WRITE
+    //  3  : CMD_REGISTER
+    //  2  : Data length
+    //  0  : High byte
+    //  1  : Low byte
+
+    //  printf("-------------------------------------------- \n");
+    //  printf("msg = %x \n", *msg);            // A5
+    //  printf("msg = %x \n", *(msg + 1));      // 5A
+    //  printf("msg = %x \n", *(msg + 2));      // Len : [3] ~ [6] + Data Len
+    //  printf("msg = %x \n", *(msg + 3));      // cmd : 0x83
+    //  printf("msg = %x \n", *(msg + 4));      // addr : H
+    //  printf("msg = %x \n", *(msg + 5));      // addr : L
+    //  printf("msg = %x \n", *(msg + 6));      // Data Len
+    //
+    //  printf("msg = %x \n", *(msg + 7));
+    //  printf("msg = %x \n", *(msg + 8));
+    //  printf("msg = %x \n", *(msg + 9));
+    //  printf("msg = %x \n", *(msg + 10));
+    //  printf("msg = %x \n", *(msg + 11));
+    //  printf("msg = %x \n", *(msg + 12));
+    //  printf("msg = %x \n", *(msg + 13));
+    //  printf("msg = %x \n", *(msg + 14));
+        /*
+        for(uint8_t i = 0 ; i<readLen+3; i++) {
+            log_info("Read data[%d]:0x%x",i,msg[i]);
+        }*/
+
+    if (*msg == CMD_TITLE_1 && *(msg + 1) == CMD_TITLE_2)
+    {
+        if (*(msg + 3) == CMD_WRITE)
+        {
+            switch (*(msg + 4))
+            {
+            case CMD_REGISTER:
+            {
+                // 頁面
+                if (strcmp((char*)pSysInfo->LcmHwRev, "") != EQUAL)
+                    strcpy((char*)pSysInfo->LcmHwRev, moduleName);
+
+                _currentPage = *(msg + 7);
+                log_info("Current Page:%d", _currentPage);
+                //                  if (_currentPage != 1 && _currentPage != 5 && _currentPage != 6 && _currentPage != 7 && _currentPage != 8)
+                //                      printf("_currentPage = %d \n", _currentPage);
+            }
+            break;
+            }
+        } else if (*(msg + 3) == CMD_MULTI_READ)
+        {
+            short key = ((short)(*(msg + 4) << 8) + *(msg + 5));
+            if (strcmp((char*)pSysInfo->LcmHwRev, "") != EQUAL)
+                strcpy((char*)pSysInfo->LcmHwRev, moduleName);
+            if (key == 0x0014)
+                _currentPage = *(msg + 8);
+            if (key >= _Touch_IDLE && key <= _Touch_Pay_LinePay) {
+
+                _btn_press_id = key;
+                _btn_press = *(msg + 8);
+            }
+            //          switch ((unsigned short) (*(msg + 4) << 8) + (unsigned short) *(msg + 5))
+            //          {
+            //              case BUTTON_GUN_INDEX:
+            //              {
+            //                  // 當前選的槍號
+            //                  _curGunIndex = (*(msg + 8));
+            //              }
+            //              break;
+            //          }
+        }
+    }
+}
 void GetDeviceInfoStatus(short address, uint8_t len)
 {
     uint8_t cmd[8];
@@ -185,14 +271,40 @@ void GetDeviceInfoStatus(short address, uint8_t len)
     usleep(1000);
     ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
 }
-void WriteCmdToLcm(uint8_t *cmd, uint8_t cmdLen)
+
+void DisplayValueToLcm(short address, uint8_t* data, uint8_t len)
 {
-    int len = write(_port, cmd, cmdLen);
-    if (len < sizeof(cmd)) {
-        log_error("Write cmd to LCM Failure. ");
+
+    uint8_t cmd[256];
+    memset(cmd, 0x00, sizeof(cmd));
+    uint8_t msg[9];
+    memset(msg, 0x00, sizeof(msg));
+
+    cmd[0] = CMD_TITLE_1;
+    cmd[1] = CMD_TITLE_2;
+    cmd[2] = 0x03 + len;
+    cmd[3] = CMD_MULTI_WRITE;
+    cmd[4] = address >> 8;
+    cmd[5] = address & 0x00FF;
+
+    for (uint8_t count = 0; count < len; count++)
+    {
+        cmd[6 + count] = *(data + count);
     }
+
+    WriteCmdToLcm(cmd, cmd[2] + 3);
+    usleep(10000);
+    ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
 }
 
+void ChangeDisplay2Value(short address, short value)
+{
+    uint8_t data[2];
+    data[0] = value >> 8;
+    data[1] = value & 0x00FF;
+    //log_info("Addr:0x%x, value:%d",address,value);
+    DisplayValueToLcm(address, data, sizeof(data));
+}
 void TradeRunning(uint8_t _run)
 {
     if (_run == TRUE) {
@@ -230,61 +342,67 @@ void CheckReturnPress()
             ShmDcCommonData->OperateIDLE[pSysInfo->CurGunSelected] = 1;
         log_info("Operate return to IDLE");
     }
-	if ( pDcChargingInfo->SystemStatus == S_AUTHORIZING ) {
+    // Cancel Trade
+	if ( pDcChargingInfo->SystemStatus == S_AUTHORIZING || 
+        (pDcChargingInfo->SystemStatus == S_IDLE && pSysInfo->SystemPage == _PAGE_AUTHORIZE)) {
+        log_info("Press Return button cancel PreAuth");
         ShmDcCommonData->TradeCancel = TRUE;
-        /*
-		if (pSysInfo->SystemPage == _PAGE_AUTHORIZE ) {
-			pSysInfo->SystemPage = _PAGE_SELECT_PAY;
-		} else if (pSysInfo->SystemPage == _PAGE_PLUGIN)
-            pSysInfo->SystemPage = _PAGE_SELECT_GUN;
-            */
+        pSysInfo->SystemPage = _PAGE_SENSING;
+        StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
+        StartSystemTimeoutDet(Timeout_TradeCancel);
         for (i = 0; i <= 30; i++) {
             if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE)
                 break;
             sleep(1);
         }
-        pSysInfo->SystemPage = _PAGE_SENSING;
-        StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
-        StartSystemTimeoutDet(Timeout_TradeCancel);
+
         ShmDcCommonData->PreAuth_Result = 0;
-        log_info("Press Return button cancel PreAuth");
-		ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
-		ShmDcCommonData->PreAuth_Result = 0;
-		for(i=0;i<=30;i++) {
-			if(ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE)
-				break;
-			sleep(1);
-		}
-		ShmDcCommonData->PreAuth_Result = 0;
+        ShmDcCommonData->AuthPass_flag[pSysInfo->CurGunSelected] = FALSE;
+        
+        log_info("Sensing Card vemdata:'%s need to cancel", ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].pCreditCard.VemData);
+        if (strcmp(ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].pCreditCard.VemData, "") != 0) {
+            ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
+            ShmDcCommonData->PreAuth_Result = 0;
+            for (i = 0; i <= 30; i++) {
+                if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE)
+                    break;
+                sleep(1);
+            }
+            ShmDcCommonData->PreAuth_Result = 0;
+        }
         StopSystemTimeoutDet();
+        pSysInfo->SystemPage = _PAGE_SELECT_GUN;
         pDcChargingInfo->SystemStatus = S_IDLE;
 		strcpy((char *)pSysConfig->UserId, "");
 		return;
 	}
+    // Authorize Page Cancel Trade
+    /*
     if (pDcChargingInfo->SystemStatus == S_IDLE && pSysInfo->SystemPage == _PAGE_AUTHORIZE) {
         ShmDcCommonData->TradeCancel = TRUE;
         pSysInfo->SystemPage = _PAGE_SENSING;
+        StopGunInfoTimeoutDet(pSysInfo->CurGunSelected);
         StartSystemTimeoutDet(Timeout_TradeCancel);
         if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_PREAUTH) {
             for (i = 0; i <= 30; i++) {
-                if (ShmDcCommonData->PreAuth_Result != 0)
+                if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE)
                     break;
                 sleep(1);
             }
             ShmDcCommonData->PreAuth_Result = 0;
-            if (ShmDcCommonData->AuthPass_flag[pSysInfo->CurGunSelected] == TRUE) {
-                ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
-                ShmDcCommonData->PreAuth_Result = 0;
-                for (i = 0; i <= 30; i++) {
-                    if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE)
-                        break;
-                    sleep(1);
-                }
+        }
+        if (strcmp(ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].pCreditCard.VemData, "") != 0) {
+            ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
+            ShmDcCommonData->PreAuth_Result = 0;
+            for (i = 0; i <= 30; i++) {
+                if (ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE)
+                    break;
+                sleep(1);
             }
-            pSysInfo->SystemPage = _PAGE_SELECT_PAY;
         }
+        pSysInfo->SystemPage = _PAGE_SELECT_PAY;
         return;
-    }
+    }*/
 	if ( pSysInfo->SystemPage == _PAGE_EXIT ) {
         StopSystemTimeoutDet();
 		pDcChargingInfo->SystemStatus = S_IDLE;
@@ -308,12 +426,16 @@ void CheckStopPress()
 }
 void CheckStopConfirmPress()
 {
-	int result;
+
 	pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(pSysInfo->CurGunSelected);
 	pDcChargingInfo->SystemStatus = S_TERMINATING;
 	pSysInfo->SystemPage = _PAGE_PAYING;
 	is_stop = FALSE;
 	ShmDcCommonData->StopCharge[pSysInfo->CurGunSelected] = TRUE;
+    if (ShmDcCommonData->is_AutoStart[pSysInfo->CurGunSelected] == TRUE) {
+        pSysInfo->SystemPage = _PAGE_COMPLETE;
+        return;
+    }
 	StartGunInfoTimeoutDet(pSysInfo->CurGunSelected,Timeout_FinalCost);
 	/*
 	ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
@@ -342,28 +464,23 @@ void CheckDonateBill(uint8_t gunIndex)
 void CheckDonateYes()
 {
 	pSysInfo->SystemPage = _PAGE_SELECT_PAY;
-	ShmDcCommonData->donate_flag[pSysInfo->CurGunSelected] = TRUE;
+	ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].IsDonateInvoice = TRUE;
 }
 void CheckDonateNo()
 {
 	pSysInfo->SystemPage = _PAGE_BILL;
-	ShmDcCommonData->donate_flag[pSysInfo->CurGunSelected] = FALSE;
+    ShmDcCommonData->TransactionInfo[pSysInfo->CurGunSelected].IsDonateInvoice = FALSE;
 }
 void CheckPayCreditCard()
 {
     ShmDcCommonData->LineStatus[pSysInfo->CurGunSelected] = 0;
     ShmDcCommonData->TradeCancel = FALSE;
    	pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(pSysInfo->CurGunSelected);
-	if (pDcChargingInfo->SystemStatus == S_IDLE) {
-		//confirmSelGun(pSysInfo->CurGunSelected);
+	if (pDcChargingInfo->SystemStatus == S_IDLE && pSysInfo->SystemPage == _PAGE_SELECT_PAY &&
+        ShmDcCommonData->PreAuth_Config == _CREDITCARD_IDLE) {
         ShmDcCommonData->PreAuth_Config = _CREDITCARD_PREAUTH;
         ShmDcCommonData->PreAuth_Result = 0;
-		//setSelGunWaitToAuthor(pSysInfo->CurGunSelected);
 		pSysInfo->SystemPage = _PAGE_AUTHORIZE;
-		//pDcChargingInfo->SystemStatus = S_AUTHORIZING;
-
-		//
-		//AuthorizingStart();
 	}
 }
 void CheckPayIcash()
@@ -376,7 +493,6 @@ void CheckPayLinePay()
 }
 void CheckTouchPress(short id)
 {
-
     GetDeviceInfoStatus(id,1);
     if (_btn_press >= 1 && _btn_press_id == id ) {
     	_btn_press_count++;
@@ -481,7 +597,6 @@ void CheckTouchPress(short id)
 
 void CheckLCMPressed()
 {
-	int i;
     pid_t Pid = fork();
     if ( Pid == 0 ) {
         while (1) {
@@ -545,85 +660,7 @@ void CheckLCMPressed()
     log_info("Create LCM fork:%d",Pid);
 }
 
-void ReadMsgFromLcm(uint8_t *msg, uint8_t readLen)
-{
-    read(_port, msg, readLen);
-
-//  5a : CMD_TITLE_1
-//  a5 : CMD_TITLE_2
-//  5
-//  81 : CMD_WRITE
-//  3  : CMD_REGISTER
-//  2  : Data length
-//  0  : High byte
-//  1  : Low byte
-
-//  printf("-------------------------------------------- \n");
-//  printf("msg = %x \n", *msg);            // A5
-//  printf("msg = %x \n", *(msg + 1));      // 5A
-//  printf("msg = %x \n", *(msg + 2));      // Len : [3] ~ [6] + Data Len
-//  printf("msg = %x \n", *(msg + 3));      // cmd : 0x83
-//  printf("msg = %x \n", *(msg + 4));      // addr : H
-//  printf("msg = %x \n", *(msg + 5));      // addr : L
-//  printf("msg = %x \n", *(msg + 6));      // Data Len
-//
-//  printf("msg = %x \n", *(msg + 7));
-//  printf("msg = %x \n", *(msg + 8));
-//  printf("msg = %x \n", *(msg + 9));
-//  printf("msg = %x \n", *(msg + 10));
-//  printf("msg = %x \n", *(msg + 11));
-//  printf("msg = %x \n", *(msg + 12));
-//  printf("msg = %x \n", *(msg + 13));
-//  printf("msg = %x \n", *(msg + 14));
-    /*
-    for(uint8_t i = 0 ; i<readLen+3; i++) {
-        log_info("Read data[%d]:0x%x",i,msg[i]);
-    }*/
-
-    if(*msg == CMD_TITLE_1 && *(msg + 1) == CMD_TITLE_2)
-    {
-        if(*(msg + 3) == CMD_WRITE)
-        {
-            switch (*(msg + 4))
-            {
-                case CMD_REGISTER:
-                {
-                    // 頁面
-                    if(strcmp((char *)pSysInfo->LcmHwRev, "") != EQUAL)
-                        strcpy((char *)pSysInfo->LcmHwRev, moduleName);
-
-                    _currentPage = *(msg + 7);
-                    log_info("Current Page:%d",_currentPage);
-//                  if (_currentPage != 1 && _currentPage != 5 && _currentPage != 6 && _currentPage != 7 && _currentPage != 8)
-//                      printf("_currentPage = %d \n", _currentPage);
-                }
-                break;
-            }
-        }
-        else if (*(msg + 3) == CMD_MULTI_READ)
-        {
-            short key = ((short)(*(msg + 4) << 8) + *(msg + 5));
-            if(strcmp((char *)pSysInfo->LcmHwRev, "") != EQUAL)
-                strcpy((char *)pSysInfo->LcmHwRev, moduleName);
-            if (key == 0x0014)
-                _currentPage = *(msg + 8);
-            if ( key >= _Touch_IDLE && key <=_Touch_Pay_LinePay ) {
 
-                _btn_press_id = key;
-                _btn_press = *(msg + 8);
-            }
-//          switch ((unsigned short) (*(msg + 4) << 8) + (unsigned short) *(msg + 5))
-//          {
-//              case BUTTON_GUN_INDEX:
-//              {
-//                  // 當前選的槍號
-//                  _curGunIndex = (*(msg + 8));
-//              }
-//              break;
-//          }
-        }
-    }
-}
 void GetHrFormTimeString(char* time,char* hr)
 {
     //char tm[] = "2021-12-06 17:29:08:084";
@@ -718,39 +755,7 @@ void GetCurrentPage()
 }
 
 
-void DisplayValueToLcm(short address, uint8_t *data, uint8_t len)
-{
-
-    uint8_t cmd[256];
-    memset(cmd, 0x00, sizeof(cmd));
-    uint8_t msg[9];
-    memset(msg, 0x00, sizeof(msg));
-
-    cmd[0] = CMD_TITLE_1;
-    cmd[1] = CMD_TITLE_2;
-    cmd[2] = 0x03 + len;
-    cmd[3] = CMD_MULTI_WRITE;
-    cmd[4] = address >> 8;
-    cmd[5] = address & 0x00FF;
-
-    for(uint8_t count = 0; count < len; count++)
-    {
-        cmd[6 + count] = *(data + count);
-    }
-
-    WriteCmdToLcm(cmd, cmd[2] + 3);
-    usleep(10000);
-    ReadMsgFromLcm(msg, ARRAY_SIZE(msg));
-}
 
-void ChangeDisplay2Value(short address, short value)
-{
-    uint8_t data[2];
-    data[0] = value >> 8;
-    data[1] = value & 0x00FF;
-    //log_info("Addr:0x%x, value:%d",address,value);
-    DisplayValueToLcm(address, data, sizeof(data));
-}
 
 //================================================
 // Warning process
@@ -801,7 +806,8 @@ void ChangeCurPage()
             break;
         }
         _currentPage = pSysInfo->PageIndex;
-        //log_info("Chagne Page:%d",pSysInfo->PageIndex);
+        if (pSysInfo->PageIndex != _PAGE_IDLE)
+            log_info("Gun[%d] Chagne LCM Page:%d",pSysInfo->CurGunSelected, pSysInfo->PageIndex);
         ChangeToOtherPage(pSysInfo->PageIndex);
     }
 }
@@ -932,7 +938,10 @@ void ChangeRemainTime(int sec)
 void ShowSelectGun()
 {
 	pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(LEFT_GUN_NUM);
-	if (pDcChargingInfo->SystemStatus == S_CHARGING) {
+    if ((pDcChargingInfo->SystemStatus >= S_AUTHORIZING &&
+        pDcChargingInfo->SystemStatus <= S_CHARGING) ||
+        pDcChargingInfo->SystemStatus == S_CCS_PRECHARGE_ST0 ||
+        pDcChargingInfo->SystemStatus == S_CCS_PRECHARGE_ST1) {
 		if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
 				pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
 			ChangeDisplay2Value(_Icon_Select_Left,_TCC_ShowLeftGunCharging_CCS1);
@@ -958,7 +967,10 @@ void ShowSelectGun()
 		}
 	}
 	pDcChargingInfo = (struct ChargingInfoData *)GetDcChargingInfoData(RIGHT_GUN_NUM);
-	if (pDcChargingInfo->SystemStatus == S_CHARGING) {
+    if ((pDcChargingInfo->SystemStatus >= S_AUTHORIZING &&
+        pDcChargingInfo->SystemStatus <= S_CHARGING) ||
+        pDcChargingInfo->SystemStatus == S_CCS_PRECHARGE_ST0 ||
+        pDcChargingInfo->SystemStatus == S_CCS_PRECHARGE_ST1) {
 		if (pDcChargingInfo->CCSGunType == _TYPE_CCS1_Liquid ||
 				pDcChargingInfo->CCSGunType == _TYPE_CCS1_Natural) {
 			ChangeDisplay2Value(_Icon_Select_Right,_TCC_ShowRightGunCharging_CCS1);
@@ -1032,8 +1044,7 @@ void ChangeCarBonValue(float data)
     memset(cmd, 0x00, sizeof(cmd));
     _carbon = data * 0.577;
     //log_info("Carbon:%d",(int)_carbon);
-    if (data > 0 && _carbon < 1)
-        _carbon = 1;
+
 	sprintf((char *) value, "%d", (int)_carbon);
     string2ByteArray(value, cmd);
     DisplayValueToLcm(_String_Carbon, cmd, sizeof(cmd));
@@ -1272,7 +1283,7 @@ void ProcessPageInfo()
                 StopSystemTimeoutDet();
             	break;
             case _PAGE_SELECT_PAY:
-            	if (ShmDcCommonData->donate_flag[i] == TRUE) {
+            	if (ShmDcCommonData->TransactionInfo[i].IsDonateInvoice == TRUE) {
             		ChangeDisplay2Value(_Icon_WordAddFriend,_ICON_Empty);
             	} else
             		ChangeDisplay2Value(_Icon_WordAddFriend,_TCC_SelectPayMode);
@@ -1374,11 +1385,8 @@ void ProcessPageInfo()
                 } else {
                     ChangeChargingEnergyValue(0);
                 }
-                if ( ShmDcCommonData->finalcost[i] > 0 && ShmDcCommonData->finalcost_flag[i] == TRUE) {
-                	StopGunInfoTimeoutDet(i);
-					ChangeChargingFeeValue(ShmDcCommonData->finalcost[i]);
-					//ShmDcCommonData->finalcost_flag[i] = FALSE;
-                }
+
+				ChangeChargingFeeValue(ShmDcCommonData->TransactionInfo[i].Amount);
                 ChangeCarBonValue(pDcChargingInfo->PresentChargedEnergy);
                 ChangeBattMapAndValue(pDcChargingInfo->EvBatterySoc);
                 //StartSystemTimeoutDet(Timeout_ReturnViewPage);
@@ -1399,8 +1407,11 @@ void ProcessPageInfo()
                 }*/
             	break;
             case _PAGE_PAYING:
-
+                ChangeDisplay2Value(_Icon_Ani_Dot, 1);
             	break;
+            case _PAGE_EXIT:
+                
+                break;
                 /*
             case _PAGE_MAINTAIN:
                 ChangeQrCode_Error();

+ 8 - 2
EVSE/Projects/DD360Tcci/Apps/ReadCmdline.c

@@ -739,7 +739,7 @@ void RunUnconditionalChargeIndex1(char *v1, char *v2, char *v3)
     //kill ev task
     system("killall Module_EvComm");
 
-    printf("Warming!!!!\n Please pay attention chiller on or off !!!!\n");
+    printf("Warming!!!!\nPlease pay attention chiller on or off !!!!\n");
     
 
     pSysInfo->CurGunSelected = _GunIndex;
@@ -1065,7 +1065,7 @@ void RunUnconditionalChargeIndex1(char *v1, char *v2, char *v3)
         }
 
         usleep(100000);
-    }
+    }// while
 }
 
 int printTimeMsg(const char *fmt, ...)
@@ -1269,6 +1269,8 @@ int main(void)
                      "       chiller                           : set chiller on/off\n"
                      "       settlement                        : Credit Card UnionSettlement\n"
                      "       rededuct                          : Credit Card rededuct\n"
+                     "       preauth                           : Credit Card PreAuth\n"
+                     "       preauthcancel                     : Credit Card PreAuth Cancel\n"
                      "\r\n";
 
     if (CreateAllCsuShareMemory() == FAIL) {
@@ -1451,6 +1453,10 @@ int main(void)
             ShmDcCommonData->UnionSettlement = 1;
         } else if(strcmp(newString[0], "rededuct") == 0) {
             ShmDcCommonData->Exe_ReDeduct = 1;
+        } else if (strcmp(newString[0], "preauth") == 0) {
+            ShmDcCommonData->PreAuth_Config = _CREDITCARD_PREAUTH;
+        } else if (strcmp(newString[0], "preauthcancel") == 0) {
+            ShmDcCommonData->PreAuth_Config = _CREDITCARD_CANCEL;
         } else if (strcmp(newString[0], "chiller") == 0) { //測試槍頭和水冷機溫度
             writeChillerStatus(newString[1]);
         } else {

+ 1 - 0
EVSE/Projects/DD360Tcci/Apps/timeout.h

@@ -60,6 +60,7 @@ enum Timeout_flag {
 	Timeout_SelectPayMode		   = 23,
 	Timeout_FinalCost			   = 24,
 	Timeout_ScanCard			   = 25,
+    Timeout_ExitPage               = 26,
     Timeout_TradeCancel            = 28,
 };
 

BIN
EVSE/Projects/DD360Tcci/Images/ramdisk.gz


BIN
EVSE/Projects/DD360Tcci/output/FactoryConfig


BIN
EVSE/Projects/DD360Tcci/output/Module_ChkSysTask


BIN
EVSE/Projects/DD360Tcci/output/Module_DoComm


BIN
EVSE/Projects/DD360Tcci/output/Module_EvComm


BIN
EVSE/Projects/DD360Tcci/output/Module_EventLogging


BIN
EVSE/Projects/DD360Tcci/output/Module_InternalComm


BIN
EVSE/Projects/DD360Tcci/output/Module_LcmControl


BIN
EVSE/Projects/DD360Tcci/output/Module_PrimaryComm


BIN
EVSE/Projects/DD360Tcci/output/Module_UpdateFW


BIN
EVSE/Projects/DD360Tcci/output/ReadCmdline


BIN
EVSE/Projects/DD360Tcci/output/main


+ 15 - 0
build_rootfs_copy.sh

@@ -0,0 +1,15 @@
+#!/bin/bash
+sudo rm /dev/ram*
+sleep 3
+rm /mnt/e/Temp/IMAGE/*
+#sudo make DD360Audi-rootfs
+#cp /opt/ti-processor-sdk-linux-am335x-evm-04.02.00.09/EVSE/Projects/DD360Audi/Images/* /mnt/e/Image/DD360Audi/
+#sudo make DD360-rootfs
+#cp /opt/ti-processor-sdk-linux-am335x-evm-04.02.00.09/EVSE/Projects/DD360/Images/* /mnt/e/Image/DD360/
+#sudo make DD360ComBox-rootfs
+#cp /opt/ti-processor-sdk-linux-am335x-evm-04.02.00.09/EVSE/Projects/DD360ComBox/Images/* /mnt/e/Image/DD360ComBox/
+#sudo make DD360UCar-rootfs
+#cp /opt/ti-processor-sdk-linux-am335x-evm-04.02.00.09/EVSE/Projects/DD360UCar/Images/* /mnt/d/Image/DD360UCar/
+sudo make DD360Tcci-rootfs
+cp /opt/ti-processor-sdk-linux-am335x-evm-04.02.00.09/EVSE/Projects/DD360Tcci/Images/* /mnt/d/Image/DD360Tcc/
+