spc-kiosk-pb/Window/WinBasic/frmICReaderUpdate.cs

357 lines
15 KiB
C#
Raw Normal View History

2019-06-16 05:12:09 +00:00
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.IO;
using System.Runtime.InteropServices;
using Cosmos.UserFrame;
using Cosmos.BaseFrame;
using Cosmos.Common;
using Cosmos.CommonManager;
using Cosmos.ServiceProvider;
namespace Cosmos.Win
{
public partial class frmICReaderUpdate : Form
{
#region
private IICReaderUs m_cDeviceICReader = null; // IC 리더기
private IICReaderUpdate m_ICReaderUpdate = null; // IC 리더기 업데이트
private StateServer StateObject = (StateServer)StateServer.GetInstance(); //StateObject : StateServer Object(객체)
private SManager sManager = new SManager(); // 이 객체를 통해 업무 Service 호출
private PosStatus m_cPosStatus = new PosStatus(); // 기본정보 참조
private PosOLEDevice.CallbackRegFunc delegateCallback;
/// <summary>
/// Device 상태 정보 객체
/// </summary>
public DeviceStatus m_cDevStatus = null;
private int nUpdateCnt = 0;
private string sWorkBizMsg = "";
private string sSetFirmUpdateFile = string.Empty; // 펌웨어 업데이트 파일
private string ICREADER_FIRMWARE_GROUP = PosConst.PGM_UPDATE_TYPE.POSDOWN_GROUP_70;
private string ICREADER_FIRMWARE_PATH = BaseCom.NxDownPath + @"ICREADER\";
private DataTable m_DataTable = new DataTable();
/// <summary>
/// 처리대상 정보
/// </summary>
public DataTable SetDataTable { set { this.m_DataTable = value; } get { return m_DataTable; } }
#endregion
#region &
public frmICReaderUpdate()
{
InitializeComponent();
base.SetStyle(ControlStyles.OptimizedDoubleBuffer | ControlStyles.AllPaintingInWmPaint | ControlStyles.ResizeRedraw, true);
//this.UpdateStyles();
m_cPosStatus = (PosStatus)StateObject.POS; // POS 기본정보
m_cDeviceICReader = (IICReaderUs)sManager.InitServiceInstance(ServiceLists.AGENT_OLEDEVICE.DLL, ServiceLists.AGENT_OLEDEVICE.DEVICE_ICREADER);
m_ICReaderUpdate = (IICReaderUpdate)sManager.InitServiceInstance(ServiceLists.BSV_BASIC.DLL, ServiceLists.BSV_BASIC.ICREADER_UPDATE);
m_cDevStatus = (DeviceStatus)StateObject.DEVICE;
delegateCallback = new PosOLEDevice.CallbackRegFunc(SetProgreeBar);
}
private void frmICReaderUpdate_Load(object sender, EventArgs e)
{
UserLog.WriteLogFile(UserCom.LOG_IOS, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", "");
InitControl();
}
private void frmICReaderUpdate_FormClosing(object sender, FormClosingEventArgs e)
{
UserLog.WriteLogFile(UserCom.LOG_IOS, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", lblTitle.Text);
}
#endregion &
#region
/// <summary>
/// 폼 컨트롤 초기화
/// </summary>
private void InitControl()
{
try
{
#region
nUpdateCnt = 0;
sWorkBizMsg = "";
lblCount.Text = "";
pbWork.Minimum = 0;
pbWork.Maximum = 100;
pbWork.Visible = false;
btnConfirm.Tag = "0";
#endregion
FormManager.SetFormAllControlFont(this, m_cPosStatus.Base.FONT);
FormManager.SetTextBoxGlobalInfo(this, m_cPosStatus.Global.m_stCultureMaster.nGroupingDigits, m_cPosStatus.Global.m_stCultureMaster.strGroupingSymbol
, m_cPosStatus.Global.m_stCultureMaster.nDecimalDigits, m_cPosStatus.Global.m_stCultureMaster.strDecimalSymbol);
FormManager.MovePopUpForm(this, false, m_cPosStatus.Sale.ScreenSizeUser);
picBack.Image = ImageManager.GetImage(Cosmos.BaseFrame.BaseCom.NxImgPath, ImageManager.POP_SIZE_S);
lblMessage.Text = MessageManager.GetErrorMessage(POS_MESSAGE.ERROR.MSG_0702);
btnYes.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0025);
btnNo.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0026);
btnConfirm.Text = MessageManager.GetLabelMessage(POS_MESSAGE.LABEL.MSG_0009);
btnYes.Visible = true;
btnNo.Visible = true;
btnConfirm.Visible = false;
this.TopMost = true;
nUpdateCnt = m_ICReaderUpdate.ICReaderUpdateCnt(ICREADER_FIRMWARE_PATH, ref sSetFirmUpdateFile);
if (nUpdateCnt == 0)
{
WinManager.ErrorMessage(MessageManager.GetErrorMessage(POS_MESSAGE.ERROR.MSG_0703));
this.Close();
return;
}
}
catch (Exception ex)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", "Process Exception !!! " + ex.Message);
}
}
#endregion
#region Control Event
private void btnYes_Click(object sender, EventArgs e)
{
int iRet = -99;
string sFilePath = ICREADER_FIRMWARE_PATH + sSetFirmUpdateFile;
string sErrorMsg = string.Empty;
try
{
pbWork.Visible = true;
btnYes.Visible = false;
btnNo.Visible = false;
// 펌웨어
if (File.Exists(sFilePath) == true)
{
lblMessage.Text = MessageManager.GetErrorMessage(POS_MESSAGE.ERROR.MSG_0672);
sWorkBizMsg = MessageManager.GetErrorMessage(POS_MESSAGE.ERROR.MSG_0672) + "...{0} %";
this.Update();
string sPort = m_cPosStatus.Base.OlePosICReaderSerialPortNumber.Replace("COM", "");
GCHandle gch = GCHandle.Alloc(delegateCallback);
IntPtr intptr_delegate = Marshal.GetFunctionPointerForDelegate(delegateCallback);
iRet = m_cDeviceICReader.SetDE_FWDOWN(Convert.ToInt16(sPort), Convert.ToInt32(m_cPosStatus.Base.OlePosICReaderSerialBaudRate), Encoding.UTF8.GetBytes(sFilePath), intptr_delegate);
gch.Free();
if (iRet == 0)
{
// 성공
UpdateResult(iRet, true);
// 1초 후 자동 닫히기
System.Threading.Thread.Sleep(1000);
btnConfirm_Click(btnYes, null);
}
else
{
// 실패
UpdateResult(iRet, false);
}
}
else
{
UpdateResult(-6, false); // -6 : 전송 할 파일 없음
}
}
catch (Exception ex)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
ex.Message);
this.Close();
}
}
private void btnNo_Click(object sender, EventArgs e)
{
UserLog.WriteLogFile(UserCom.LOG_IOS, System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name
, System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()"
, "ICREADER FW => 업데이트 취소");
// 처리 상태 저장
SetDataState(ICREADER_FIRMWARE_GROUP, false);
// 펌웨어 파일 삭제
DeleteFile();
btnConfirm_Click(btnNo, null);
}
private void btnConfirm_Click(object sender, EventArgs e)
{
if ((string)btnConfirm.Tag != "1")
{
this.DialogResult = DialogResult.Cancel;
}
else
{
this.DialogResult = DialogResult.OK;
}
this.Close();
}
#endregion Control Event
#region User Method
/// <summary>
/// 상태 진행바
/// </summary>
/// <param name="iValue"></param>
/// <param name="iMaxValue"></param>
private void SetProgreeBar(int iValue, int iMaxValue)
{
try
{
double nPercent = CmUtil.DoubleMultiplication(CmUtil.DoubleDivision(iValue, iMaxValue), 100);
pbWork.Visible = true;
pbWork.Minimum = 0;
pbWork.Maximum = 100;
pbWork.Value = (int)Math.Round(nPercent, 0, MidpointRounding.AwayFromZero);
pbWork.Update();
lblCount.Visible = true;
lblCount.Text = string.Format(sWorkBizMsg, Math.Round(nPercent, 0, MidpointRounding.AwayFromZero).ToString());
lblCount.Update();
if (iValue == iMaxValue)
{
System.Threading.Thread.Sleep(300);
}
Application.DoEvents();
}
catch (Exception ex)
{
WinManager.ExceptionMessage(System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name,
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + System.Reflection.MethodBase.GetCurrentMethod().Name + "()", ex.Message);
}
}
private void UpdateResult(int iRet, bool bRetFlag)
{
string sErrorMsg = string.Empty;
try
{
// 메세지 표시 및 컨트롤 visible 처리
if (bRetFlag)
{
lblMessage.Text = MessageManager.GetErrorMessage(POS_MESSAGE.ERROR.MSG_0704);
btnConfirm.Tag = "1";
}
else
{
sErrorMsg = m_ICReaderUpdate.ICReaderResultCode(iRet);
lblMessage.Text = MessageManager.GetErrorMessage(sErrorMsg);
lblCount.Visible = false;
pbWork.Visible = false;
btnConfirm.Visible = true;
}
this.Update();
// 처리 상태 저장
SetDataState(ICREADER_FIRMWARE_GROUP, bRetFlag);
DeleteFile();
}
catch (Exception ex)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
ex.Message);
}
}
private void DeleteFile()
{
try
{
//DirectoryInfo dir = new DirectoryInfo(ICREADER_FIRMWARE_PATH);
//dir.Delete(true);
CmUtil.DeleteDirectoryInFile(ICREADER_FIRMWARE_PATH, 2);
return;
}
catch (Exception ex)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
ex.Message);
}
}
#endregion User Method
#region
private void SetDataState(string sGroup, bool bState)
{
try
{
foreach (DataRow dr in m_DataTable.Rows)
{
string sGroupCheck = CmUtil.MidH(dr["KIND"].ToString(), 0, 2).Trim();
if (sGroupCheck == sGroup)
{
dr["APP_TYPE"] = (bState == true) ? ItemConst.PGM_DOWN_STATE.Update_OK : ItemConst.PGM_DOWN_STATE.Update_Fail;
break;
}
}
}
catch (Exception ex)
{
UserLog.WriteLogFile(UserCom.LOG_ERROR,
System.Reflection.Assembly.GetExecutingAssembly().ManifestModule.Name, // Project Name (프로젝트명)
System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Name + "." + // Class Name (Class Name (클래스명))
System.Reflection.MethodBase.GetCurrentMethod().Name + "()", // Function Name (Function Name (함수명))
ex.Message);
}
}
#endregion
}
}