первый
This commit is contained in:
419
devices/Validators/Validator.cpp
Normal file
419
devices/Validators/Validator.cpp
Normal file
@ -0,0 +1,419 @@
|
||||
//---------------------------------------------------------------------------
|
||||
#include "stdafx.h"
|
||||
//------------------------------------------------------------------------------
|
||||
#pragma hdrstop
|
||||
|
||||
#include <string>
|
||||
#include <windows.h>
|
||||
|
||||
//#include <IniFiles.hpp>
|
||||
#include "Validator.h"
|
||||
#include "inifile.h"
|
||||
#include "stdTools.h"
|
||||
//#include "ud_Module.h"
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
//Validator* validator=NULL;
|
||||
//---------------------------------------------------------------------------
|
||||
//---------------------------------------------------------------------------
|
||||
unsigned char ConReset[6] = { 0x02,0x03,0x06,0x30,0x41,0xB3 }; //RESET <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
|
||||
unsigned char ConReACK[6] = { 0x02,0x03,0x06,0x00,0xC2,0x82 }; //<2F><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>...
|
||||
unsigned char ConStPoll[6] = { 0x02,0x03,0x06,0x33,0xDA,0x81 }; //POLL 33H Request for Bill-to-Bill unit activity Status (<28><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>)
|
||||
unsigned char ConIdent[6] = { 0x02,0x03,0x06,0x37,0xFE,0xC7 }; //IDENTIFICATION 37H Request for Model, Serial Number, Country ISO code, Asset Number
|
||||
|
||||
//#pragma package(smart_init)
|
||||
//---------------------------------------------------------------------------
|
||||
#define POLYNOMIAL 0x08408
|
||||
unsigned int GetCRC16(unsigned char* bufData, unsigned int sizeData)
|
||||
{
|
||||
unsigned int CRC, i;
|
||||
unsigned char j;
|
||||
CRC = 0;
|
||||
for(i=0; i < sizeData; i++)
|
||||
{
|
||||
CRC ^= bufData[i];
|
||||
for(j=0; j < 8; j++)
|
||||
{
|
||||
if(CRC & 0x0001) {CRC >>= 1; CRC ^= POLYNOMIAL;}
|
||||
else CRC >>= 1;
|
||||
}
|
||||
}
|
||||
return CRC;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
/*unsigned int GetCRC16(char* bufData, unsigned int sizeData)
|
||||
{ return GetCRC16((unsigned char*)bufData, sizeData);
|
||||
}*/
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD>
|
||||
int addZero(int val,int cnt)
|
||||
{
|
||||
for(int i=0;i<cnt;i++)
|
||||
val=val*10;
|
||||
return val;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
Validator::Validator()
|
||||
{
|
||||
//Pay=0;
|
||||
cPort=new ComPort();
|
||||
bNominals=false; //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> 1 <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>
|
||||
|
||||
pthread_mutex_init(&m_mutex, NULL);
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
Validator::~Validator()
|
||||
{
|
||||
stopPay();
|
||||
pthread_mutex_destroy(&m_mutex);
|
||||
delete cPort;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> ini <20><><EFBFBD><EFBFBD><EFBFBD>
|
||||
/*void Validator::LoadSetup()
|
||||
{
|
||||
TIniFile* ini = new TIniFile();
|
||||
ini->Load("settings.ini");
|
||||
cPort->ComNumber=ini->ReadString("Validator","Port","0");
|
||||
cPort->BaudRate=ini->ReadLong("Validator","BaudRate","0");
|
||||
m_testmode=ini->ReadBool("Validator","TestMode","0");
|
||||
delete ini;
|
||||
}*/
|
||||
//---------------------------------------------------------------------------
|
||||
bool Validator::OpenCOMPort(std::string ComNumber, int BaudRate)
|
||||
{
|
||||
cPort->ComNumber = ComNumber;
|
||||
cPort->BaudRate = BaudRate;
|
||||
|
||||
cPort->Close();
|
||||
|
||||
if (cPort->Open(cPort->ComNumber))
|
||||
{
|
||||
if (!cPort->Setup(2))
|
||||
return false;
|
||||
|
||||
if (!cPort->SetTimeout(500)) //50 <20><><EFBFBD> 5 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> 1/10 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
return false;
|
||||
}
|
||||
else return false;
|
||||
return true;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 2 <20><><EFBFBD><EFBFBD><EFBFBD> <20> CRC <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
bool Validator::CheckOnCRC(unsigned char* lpBuffer,unsigned long nSize)
|
||||
{
|
||||
if(nSize<2) return false;
|
||||
unsigned int CRC=GetCRC16(lpBuffer,nSize-2);
|
||||
unsigned int* pCRC=(unsigned int*)&lpBuffer[nSize-2];
|
||||
return (CRC==*pCRC);
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//req - <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> CRC
|
||||
//ans - <20><><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> CRC <20><><EFBFBD> <20><><EFBFBD>
|
||||
bool Validator::SendCommand(std::string req, std::string &ans)
|
||||
{
|
||||
unsigned short crc=GetCRC16((unsigned char*)req.c_str(),req.size());
|
||||
req+=((char*)(&crc))[0]; req+=((char*)(&crc))[1];
|
||||
unsigned int BytesWritten=cPort->Write(req.c_str(),req.size());
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
ans="";
|
||||
for(int i=0;i<255;i++)
|
||||
{
|
||||
Sleep(10);
|
||||
char ch;
|
||||
unsigned int BytesRead=cPort->Read(&ch,1);
|
||||
if (BytesRead>0) ans+=ch; else break;
|
||||
}
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> CRC
|
||||
if(ans.size()>=2)
|
||||
{
|
||||
crc=GetCRC16((unsigned char*)ans.c_str(),ans.size()-2);
|
||||
if(crc==((unsigned short*)(&ans.c_str()[ans.size()-2]))[0]) return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
bool Validator::Start()
|
||||
{
|
||||
bool result=true;
|
||||
|
||||
if(result) result=result && Reset(); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
if(result) result=result && getSerialNumber(); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
if(result) result=result && getNominals(); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>
|
||||
if(result) result=result && SetEnableBillTypes(true); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>
|
||||
|
||||
return result || m_testmode; //<2F> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> OK
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (RESET 30H Command for Bill-to-Bill unit to self-reset)
|
||||
bool Validator::Reset()
|
||||
{
|
||||
std::string req,ans;
|
||||
req+=(char)0x02; req+=(char)0x03; req+=(char)0x06; req+=(char)0x30;
|
||||
return SendCommand(req,ans);
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (GET STATUS 31H Request for Bill-to-Bill unit set-up status)
|
||||
bool Validator::GetStatus()
|
||||
{
|
||||
std::string req,ans;
|
||||
req+=(char)0x02; req+=(char)0x03; req+=(char)0x06; req+=(char)0x31; //req+=(char)0x41; req+=(char)0xB3;
|
||||
bool r=SendCommand(req,ans);
|
||||
if(r && ans.length()>6) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
{
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 3 <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 3 <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 3 <20><> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
}
|
||||
return r;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>
|
||||
//enable - true <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD>, false <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD>
|
||||
bool Validator::SetEnableBillTypes(bool enable)
|
||||
{
|
||||
std::string req,ans;
|
||||
if(enable)
|
||||
{ req+=(char)0x02; req+=(char)0x03; req+=(char)0x0C; req+=(char)0x34;
|
||||
req+=(char)0xFF; req+=(char)0xFF; req+=(char)0xFF; //24 <20><><EFBFBD><EFBFBD>
|
||||
req+=(char)0x00; req+=(char)0x00; req+=(char)0x00; //24 <20><><EFBFBD><EFBFBD>
|
||||
}else
|
||||
{ req+=(char)0x02; req+=(char)0x03; req+=(char)0x0C; req+=(char)0x34;
|
||||
req+=(char)0x00; req+=(char)0x00; req+=(char)0x00; //24 <20><><EFBFBD><EFBFBD>
|
||||
req+=(char)0x00; req+=(char)0x00; req+=(char)0x00; //24 <20><><EFBFBD><EFBFBD>
|
||||
}
|
||||
bool r=SendCommand(req,ans);
|
||||
return r;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
bool Validator::getSerialNumber()
|
||||
{
|
||||
unsigned int BytesWritten=cPort->Write(ConIdent,sizeof(ConIdent));
|
||||
unsigned int BytesRead=cPort->Read(ReadAr,sizeof(ReadAr));
|
||||
if(!CheckOnCRC(ReadAr,BytesRead)) return false;
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>
|
||||
if(BytesRead!=39)
|
||||
{
|
||||
Utility::logrotate("validator.log","<EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
||||
return false;
|
||||
}
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
std::string str1((char*)&ReadAr[3],15);
|
||||
BatchNumber= Utility::trim(str1);
|
||||
|
||||
std::string str2((char*)&ReadAr[18],12);
|
||||
SerialNumber= Utility::trim(str2);
|
||||
|
||||
Sleep(100);
|
||||
return true;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
bool Validator::getNominals()
|
||||
{
|
||||
unsigned char ConGetBT[6] = { 0x02,0x03,0x06,0x41,0x4F,0xD1 }; //GET BILL TABLE <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
ConGetBT[5] = GetCRC16(ConGetBT, 5); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> CRC
|
||||
|
||||
bNominals=false;
|
||||
Sleep(100); //<2F><> <20><><EFBFBD><EFBFBD>
|
||||
unsigned int BytesWritten=cPort->Write(ConGetBT,sizeof(ConGetBT));
|
||||
unsigned int BytesRead=cPort->Read(ReadAr,sizeof(ReadAr));
|
||||
if(!CheckOnCRC(ReadAr,BytesRead)) return bNominals;
|
||||
Sleep(100); //<2F><> <20><><EFBFBD><EFBFBD>
|
||||
for(unsigned char i=0;i<23;i++)
|
||||
{
|
||||
bt[i].val=addZero(ReadAr[3+i*5],ReadAr[3+i*5+4]);
|
||||
//<2F><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 3 <20><><EFBFBD><EFBFBD><EFBFBD>
|
||||
bt[i].country[0]=ReadAr[3+i*5+1];
|
||||
bt[i].country[1]=ReadAr[3+i*5+2];
|
||||
bt[i].country[2]=ReadAr[3+i*5+3];
|
||||
bt[i].val=addZero(ReadAr[3+i*5],ReadAr[3+i*5+4]);
|
||||
}
|
||||
bNominals=true;
|
||||
return bNominals;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
||||
//state - <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (<28><>. <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>)
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> 0 <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
int Validator::getTHPay(int &state)
|
||||
{
|
||||
state=0;
|
||||
int result = 0;
|
||||
if(!cPort->isOpen()){Sleep(1000); return result;}
|
||||
|
||||
unsigned char buffer[255];
|
||||
memset(buffer, 0, sizeof(buffer));
|
||||
|
||||
unsigned int BytesWritten=0;
|
||||
unsigned int BytesRead=0;
|
||||
|
||||
BytesWritten=cPort->Write(ConReACK, sizeof(ConReACK)); //<2F><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
Sleep(10);
|
||||
|
||||
BytesWritten=cPort->Write(ConStPoll, sizeof(ConStPoll)); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
BytesRead=cPort->Read(buffer,sizeof(buffer));
|
||||
if(CheckOnCRC(buffer,BytesRead))
|
||||
{
|
||||
switch (buffer[3])
|
||||
{
|
||||
case 0x13://19 <20><><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> RESET
|
||||
//Utility::logrotate("validator.log","(State)0x13 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
||||
break;
|
||||
case 0x14: //20 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (IDLING <20> The state in which Bill-to-Bill is ready accept bills)
|
||||
//Utility::logrotate("validator.log","(State)0x14 <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
||||
break;
|
||||
case 0x15: //21 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (<28> <20><><EFBFBD><EFBFBD> 3 <20><><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>)
|
||||
state = 0x15;
|
||||
//Utility::logrotate("validator.log","(State)21 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 1 <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
||||
break;
|
||||
case 0x17: //23 <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
state = 0x17;
|
||||
//Utility::logrotate("validator.log","(State)23 <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>!");
|
||||
break;
|
||||
case 0x19://25 DISABLED <20> The Bill-to-Bill unit has been disabled by the Controller and also the state in which Bill-to-Bill unit is after initialization.
|
||||
state = 0x19;
|
||||
//Utility::logrotate("validator.log","(State)25 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>!!!");
|
||||
SetEnableBillTypes(true);
|
||||
break;
|
||||
case 0x1c: //28 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
//Utility::logrotate("validator.log","(State)28 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
||||
break;
|
||||
case 0x41: //41H <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>...
|
||||
//Utility::logrotate("validator.log","(State)0x41 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>...");
|
||||
break;
|
||||
case 0x45: //69 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>".
|
||||
//Utility::logrotate("validator.log","(State)69 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
||||
break;
|
||||
case 0x81: //129 <20> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
state = 0x81;
|
||||
//Utility::logrotate("validator.log","(State)129 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
||||
if (buffer[4]<23)
|
||||
{
|
||||
result = bt[buffer[4]].val; //<2F> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> buffer[5]
|
||||
Utility::logrotate("validator.log", "(Pay)" + Utility::IntToStdStr(result));
|
||||
}
|
||||
break;
|
||||
default:
|
||||
Utility::logrotate("validator.log", "(State???)" + Utility::IntToStdStr(buffer[3]));
|
||||
}
|
||||
|
||||
Utility::logrotate("validator.log", "buffer[3] = " + Utility::IntToStdStr(buffer[3]));
|
||||
Utility::logrotate("validator.log", "state = " + Utility::IntToStdStr(state));
|
||||
|
||||
}
|
||||
Sleep(100);
|
||||
|
||||
return result;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
void Validator::endPay()
|
||||
{
|
||||
SetEnableBillTypes(false);
|
||||
|
||||
unsigned int BytesWritten,BytesRead;
|
||||
BytesWritten=cPort->Write(ConReACK , sizeof(ConReACK));
|
||||
|
||||
BytesWritten=cPort->Write(ConStPoll , sizeof(ConStPoll));
|
||||
BytesRead=cPort->Read(ReadAr,sizeof(ReadAr));
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
int Validator::GetState() //<2F><><EFBFBD><EFBFBD> 0 <20><> <20><><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
{
|
||||
if(m_testmode) return 0;
|
||||
//if(! bNominals) getNominals(); //todo <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
if(! bNominals) return 1;
|
||||
return 0;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
std::string Validator::GetStatusDescription(char StatusCode) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
{
|
||||
if (StatusCode == 0x00)
|
||||
return "OK";
|
||||
else
|
||||
if (StatusCode == 1)
|
||||
return "<EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>";
|
||||
else
|
||||
return "Error";
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
bool Validator::startPay() //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>
|
||||
{
|
||||
if (!execute_thread) //<2F><><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
{
|
||||
int ret = pthread_create(&m_threadid, NULL, Validator::thread_func, (void*)this);
|
||||
if (ret == 0)
|
||||
execute_thread = true;
|
||||
}
|
||||
return execute_thread;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
bool Validator::stopPay() //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
{
|
||||
if (execute_thread)
|
||||
{
|
||||
execute_thread = false;
|
||||
void* ret = NULL;
|
||||
pthread_join(m_threadid, &ret);
|
||||
}
|
||||
return !execute_thread;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
void* Validator::thread_func(void *pData)
|
||||
{
|
||||
Validator* validator=(Validator*) pData;
|
||||
while (validator->execute_thread)
|
||||
{
|
||||
int pay,state;
|
||||
pay = validator->getTHPay(state);
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
if (pthread_mutex_lock(&validator->m_mutex) == 0)
|
||||
{
|
||||
validator->m_payState = state;
|
||||
pthread_mutex_unlock(&validator->m_mutex);
|
||||
}
|
||||
if (pay > 0) //<2F><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
{
|
||||
if (pthread_mutex_lock(&validator->m_mutex) == 0) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
{
|
||||
validator->m_pays.add(pay);
|
||||
pthread_mutex_unlock(&validator->m_mutex);
|
||||
}
|
||||
}
|
||||
}
|
||||
validator->endPay();
|
||||
return NULL;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>, <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
//<2F><><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
|
||||
int Validator::getPay()
|
||||
{
|
||||
int pay = 0;
|
||||
if (pthread_mutex_lock(&m_mutex) == 0) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
{
|
||||
if (m_pays.count() > 0)
|
||||
{
|
||||
pay = m_pays.get(0);
|
||||
m_pays.del((unsigned int)0);
|
||||
}
|
||||
pthread_mutex_unlock(&m_mutex);
|
||||
}
|
||||
return pay;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
int Validator::getPayState()
|
||||
{
|
||||
int result = 0;
|
||||
if (pthread_mutex_lock(&m_mutex) == 0) //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
{
|
||||
result = m_payState;
|
||||
pthread_mutex_unlock(&m_mutex);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
//---------------------------------------------------------------------------
|
||||
Reference in New Issue
Block a user