Files
DDUtility/DDUtilityApp/LOGPARSER/FrmEqSelector.cs
jungwoois f0114e7b3f Ver 2025.05.01.0
B2 Database 변경
2025-05-01 11:59:58 +09:00

1399 lines
63 KiB
C#

using DDUtilityApp.DATA;
using DDUtilityApp.LOGPARSER.DATA;
using DDUtilityApp.SECS;
using FluentFTP;
using FluentFTP.Helpers;
using JWH;
using JWH.CONTROL;
using JWH.DATA;
using JWH.NETWORK;
using Org.BouncyCastle.Tls.Crypto;
using Renci.SshNet;
using Renci.SshNet.Sftp;
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Diagnostics;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Net.NetworkInformation;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Windows.Forms.DataVisualization.Charting;
using Telerik.WinControls.UI;
using static Telerik.WinControls.UI.ValueMapper;
namespace DDUtilityApp.LOGPARSER
{
public partial class FrmEqSelector : Form
{
#region [ Properties ] ------------------------------------------------
public enum eServerType { EIS, AGV }
public eServerType ServerType { get; set; } = eServerType.EIS;
/// <summary>
/// 로그서버 접속정보
/// </summary>
public Account Account { get; set; } = null;
/// <summary>
/// 선택된 로그파일
/// </summary>
public LogFile[] SelectedLogFiles { get; set; } = null;
private LogServer LogServer { get; set; } = null;
public EisEquipment Equipment { get; set; } = null;
public string ServerName { get; set; } = string.Empty;
public SECSDefine SECSDefine { get; set; } = null;
private int InitializeStatus { get; set; } = 0;
#endregion
#region [ FrmEqSelector ] ---------------------------------------------
public FrmEqSelector()
{
InitializeComponent();
this.SetLayout();
this.SetEventHandler();
}
public FrmEqSelector(eServerType server) : this()
{
this.ServerType = server;
}
private void SetLayout()
{
Font font = new Font("돋움체", 9);
this.tboxName.ImeMode = ImeMode.Hangul;
this.tboxEquipmentID.ImeMode = ImeMode.Alpha;
this.chkAllEquipment.Checked = GlobalVariable.Instance.FrmEqSelector_AllEquipment;
this.chkUseSMB.Checked = true; // = GlobalVariable.Instance.FrmEqSelector_UseSMB
this.chkUseSMB.Visible = false;
this.tabControl1.SelectedIndex = 0;
this.tboxModelDescription.Font = font;
}
protected void SetEventHandler()
{
this.Shown += this.FrmEqSelector_Shown;
this.FormClosing += FrmEqSelector_FormClosing;
this.FormClosed += this.FrmEqSelector_FormClosed;
this.Disposed += this.FrmEqSelector_Disposed;
this.cboxServer.SelectedValueChanged += CboxServer_SelectedValueChanged;
this.btnOK.Click += BtnOK_Click;
this.tboxName.KeyDown += TboxFilter_KeyDown;
this.tboxEquipmentID.KeyDown += TboxFilter_KeyDown;
this.chkAllEquipment.CheckStateChanged += ChkAllEquipment_CheckStateChanged;
this.flowLayoutPanel1.DoubleClick += this.FlowLayoutPanel1_DoubleClick;
this.gridEquipments.SelectionChanged += GridEquipments_SelectionChanged;
this.gridEquipments.CellDoubleClick += GridEquipments_CellDoubleClick;
this.gridEquipments.DataBindingComplete += GridEquipments_DataBindingComplete;
this.gridEquipments.KeyDown += GridEquipments_KeyDown;
this.gridLogFiles.CellDoubleClick += GridLogFiles_CellDoubleClick;
this.gridLogFiles.KeyDown += GridLogFiles_KeyDown;
this.gridWorkflow.CellDoubleClick += Grid_CellDoubleClick;
this.gridWorkflow.KeyDown += Grid_KeyDown;
this.gridHsms.CellDoubleClick += Grid_CellDoubleClick;
this.gridHsms.KeyDown += Grid_KeyDown;
}
private async void FrmEqSelector_Shown(object sender, EventArgs e)
{
await Task.Delay(200);
try
{
this.SuspendLayout();
this.GridEquipments_Setting();
this.GridLogFiles_Setting(this.gridLogFiles);
this.GridLogFiles_Setting(this.gridHsms);
this.GridLogFiles_Setting(this.gridWorkflow);
this.GridModelDetail_Setting();
this.InitializeStatus = 1;
this.SetLogServer();
if (this.Equipment != null) this.SetEquipment(this.Equipment);
else this.SetEquipment(this.ServerName, this.Equipment?.EquipmentID);
this.InitializeStatus = 0;
this.GridEquipments_SelectionChanged(this.gridEquipments, null);
this.SetSelectedLogFiles(this.SelectedLogFiles);
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex, true);
}
finally
{
this.InitializeStatus = 0;
this.ResumeLayout();
}
}
private void FrmEqSelector_Disposed(object sender, EventArgs e)
{
if (this.gridEquipments != null) this.gridEquipments.Dispose();
if (this.gridLogFiles != null) this.gridLogFiles.Dispose();
if (this.gridModelDetail != null) this.gridModelDetail.Dispose();
}
private void FlowLayoutPanel1_DoubleClick(object sender, EventArgs e)
{
this.ControlCapture();
}
protected override bool ProcessCmdKey(ref Message msg, Keys keyData)
{
try
{
switch (keyData)
{
case Keys.F1:
Process.Start("IEXPLORE.EXE", "http://pms.e1soft.co.kr:8090/Deploy/eqview/");
break;
case Keys.F6:
this.gridEquipments.BestFitColumns(BestFitColumnMode.DisplayedCells);
this.gridLogFiles.BestFitColumns(BestFitColumnMode.DisplayedCells);
this.gridModelDetail.BestFitColumns(BestFitColumnMode.DisplayedCells);
break;
}
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex);
}
return base.ProcessCmdKey(ref msg, keyData);
}
private void FrmEqSelector_FormClosing(object sender, FormClosingEventArgs e)
{
}
private void FrmEqSelector_FormClosed(object sender, FormClosedEventArgs e)
{
StringBuilder sb = new StringBuilder();
foreach (GridViewColumn column in this.gridEquipments.Columns.OrderBy(x => x.Index))
if (column.IsVisible) sb.AppendFormat($"{column.Name};");
GlobalVariable.Instance.FrmEqSelector_GridEquipmentHeader = sb.ToString();
GlobalVariable.Instance.FrmEqSelector_UseSMB = this.chkUseSMB.Checked;
GlobalVariable.Instance.SaveSetting();
if (this.DialogResult == DialogResult.OK)
this.GetGEMSetting();
}
#endregion
#region [ Control Events ] --------------------------------------------
private void CboxServer_SelectedValueChanged(object sender, EventArgs e)
{
try
{
EisEquipment[] equipments = this.GetEquipments();
if (this.chkAllEquipment.Checked == false)
equipments = equipments.Where(x => x.MesRegistration).ToArray();
this.gridEquipments.AutoBinding(equipments);
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex, true);
}
finally
{
this.Cursor = Cursors.Default;
}
}
/// <summary>
/// jhlim 20250202
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void tabControl1_SelectedIndexChanged(object sender, EventArgs e)
{
try
{
if (this.tabControl1.SelectedTab == this.tabHSMS)
{
if (this.gridHsms.DataSource != null) return;
string remotePath = $"/{this.Account.DefaultPath}/{this.Equipment.EquipmentID}/THiRA_SECSGEM/HSMS";
switch (this.Account.Access)
{
case AccessType.SMB:
break;
case AccessType.FTPS:
{
FtpsClient.Connect();
FtpListItem[] items = FtpsClient.GetFtpsList(remotePath);
this.gridHsms.AutoBinding(this.GetLogFiles(items));
FtpsClient.Disconnect();
}
break;
case AccessType.SFTP:
{
StpClientWrap.Connect();
ISftpFile[] items = (ISftpFile[])StpClientWrap.GetSftpList(remotePath);
this.gridHsms.AutoBinding(this.GetLogFiles(items));
StpClientWrap.Disconnect();
}
break;
case AccessType.FTP:
break;
}
}
else if (this.tabControl1.SelectedTab == this.tabWorkflow)
{
if (this.gridWorkflow.DataSource != null) return;
string remotePath = $"/{this.Account.DefaultPath}/{this.Equipment.EquipmentID}/Workflow";
switch (this.Account.Access)
{
case AccessType.SMB:
break;
case AccessType.FTPS:
{
FtpsClient.Connect();
FtpListItem[] items = FtpsClient.GetFtpsList(remotePath);
LogFile[] logFiles = this.GetLogFiles(items);
this.gridWorkflow.AutoBinding(logFiles);
FtpsClient.Disconnect();
}
break;
case AccessType.SFTP:
{
StpClientWrap.Connect();
ISftpFile[] items = (ISftpFile[])StpClientWrap.GetSftpList(remotePath);
this.gridWorkflow.AutoBinding(this.GetLogFiles(items));
StpClientWrap.Disconnect();
}
break;
case AccessType.FTP:
break;
}
}
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex, true);
}
}
/// <summary>
/// [CheckPoint] 로그파일 목록을 반환한다
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void BtnOK_Click(object sender, EventArgs e)
{
try
{
LogFile logFile = null;
List<LogFile> list = new List<LogFile>();
foreach (GridViewRowInfo row in this.gridLogFiles.SelectedRows)
{
logFile = row.DataBoundItem as LogFile;
if (logFile == null) continue;
list.Add(logFile);
}
SelectedLogFiles = list.ToArray();
this.DialogResult = DialogResult.OK;
this.Close();
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex, true);
}
}
private void TboxFilter_KeyDown(object sender, KeyEventArgs e)
{
switch (e.KeyCode)
{
case Keys.Enter:
this.gridEquipments.FilterDescriptors.Remove("DisplayName");
this.gridEquipments.FilterDescriptors.Remove("MesName");
this.gridEquipments.FilterDescriptors.Remove("EquipmentID");
if (string.IsNullOrWhiteSpace(this.tboxEquipmentID.Text) == false)
{
Telerik.WinControls.Data.FilterDescriptor filter = new Telerik.WinControls.Data.FilterDescriptor("EquipmentID", Telerik.WinControls.Data.FilterOperator.Contains, this.tboxEquipmentID.Text);
this.gridEquipments.FilterDescriptors.Add(filter);
}
if (string.IsNullOrWhiteSpace(this.tboxName.Text) == false)
{
string columnName = string.Empty; ;
if (string.IsNullOrEmpty(columnName)) columnName = this.gridEquipments.Columns["DisplayName"].IsVisible ? "DisplayName" : string.Empty;
if (string.IsNullOrEmpty(columnName)) columnName = this.gridEquipments.Columns["MesName"].IsVisible ? "MesName" : string.Empty;
if (string.IsNullOrEmpty(columnName)) columnName = "DisplayName";
Telerik.WinControls.Data.FilterDescriptor filter = new Telerik.WinControls.Data.FilterDescriptor(columnName, Telerik.WinControls.Data.FilterOperator.Contains, this.tboxName.Text);
this.gridEquipments.FilterDescriptors.Add(filter);
}
break;
case Keys.Escape:
if (sender == this.tboxEquipmentID) this.gridEquipments.FilterDescriptors.Remove("EquipmentID");
if (sender == this.tboxName) { this.gridEquipments.FilterDescriptors.Remove("DisplayName"); this.gridEquipments.FilterDescriptors.Remove("MesName"); }
break;
}
}
private void ChkAllEquipment_CheckStateChanged(object sender, EventArgs e)
{
this.CboxServer_SelectedValueChanged(this.cboxServer, null);
GlobalVariable.Instance.FrmEqSelector_AllEquipment = this.chkAllEquipment.Checked;
}
#endregion
#region [ GridEquipments ] --------------------------------------------
private void GridEquipments_Setting()
{
GridViewEx grid = this.gridEquipments;
grid.TableElement.RowHeight = 20;
grid.MultiSelect = false;
Dictionary<string, string> dicColumnText = new Dictionary<string, string>();
dicColumnText.Add("Facility", "");
dicColumnText.Add("Line", "");
dicColumnText.Add("EquipmentID", "");
dicColumnText.Add("DisplayName", "Name");
dicColumnText.Add("ProcessSegmentID", "공정ID");
dicColumnText.Add("ProcessSegmentName", "공정명");
dicColumnText.Add("MesName", "MES Name");
dicColumnText.Add("Description", "EIS Name");
dicColumnText.Add("ControlMode", "Control");
dicColumnText.Add("State", "");
dicColumnText.Add("LastTrackInLotID", "In LOT");
dicColumnText.Add("LastTrackOutLotID", "Out LOT");
dicColumnText.Add("ModelID", "");
dicColumnText.Add("Maker", "");
dicColumnText.Add("Version", "");
dicColumnText.Add("ModelVersion", "ModelVer");
dicColumnText.Add("EquipmentIP", "");
dicColumnText.Add("Port", "");
dicColumnText.Add("ServerIP", "");
dicColumnText.Add("OriginServerIP", "OriginIP");
dicColumnText.Add("GemSettingID", "GemID");
dicColumnText.Add("DriverFileName", "Driver File");
dicColumnText.Add("LogPath", "");
dicColumnText.Add("PMDate", "PM Date");
dicColumnText.Add("PlcType", "PLC Type");
#region [ ]
string columnNames = GlobalVariable.Instance.FrmEqSelector_GridEquipmentHeader;
string columnText = string.Empty;
if (string.IsNullOrEmpty(columnNames) == false)
{
foreach (string columnName in columnNames.Split(new string[] { ";" }, StringSplitOptions.RemoveEmptyEntries))
{
columnText = columnName;
if (dicColumnText.ContainsKey(columnName))
{
if (string.IsNullOrEmpty(dicColumnText[columnName]) == false) columnText = dicColumnText[columnName];
dicColumnText.Remove(columnName);
}
grid.AddColumn(columnName, columnText);
}
}
foreach (string columnName in dicColumnText.Keys)
{
columnText = columnName;
if (string.IsNullOrEmpty(dicColumnText[columnName]) == false) columnText = dicColumnText[columnName];
grid.AddColumn(columnName, columnText).IsVisible = false;
}
#endregion
grid.AddContextMenu("");
grid.AddContextMenu("Open Windows", this.GridEquipments_OpenWindows);
}
/// <summary>
/// [CheckPoint] 선택된 설비의 로그파일 목록을 표시한다.
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void GridEquipments_SelectionChanged(object sender, EventArgs e)
{
try
{
if (this.InitializeStatus > 0) return;
if (this.gridEquipments.SelectedRows.Count < 1) return;
this.gridLogFiles.DataSource = null;
this.gridModelDetail.DataSource = null;
this.gridWorkflow.DataSource = null;
this.gridHsms.DataSource = null;
EisEquipment equipment = this.gridEquipments.SelectedRows[0].DataBoundItem as EisEquipment;
if (equipment == null) return;
this.Cursor = Cursors.WaitCursor;
this.Equipment = equipment;
LogServer logServer = this.cboxServer.SelectedItem as LogServer;
string path = string.Empty;
#region [ Model Details ]
// 모델 버전 정보
EisModelDetails[] modelDetails = this.GetModelDetails(equipment);
this.gridModelDetail.AutoBinding(modelDetails);
this.gridModelDetail.SetRowForeColor("LockState", $"LockState = 'BLOCKED'", Color.LightGray);
foreach (GridViewRowInfo row in this.gridModelDetail.Rows)
{
EisModelDetails item = row.DataBoundItem as EisModelDetails;
if (item == null) continue;
if (item.Version == equipment.Version)
{
row.IsSelected = true;
row.IsCurrent = true;
break;
}
}
// 모델 정보
EisModelInfo[] modelInfo = this.GetModelInfo(equipment);
if (modelInfo?.Length > 0)
{
this.tboxModelDescription.Text = modelInfo[0].Description;
}
#endregion
#region [ LogFiles ]
if (logServer.NetworkAccount.ContainsKey(equipment.LogServerIP) == false) return;
{
this.Account = logServer.NetworkAccount[equipment.LogServerIP];
switch (this.Account.Access)
{
case AccessType.SMB:
{
// Checking Local IP-Address
bool isLocal = false;
foreach (NetworkInterface nic in NetworkInterface.GetAllNetworkInterfaces())
foreach (UnicastIPAddressInformation ip in nic.GetIPProperties().UnicastAddresses)
if (ip.Address.AddressFamily == System.Net.Sockets.AddressFamily.InterNetwork)
if (ip.Address.ToString() == this.Account.IPAddress) { isLocal = true; break; }
if (this.chkUseSMB.Checked)
{
if (isLocal) path = $@"{equipment.LogPath}\{equipment.EquipmentID}";
else return;
}
else
{
if (isLocal) path = $@"{equipment.LogPath}\{equipment.EquipmentID}";
else path = $@"\\{this.Account.IPAddress}\{this.Account.DefaultPath}{equipment.EquipmentID}\";
}
int result = ExtensionAPI.ConnectRemoteServer(this.Account.IPAddress, this.Account.UserID, this.Account.Password);
if (result != 0 && result != 1219) { MessageBox.Show($@"네트워크 접근에 실패하였습니다. (Code:{result})"); return; }
DirectoryInfo directory = new DirectoryInfo(path);
if (directory.Exists == false) { MessageBox.Show($@"폴더가 존재하지 않습니다" + Environment.NewLine + Environment.NewLine + $@"Path: {path}"); return; }
this.gridLogFiles.AutoBinding(this.GetLogFiles(directory.GetFiles()));
this.rstatus1.Text = $"Path={path}";
}
break;
case AccessType.FTPS:
{
FtpsClient.Initialize(this.Account.IPAddress, this.Account.UserID, this.Account.Password);
FtpsClient.Connect();
path = $"/{this.Account.DefaultPath}/{equipment.EquipmentID}";
FtpListItem[] ftpFiles = FtpsClient.GetFtpsList(path);
if (ftpFiles != null) this.gridLogFiles.AutoBinding(this.GetLogFiles(ftpFiles));
this.rstatus1.Text = $"Path={this.Account.IPAddress}{path}";
//if (FtpsClient.IsDirExists($"{path}/THiRA_SECSGEM/HSMS") && !this.tabControl1.TabPages.Contains(tabHSMS))
// this.tabControl1.TabPages.Add(this.tabHSMS);
FtpsClient.Disconnect();
}
break;
case AccessType.SFTP:
{
StpClientWrap.Initialize(this.Account.IPAddress, this.Account.UserID, this.Account.Password);
StpClientWrap.Connect();
path = $"/{this.Account.DefaultPath}/{equipment.EquipmentID}";
ISftpFile[] ftpFiles = (ISftpFile[])StpClientWrap.GetSftpList(path);
if (ftpFiles != null) this.gridLogFiles.AutoBinding(this.GetLogFiles(ftpFiles));
this.rstatus1.Text = $"Path={this.Account.IPAddress}{path}";
//if (StpClientWrap.IsDirExists($"{path}/THiRA_SECSGEM/HSMS") && !this.tabControl1.TabPages.Contains(tabHSMS))
// this.tabControl1.TabPages.Add(this.tabHSMS);
StpClientWrap.Disconnect();
}
break;
case AccessType.FTP:
{
}
break;
}
}
#endregion
#region [ Workflow & HSMS ]
this.tabControl1_SelectedIndexChanged(this.tabControl1, new EventArgs());
#endregion
}
catch (Exception ex)
{
if (this.LogServer.NetworkAccount.ContainsKey(this.Equipment.LogServerIP))
{
// 해당 접속정보를 삭제한다
this.LogServer.NetworkAccount.Remove(this.Equipment.LogServerIP);
ExpressionFormattingObject formatting = new ExpressionFormattingObject($"Marking", $"ServerIP = '{this.Equipment.LogServerIP}'", true);
formatting.RowBackColor = Color.FromArgb(88, 255, 0, 0);
this.gridEquipments.Columns["ServerIP"].ConditionalFormattingObjectList.Add(formatting);
}
XLogger.Instance.Fatal(ex, true);
}
finally
{
this.Cursor = Cursors.Default;
}
}
private void GridEquipments_CellDoubleClick(object sender, GridViewCellEventArgs e)
{
try
{
this.gridLogFiles.ClearSelection();
if (this.gridLogFiles.Rows.Count > 0) this.gridLogFiles.Rows[0].IsSelected = true;
this.GridLogFiles_CellDoubleClick(this.gridLogFiles, null);
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex);
}
}
private void GridEquipments_DataBindingComplete(object sender, GridViewBindingCompleteEventArgs e)
{
GridViewEx grid = this.gridEquipments;
if (grid.Columns.Contains("Version"))
{
bool isExist = false;
foreach (BaseFormattingObject item in grid.Columns["Version"].ConditionalFormattingObjectList)
if (item.Name == "VERSION_MissMatch") isExist = true;
if (isExist == false)
{
ExpressionFormattingObject formatting = new ExpressionFormattingObject($"VERSION_MissMatch", "Version<>ModelVersion", true);
formatting.CellBackColor = Color.FromArgb(128, 255, 0, 0);
grid.Columns["Version"].ConditionalFormattingObjectList.Add(formatting);
}
}
if (grid.Columns.Contains("PMDate"))
{
bool isExist = false;
foreach (BaseFormattingObject item in grid.Columns["PMDate"].ConditionalFormattingObjectList)
if (item.Name == "PMDate_MissMatch") isExist = true;
if (isExist == false)
{
StringBuilder sb = new StringBuilder();
sb.Append($"PMDate>=#{DateTime.Now.ToString("yyyy-MM-dd")}#");
sb.Append(" AND ");
sb.Append($"PMDate<#{DateTime.Now.AddDays(1).ToString("yyyy-MM-dd")}#");
ExpressionFormattingObject formatting = new ExpressionFormattingObject($"PMDate_MissMatch", sb.ToString(), true);
formatting.CellBackColor = Color.YellowGreen;
grid.Columns["PMDate"].ConditionalFormattingObjectList.Add(formatting);
}
}
}
private void GridEquipments_KeyDown(object sender, KeyEventArgs e)
{
if (e.KeyCode == Keys.Enter) this.BtnOK_Click(this.btnOK, null);
}
private void GridEquipments_OpenWindows(object sender, params object[] args)
{
try
{
if (this.gridEquipments.SelectedRows.Count < 1) return;
string serverID = this.cboxServer.Text;
string equipmentID = this.gridEquipments.SelectedRows[0].Cells["EquipmentID"].Value.ToString();
//this.gridLogFiles.SelectedRows;
ProcessStartInfo processStartInfo = new ProcessStartInfo();
processStartInfo.FileName = Application.ExecutablePath;
processStartInfo.WorkingDirectory = Environment.CurrentDirectory;
processStartInfo.Arguments = $"FrmLogParser {serverID} {equipmentID}";
Process process = Process.Start(processStartInfo);
//this.DialogResult = DialogResult.Cancel;
//this.Close();
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex);
}
}
#endregion
#region [ GridLogFiles ] ----------------------------------------------
private void GridLogFiles_Setting(GridViewEx grid)
{
//GridViewEx grid = this.gridLogFiles; jhlim 20250202
grid.TableElement.RowHeight = 20;
grid.MultiSelect = true;
grid.AddColumn("Name");
grid.AddColumn("Length");
grid.AddColumn("LastWriteTime");
//grid.AddContextMenu("");
//grid.AddContextMenu("Open Log", GridEquipments_OpenWindows);
}
private void GridLogFiles_CellDoubleClick(object sender, GridViewCellEventArgs e)
{
try
{
this.BtnOK_Click(this.btnOK, null);
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex, true);
}
}
private void GridLogFiles_KeyDown(object sender, KeyEventArgs e)
{
if (e.KeyCode == Keys.Enter) this.BtnOK_Click(this.btnOK, null);
}
#endregion
#region [ Grid Worflow & HSMS ] ----------------------------------------------
/// <summary>
/// Workflow, HSMS 파일목록 Grid
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Grid_KeyDown(object sender, KeyEventArgs e)
{
if (e.KeyCode == Keys.Enter)
{
Grid_CellDoubleClick((GridViewEx)sender, null);
}
}
/// <summary>
/// Workflow, HSMS 파일 Download
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void Grid_CellDoubleClick(object sender, GridViewCellEventArgs e)
{
try
{
string destPath = Path.Combine(GlobalVariable.Instance.DownloadPath, this.Equipment.EquipmentID);
RadGridView grid = sender as RadGridView;
if (grid == null && sender.GetType() == typeof(GridDataCellElement))
{
GridDataCellElement element = sender as GridDataCellElement;
grid = element.RowElement.GridControl;
}
if (grid == null) return;
if (grid == this.gridHsms) destPath = Path.Combine(destPath, "HSMS");
else if (grid == this.gridWorkflow) destPath = Path.Combine(destPath, "Workflow");
if (System.IO.Directory.Exists(destPath) == false) System.IO.Directory.CreateDirectory(destPath);
List<string> downfiles = new List<string>();
foreach (GridViewRowInfo row in grid.SelectedRows)
{
LogFile logFile = row.DataBoundItem as LogFile;
string destFileName = Path.Combine(destPath, logFile.FileName);
switch (this.Account.Access)
{
case AccessType.SMB:
{ }
break;
case AccessType.FTPS:
{
FtpsClient.DownloadFtpsFile(logFile.FullName, destFileName);
downfiles.Add(destFileName);
logFile.DestFullName = destFileName;
}
break;
case AccessType.SFTP:
{
StpClientWrap.DownloadSftpFile(logFile.FullName, destFileName);
downfiles.Add(destFileName);
logFile.DestFullName = destFileName;
}
break;
case AccessType.FTP:
{ }
break;
}
}
//MessageBox.Show($"{grid.SelectedRows.Count}개의 파일을 저장하였습니다.");
foreach (string file in downfiles)
System.Diagnostics.Process.Start(file);
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex, true);
}
}
private void GridLogFiles_OpenWindows(object sender, params object[] args)
{
try
{
if (this.gridEquipments.SelectedRows.Count < 1) return;
string serverID = this.cboxServer.Text;
string equipmentID = this.gridEquipments.SelectedRows[0].Cells["EquipmentID"].Value.ToString();
ProcessStartInfo processStartInfo = new ProcessStartInfo();
processStartInfo.FileName = Application.ExecutablePath;
processStartInfo.WorkingDirectory = Environment.CurrentDirectory;
processStartInfo.Arguments = $"FrmLogParser {serverID} {equipmentID}";
Process process = Process.Start(processStartInfo);
//this.DialogResult = DialogResult.Cancel;
//this.Close();
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex);
}
}
#endregion
#region [ GridModelDetail ] -------------------------------------------
private void GridModelDetail_Setting()
{
GridViewDataColumn item = null;
GridViewEx grid = this.gridModelDetail;
grid.MasterView.TableHeaderRow.MinHeight = 30;
grid.AutoSizeRows = true;
//grid.AllowDragToGroup = false;
grid.AllowAutoSizeColumns = false;
//grid.AutoSizeColumnsMode = GridViewAutoSizeColumnsMode.Fill;
grid.Columns.Clear();
grid.AddColumn("ModelID").IsVisible = false;
item = grid.AddColumn("Version");
item.MinWidth = 100; item.MaxWidth = 120;
item = grid.AddColumn("Description");
item.MinWidth = 100; //item.MaxWidth = 500;
item = grid.AddColumn("DateTime");
item.MinWidth = 100; item.MaxWidth = 130;
item = grid.AddColumn("Modifier");
item.MinWidth = 80; item.MaxWidth = 80;
//grid.AddColumn("LockState");
}
private EisModelDetails[] GetModelDetails(EisEquipment equipment)
{
try
{
LogServer logServer = this.cboxServer.SelectedItem as LogServer;
if (logServer == null) return null;
this.LogServer = logServer;
this.Cursor = Cursors.WaitCursor;
DataTable dtModelDetails = logServer.GetModelDetails(equipment.ModelID);
EisModelDetails[] modelDetails = dtModelDetails.ToClass<EisModelDetails>();
return modelDetails;
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex, true);
return null;
}
}
private EisModelInfo[] GetModelInfo(EisEquipment equipment)
{
try
{
LogServer logServer = this.cboxServer.SelectedItem as LogServer;
if (logServer == null) return null;
this.LogServer = logServer;
this.Cursor = Cursors.WaitCursor;
DataTable dtModelDetails = logServer.GetModelInfo(equipment.ModelID);
EisModelInfo[] modelDetails = dtModelDetails.ToClass<EisModelInfo>();
return modelDetails;
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex, true);
return null;
}
}
#endregion
#region [ Method ] ----------------------------------------------------
private void SetLogServer()
{
this.cboxServer.Items.Clear();
StringBuilder sbEquipments = new StringBuilder();
StringBuilder sbModelDetails = new StringBuilder();
StringBuilder sbModelInfo = new StringBuilder();
LogServer logServer = null;
switch (this.ServerType)
{
case eServerType.EIS:
sbEquipments.Clear();
sbEquipments.AppendLine($"SELECT EQ.Line, ");
sbEquipments.AppendLine($" EQ.ModelID, ");
sbEquipments.AppendLine($" (SELECT MAX(Version) FROM EquipmentModelDetails WHERE ModelID=EQ.ModelID AND LockState != 'BLOCKED') ModelVersion, ");
sbEquipments.AppendLine($" EQ.Version, ");
sbEquipments.AppendLine($" EQ.RunningVersion, ");
sbEquipments.AppendLine($" EQ.EquipmentID, ");
sbEquipments.AppendLine($" EQ.Description, ");
sbEquipments.AppendLine($" DP.GemSettingID, ");
sbEquipments.AppendLine($" DP.DriverFileName, ");
sbEquipments.AppendLine($" DP.EquipmentIP, ");
sbEquipments.AppendLine($" DP.Port, ");
sbEquipments.AppendLine($" EQ.ServerIP, ");
sbEquipments.AppendLine($" EQ.OriginServerIP, ");
sbEquipments.AppendLine($" DP.MESDaemon, ");
sbEquipments.AppendLine($" DP.MESService, ");
sbEquipments.AppendLine($" DP.MESSubject, ");
sbEquipments.AppendLine($" DP.PlcType, ");
sbEquipments.AppendLine($" EQ.LogPath ");
sbEquipments.AppendLine($"FROM Equipment EQ ");
sbEquipments.AppendLine($" LEFT JOIN ( ");
sbEquipments.AppendLine($" SELECT DP1.EquipmentID, ");
sbEquipments.AppendLine($" DP1.GemSettingID, ");
sbEquipments.AppendLine($" DP1.Value EquipmentIP, ");
sbEquipments.AppendLine($" DP2.Value DriverFileName, ");
sbEquipments.AppendLine($" DP3.Value Port, ");
sbEquipments.AppendLine($" DP4.Value MESDaemon, ");
sbEquipments.AppendLine($" DP5.Value MESService, ");
sbEquipments.AppendLine($" DP6.Value MESSubject, ");
sbEquipments.AppendLine($" DP7.Value PlcType ");
sbEquipments.AppendLine($" FROM DriverParameter DP1 ");
sbEquipments.AppendLine($" LEFT JOIN DriverParameter DP2 ON DP2.EquipmentID=DP1.EquipmentID AND DP2.DriverName=DP1.DriverName AND DP2.Name IN ('MessageFileName', 'PLC_MAPFILENAME') ");
sbEquipments.AppendLine($" LEFT JOIN DriverParameter DP3 ON DP3.EquipmentID=DP1.EquipmentID AND DP3.DriverName=DP1.DriverName AND DP3.Name IN ('PortNo', 'PLC_PORT') ");
sbEquipments.AppendLine($" LEFT JOIN DriverParameter DP4 ON DP4.EquipmentID=DP1.EquipmentID AND DP4.DriverName='MES' AND DP4.Name IN ('Daemon') ");
sbEquipments.AppendLine($" LEFT JOIN DriverParameter DP5 ON DP5.EquipmentID=DP1.EquipmentID AND DP5.DriverName='MES' AND DP5.Name IN ('Service') ");
sbEquipments.AppendLine($" LEFT JOIN DriverParameter DP6 ON DP6.EquipmentID=DP1.EquipmentID AND DP6.DriverName='MES' AND DP6.Name IN ('SendSubject') ");
sbEquipments.AppendLine($" LEFT JOIN DriverParameter DP7 ON DP7.EquipmentID=DP1.EquipmentID AND DP7.DriverName='EQP' AND DP7.Name IN ('PLC_TYPE') ");
sbEquipments.AppendLine($" WHERE DP1.Name IN ('RemoteAddress', 'PLC_IPADDRESS') ) DP ON DP.EquipmentID = EQ.EquipmentID ");
sbEquipments.AppendLine($"ORDER BY Line, ModelID, EquipmentID ");
sbModelDetails.Clear();
sbModelDetails.AppendLine($"SELECT * ");
sbModelDetails.AppendLine($"FROM EquipmentModelDetails ");
sbModelDetails.AppendLine($"WHERE ModelID=@MODEL_ID ");
sbModelDetails.AppendLine($"ORDER BY Version DESC ");
sbModelInfo.Clear();
sbModelInfo.AppendLine($"SELECT * ");
sbModelInfo.AppendLine($"FROM EquipmentModel ");
sbModelInfo.AppendLine($"WHERE ModelID=@MODEL_ID ");
#region [ EIS.B1 ]
logServer = new LogServer("EIS.B1");
logServer.DBConnectionString = $@"server=192.168.7.208;database=DDEIS;uid=EES_Service;pwd=99dU6QABcghnV^;";
logServer.DBGetEquipments = sbEquipments.ToString();
logServer.DBGetModelDetails = sbModelDetails.ToString();
logServer.DBGetModelInfo = sbModelInfo.ToString();
// B1
logServer.NetworkAccount.Add("192.168.7.214", new Account("192.168.7.214", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.7.215", new Account("192.168.7.215", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.7.216", new Account("192.168.7.216", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.7.217", new Account("192.168.7.217", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.7.218", new Account("192.168.7.218", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.7.219", new Account("192.168.7.219", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
//logServer.NetworkAccount.Add("192.168.7.150", new Account("192.168.7.150", "T001084@DAEDUCK.COM", "daeduck!1", @"Vol2\EIS서버\"));
logServer.NetworkAccount.Add("192.168.115.214", new Account("192.168.7.214", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.115.215", new Account("192.168.7.215", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.115.216", new Account("192.168.7.216", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.115.217", new Account("192.168.7.217", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.115.218", new Account("192.168.7.218", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.115.219", new Account("192.168.7.219", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.235.214", new Account("192.168.7.214", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.235.215", new Account("192.168.7.215", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.235.216", new Account("192.168.7.216", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.235.217", new Account("192.168.7.217", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.235.218", new Account("192.168.7.218", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.235.219", new Account("192.168.7.219", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.113.231", new Account("192.168.113.231", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.113.232", new Account("192.168.113.232", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.113.233", new Account("192.168.113.233", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.113.236", new Account("192.168.113.236", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.233.231", new Account("192.168.233.231", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.233.232", new Account("192.168.233.232", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.233.233", new Account("192.168.233.233", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
// M1
logServer.NetworkAccount.Add("192.168.143.231", new Account("192.168.143.231", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.143.232", new Account("192.168.143.232", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.143.233", new Account("192.168.143.233", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.143.235", new Account("192.168.143.235", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
// B4, MTV
logServer.NetworkAccount.Add("192.168.163.232", new Account("192.168.163.232", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.173.232", new Account("192.168.173.232", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.FTPAddress = "192.168.7.208";
logServer.FTPPort = 7000;
logServer.FTPUserID = "anonymous";
logServer.FTPPassword = "";
//logServer.FTPUserID = "EES_Service";
//logServer.FTPPassword = "99dU6QABcghnV^";
this.cboxServer.Items.Add(logServer);
#endregion
#region [ EIS.B2 ]
logServer = new LogServer("EIS.B2");
logServer.DBConnectionString = $@"server=192.168.8.214;database=EIS;uid=EIS_Service;pwd=Yi^d!3dqpc%m;";
logServer.DBGetEquipments = sbEquipments.ToString();
logServer.DBGetModelDetails = sbModelDetails.ToString();
logServer.DBGetModelInfo = sbModelInfo.ToString();
logServer.NetworkAccount.Add("192.168.8.215", new Account("192.168.8.215", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.8.216", new Account("192.168.8.216", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.NetworkAccount.Add("192.168.8.217", new Account("192.168.8.217", "loguser", "Daeduck!1", @"EISLog", AccessType.FTPS));
logServer.FTPAddress = "192.168.8.217";
logServer.FTPPort = 21;
logServer.FTPUserID = "anonymous";
logServer.FTPPassword = "";
this.cboxServer.Items.Add(logServer);
#endregion
break;
case eServerType.AGV:
break;
}
}
public EisEquipment[] GetEquipments()
{
try
{
LogServer logServer = this.cboxServer.SelectedItem as LogServer;
if (logServer == null) return null;
this.LogServer = logServer;
this.Cursor = Cursors.WaitCursor;
DataTable dtEisEquipment = logServer.GetEquipments();
EisEquipment[] equipments = dtEisEquipment.ToClass<EisEquipment>();
// Get Equipment Information of the MES Database
DataTable dtMesEquipment = this.GetMesEquipment();
foreach (EisEquipment equipment in equipments)
{
equipment.DisplayNameOrder = GlobalVariable.Instance.FrmEqSelector_NameOrder;
equipment.Server = logServer;
equipment.Description = equipment.Description.Replace("EQP_NAME=", "");
#region [ Setting Equipment Information with MES ]
try
{
if (dtMesEquipment != null)
{
DataRow[] mesRows = dtMesEquipment.Select($"EQUIPMENTID='{equipment.EquipmentID}'");
equipment.MesRegistration = false;
if (mesRows.Length < 1) continue;
DataRow row = mesRows[0];
if (mesRows.Length > 0)
{
for (int i = 0; i < mesRows.Length; i++)
{
if (mesRows[i]["SITEID"].ToString() == "1130")
{
row = mesRows[i];
break;
}
}
}
equipment.Facility = row["FACILITYNAME"].ToString();
equipment.ProcessSegmentID = row["PROCESSSEGMENTID"].ToString();
equipment.ProcessSegmentName = row["PROCESSSEGMENTNAME"].ToString();
equipment.MesName = row["DESCRIPTION"].ToString();
equipment.OperationMode = row["OPERATIONMODE"].ToString();
equipment.ControlMode = row["CONTROLMODE"].ToString();
equipment.State = row["EQPSTATE"].ToString();
equipment.LastTrackInLotID = row["LASTTRACKINLOTID"].ToString();
equipment.LastTrackOutLotID = row["LASTTRACKOUTLOTID"].ToString();
equipment.Maker = row["MAKER"].ToString();
DateTime pmDateTime = DateTime.MinValue;
if (DateTime.TryParseExact(row["PLANDATE"].ToString(), "yyyyMMddHHmmss", System.Globalization.CultureInfo.InvariantCulture, System.Globalization.DateTimeStyles.None, out pmDateTime))
equipment.PMDate = pmDateTime;
equipment.MesRegistration = true;
}
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex);
}
#endregion
}
return equipments.OrderBy(x => x.OrderByKey).ThenBy(x => x.Line).ThenBy(x => x.ProcessSegmentID).ThenBy(x => x.MesName).ToArray();
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex, true);
return null;
}
finally
{
this.Cursor = Cursors.Default;
}
}
private void SetEquipment(DataTableBase equipment)
{
try
{
if (equipment == null) return;
EisEquipment eqp = equipment as EisEquipment;
if (eqp != null)
{
if (eqp.Server == null) return;
foreach (LogServer server in this.cboxServer.Items)
{
if (server.Name == eqp.Server.Name)
{
this.cboxServer.SelectedItem = server;
foreach (GridViewRowInfo row in this.gridEquipments.Rows)
{
EisEquipment bindItem = row.DataBoundItem as EisEquipment;
if (bindItem == null) continue;
if (bindItem.EquipmentID == eqp.EquipmentID)
{
row.IsSelected = true;
row.IsCurrent = true;
}
}
}
}
return;
}
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex);
}
}
private void SetEquipment(string serverName, string equipmentID)
{
try
{
foreach (LogServer server in this.cboxServer.Items)
{
if (server.Name == serverName)
{
this.cboxServer.SelectedItem = server;
foreach (GridViewRowInfo row in this.gridEquipments.Rows)
{
EisEquipment bindItem = row.DataBoundItem as EisEquipment;
if (bindItem == null) continue;
if (bindItem.EquipmentID == equipmentID)
{
row.IsSelected = true;
row.IsCurrent = true;
}
}
}
}
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex);
}
}
private void SetSelectedLogFiles(LogFile[] logFiles)
{
this.gridLogFiles.ClearSelection();
GridViewRowInfo current = null;
foreach (GridViewRowInfo row in this.gridLogFiles.Rows)
{
LogFile item = row.DataBoundItem as LogFile;
if (item == null) continue;
foreach (LogFile logFile in logFiles)
{
if (string.Compare(item.FileName, logFile.FileName, true) == 0)
{
if (current == null)
{
current = row;
row.IsCurrent = true;
}
row.IsSelected = true;
break;
}
}
}
}
private object GetNetworkAccount(string logserverIP) //jhim 20250202
{
return ((LogServer)this.cboxServer.SelectedItem)?.NetworkAccount[logserverIP];
}
/// <summary>
/// DB에서 GEM 정보 수집
/// </summary>
private void GetGEMSetting()
{
try
{
LogServer logServer = this.cboxServer.SelectedItem as LogServer;
if (logServer == null) return;
if (this.Equipment == null) return;
this.Cursor = Cursors.WaitCursor;
DataSet ds = logServer.ExecuteQuery($"SELECT GEMObject FROM GEMParameter WHERE ModelID='{this.Equipment.ModelID}' AND GemSettingID='{this.Equipment.GemSettingID}'");
if (ds == null || ds.Tables.Count < 1 || ds.Tables[0].Rows.Count < 1) return;
byte[] byteObject = (byte[])ds.Tables[0].Rows[0][0];
EIS.Framework.Service.GEM.GEMSettings gem = byteObject.ToObject<EIS.Framework.Service.GEM.GEMSettings>();
this.SECSDefine = new SECSDefine(gem);
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex, true);
}
finally
{
this.Cursor = Cursors.Default;
}
}
/// <summary>
/// MES DB에서 설비정보 수집
/// </summary>
/// <returns></returns>
private DataTable GetMesEquipment()
{
SqlConnection sqlConnection = null;
DataSet ds = null;
DataTable dt = null;
try
{
string connectionString = string.Empty;
connectionString = $@"server=192.168.8.232;database=ddmes;uid=DDB2MESAdmin;pwd=Yhqe4csJXJ4W5$%;";
StringBuilder query = new StringBuilder();
query.AppendLine($" SELECT A.SITEID, ");
query.AppendLine($" A.FACILITYID, ");
query.AppendLine($" D.FACILITYNAME, ");
query.AppendLine($" B.PROCESSSEGMENTID, ");
query.AppendLine($" B.PROCESSSEGMENTNAME, ");
query.AppendLine($" A.SUBCATEGORY, ");
query.AppendLine($" C.EQUIPMENTID AS MAINEQUIPMENTID, ");
query.AppendLine($" C.EQUIPMENTNAME AS MAINEQUIPMENTNAME, ");
query.AppendLine($" A.EQUIPMENTID, ");
query.AppendLine($" A.EQUIPMENTNAME, ");
query.AppendLine($" A.DESCRIPTION, ");
query.AppendLine($" A.OPERATIONMODE, ");
query.AppendLine($" A.CONTROLMODE, ");
query.AppendLine($" A.LASTTRACKINLOTID, ");
query.AppendLine($" A.LASTTRACKOUTLOTID, ");
query.AppendLine($" A.MAKER, ");
query.AppendLine($" A.EQPSTATE, ");
query.AppendLine($" A.LOCATION ");
query.AppendLine($" , E.PLANDATE ");
query.AppendLine($" FROM CIM_EQUIPMENT A (nolock) ");
query.AppendLine($" LEFT JOIN CIM_PROCESSSEGMENT B (nolock) ON A.PROCESSSEGMENTID = B.PROCESSSEGMENTID AND A.SITEID = B.SITEID ");
query.AppendLine($" LEFT JOIN CIM_EQUIPMENT C (nolock) ON A.PARENTID = C.EQUIPMENTID AND A.SITEID = C.SITEID ");
query.AppendLine($" LEFT JOIN CIM_FACILITY D (nolock) ON A.PHYSICALLOCATION = D.FACILITYID AND A.SITEID = D.SITEID ");
query.AppendLine($" LEFT JOIN (SELECT SITEID, EQUIPMENTID, MIN(PLANSTART) PLANDATE FROM DD_SEGMENTPMDETAIL (nolock) WHERE PLANSTART >= '{DateTime.Now.ToString("yyyyMMdd")}' GROUP BY SITEID, EQUIPMENTID) E ON A.EQUIPMENTID = E.EQUIPMENTID AND A.SITEID = E.SITEID ");
//query.AppendLine($" WHERE A.SITEID='1130' ");
sqlConnection = new SqlConnection();
sqlConnection.ConnectionString = connectionString;
sqlConnection.Open();
SqlCommand sqlCommand = new SqlCommand();
sqlCommand.Connection = sqlConnection;
sqlCommand.CommandType = CommandType.Text;
sqlCommand.CommandText = query.ToString();
ds = new DataSet();
SqlDataAdapter sqlAdapter = new SqlDataAdapter(sqlCommand);
sqlAdapter.Fill(ds);
sqlConnection.Close();
if (ds != null && ds.Tables.Count > 0) dt = ds.Tables[0];
return dt;
}
catch (Exception ex)
{
XLogger.Instance.Fatal(ex);
return null;
}
finally
{
if (sqlConnection != null && sqlConnection.State != ConnectionState.Closed)
{
sqlConnection.Close();
sqlConnection.Dispose();
}
}
}
/// <summary>
/// SMB Log Files
/// </summary>
/// <param name="fileItems"></param>
/// <returns></returns>
private LogFile[] GetLogFiles(FileInfo[] fileItems)
{
LogFile[] logFiles = fileItems
.Select(item => new LogFile
{
Account = this.Account,
FullName = item.FullName,
Length = item.Length,
CreationTime = item.CreationTime,
LastAccessTime = item.LastAccessTime,
LastWriteTime = item.LastWriteTime
})
.OrderByDescending(x => x.Name)
.ToArray();
return logFiles;
}
/// <summary>
/// FTPS Log Files
/// </summary>
/// <param name="fileItems"></param>
/// <returns></returns>
private LogFile[] GetLogFiles(FtpListItem[] fileItems)
{
LogFile[] logFiles = fileItems.Where(item => item.Type == FtpFileSystemObjectType.File)
.Select(item => new LogFile
{
Account = this.Account,
FullName = item.FullName,
Length = item.Size,
CreationTime = item.Created.ToLocalTime(),
LastAccessTime = item.Modified.ToLocalTime(),
LastWriteTime = item.Modified.ToLocalTime()
})
.OrderByDescending(x => x.Name)
.ToArray();
return logFiles;
}
/// <summary>
/// SFTP Log Files
/// </summary>
/// <param name="fileItems"></param>
/// <returns></returns>
private LogFile[] GetLogFiles(ISftpFile[] fileItems)
{
LogFile[] logFiles = fileItems.Where(item => !item.IsDirectory && item.Name != "." && item.Name != "..")
.Select(item => new LogFile
{
Account = this.Account,
FullName = item.FullName,
Length = item.Length,
CreationTime = item.LastAccessTime,
LastAccessTime = item.LastAccessTime,
LastWriteTime = item.LastWriteTime
})
.OrderByDescending(x => x.Name)
.ToArray();
return logFiles;
}
/// <summary>
/// Fts Log Files jhlim 20250202
/// </summary>
/// <param name="fileItems"></param>
/// <returns></returns>
private LogFile[] GetFtpslogFiles(object fileItems)
{
LogFile[] logFiles = ((FtpListItem[])fileItems).Where(item => item.Type == FtpFileSystemObjectType.File)
.Select(item => new LogFile
{
Account = this.Account,
FullName = item.FullName,
Length = item.Size,
CreationTime = item.Modified,
LastAccessTime = item.Modified,
LastWriteTime = item.Modified
})
.OrderByDescending(x => x.Name)
.ToArray();
return logFiles;
}
#endregion
}
}