using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using AutoUpdaterDotNET;
using IOB_UT;
using NLog;
using NLog.Targets;
using NLog.Config;
using System.Configuration;
using System.Net;
namespace IOB_WIN
{
public partial class MainForm : Form
{
#region variabili globali, utils ed helpers
///
/// Ramo applicazione (x update)
///
protected string branchName = "develop";
///
/// Indirizzo server
///
protected string MPIP = "";
///
/// URL base applicazione
///
protected string MPURL = "";
///
/// chiamata x check alive di base
///
protected string CMDALIVE = "";
///
/// chiamata x invio comunicazioen reboot dell'IOBMAN
///
protected string CMDREBO = "";
///
/// chiamata x ricevere un codice IOB da gestire/acquisire
///
protected string CMDIOB2CALL = "";
///
/// Num max di CNC da gestire
///
protected int MAXCNC = 1;
///
/// Lista delle IOB da avviare
///
protected List IOB2START;
///
/// oggetto logging
///
public static Logger lg;
///
/// Data Avvio form
///
protected DateTime formStartTime;
///
/// Data ultimo controllo comunicazione
///
public DateTime lastComCheck;
///
/// mostra un testo sulla status bar + LOG
///
///
public void displayTaskAndLog(string txt2show)
{
lblStatus.Text = txt2show;
lblStatus.Invalidate();
lgInfo(txt2show);
}
///
/// Mostra update delle statistiche di comunicazione (num plc connessi, indirizzo server) con colore ad indicare anomalie...
///
///
///
public void updateComStats(int numPLC, bool serverOk)
{
// testo
lblComStats.Text = string.Format("{0} PLC --> {1} (MP/IO)", numPLC, MPIP);
// colore secondo valori... server !="ND" è ok, PLC > 0 è OK
int score = 0;
if (serverOk) score++;
if (numPLC > 0) score++;
switch (score)
{
case 0:
lblComStats.ForeColor = Color.Red;
break;
case 1:
lblComStats.ForeColor = Color.Orange;
break;
case 2:
lblComStats.ForeColor = Color.Green;
break;
default:
lblComStats.ForeColor = Color.Gray;
break;
}
}
///
/// Effettua logging INFO corretto impostanto anche la variabile IOB prima di scrivere...
///
///
protected void lgInfo(string txt2log)
{
lg.Factory.Configuration.Variables["codIOB"] = "MAIN";
lg.Info(txt2log);
}
///
/// Effettua logging ERROR corretto impostanto anche la variabile IOB prima di scrivere...
///
///
protected void lgError(string txt2log)
{
lg.Factory.Configuration.Variables["codIOB"] = "MAIN";
lg.Error(txt2log);
}
#endregion
#region gestione update
///
/// URL stringa di UPDATE...
///
protected string updateUrl
{
get
{
return string.Format("http://seriate.steamware.net:8083/SWS/MAPO/IOB-WIN/{0}/manifest.xml", branchName);
}
}
///
/// IP del PC
///
protected string currIP
{
get
{
string answ = "127.0.0.1";
return answ;
}
}
///
/// URL per segnalazione reboot...
///
protected string urlReboot
{
get
{
string answ = "";
try
{
answ = string.Format(@"http://{0}{1}{2}{3}&mac={4}", MPIP, MPURL, CMDREBO, utils.GetIP(), utils.GetMACAddress());
}
catch
{
answ = string.Format(@"http://{0}{1}{2}{3}", MPIP, MPURL, CMDREBO, utils.GetIP());
}
return answ;
}
}
///
/// URL per chiedere quale sia la IOB da acquisire/gestire (se c'è...)
///
protected string urlIob2call
{
get
{
string answ = "";
try
{
answ = string.Format(@"http://{0}{1}{2}{3}", MPIP, MPURL, CMDIOB2CALL, utils.GetIP());
}
catch
{ }
return answ;
}
}
///
/// Richeista verifica update
///
///
///
private void mCheckUpdates_Click(object sender, EventArgs e)
{
// avvio controllo
AutoUpdater.ShowSkipButton = false;
AutoUpdater.ShowRemindLaterButton = false;
AutoUpdater.RunUpdateAsAdmin = utils.CRB("AUpdAsAdm");
AutoUpdater.Start(updateUrl);
}
#endregion
#region init form
public MainForm()
{
InitializeComponent();
myInit();
}
protected void myInit()
{
DateTime adesso = DateTime.Now;
formStartTime = adesso;
lastComCheck = adesso.AddHours(-1);
lblStatus.Text = "Loading";
// fix icon!
notifyIcon1.Text = string.Format("IOB-WIN | {0}", System.Reflection.Assembly.GetExecutingAssembly().GetName().Version);
Icon = Icon.ExtractAssociatedIcon(utils.defIconFilePath);
notifyIcon1.Icon = Icon.ExtractAssociatedIcon(utils.defIconFilePath);
// fix versione!
lblApp.Text = string.Format("{0}", ConfigurationManager.AppSettings.Get("appName"));
lblVers.Text = string.Format(" v.{0}", System.Reflection.Assembly.GetExecutingAssembly().GetName().Version);
#if DEBUG
// Setup the logging view for Sentinel - http://sentinel.codeplex.com
var sentinelTarget = new NLogViewerTarget()
{
Name = "sentinel",
Address = "udp://127.0.0.1:9999",
IncludeNLogData = false
};
var sentinelRule = new LoggingRule("*", LogLevel.Trace, sentinelTarget);
LogManager.Configuration.AddTarget("sentinel", sentinelTarget);
LogManager.Configuration.LoggingRules.Add(sentinelRule);
#endif
LogManager.ReconfigExistingLoggers();
lg = LogManager.GetCurrentClassLogger();
displayTaskAndLog("MainForm Starting");
// se abilitato autoload conf leggo file corretto...
if (utils.CRB("autoLoadConf"))
{
loadIniFile(utils.mainConfFilePath);
lgInfo("INI LOADED");
// avvio child come richiesto!
startAdapters();
}
else
{
displayTaskAndLog("Waiting for config file selection");
}
displayTaskAndLog("Program Running");
createTrayMenu();
displayTaskAndLog("Tray Menu OK");
// avvio minimizzato se richiesto
if (utils.CRB("startMinimized"))
{
// imposto minimized se necessario!
if (WindowState != FormWindowState.Minimized)
{
WindowState = FormWindowState.Minimized;
}
displayTaskAndLog("Minimized");
}
try
{
// segnalo reboot (programma)...
utils.callUrl(urlReboot);
}
catch (Exception exc)
{
lgError(string.Format("MainForm myInit EXCEPTION in fase di chiamata URL di reboot:{0}{1}{2}", urlReboot, Environment.NewLine, exc));
}
displayTaskAndLog("Main Form OK");
}
///
/// Avvio gli adapters richeisti
///
private void startAdapters()
{
// avvio child richiesti
foreach (var item in IOB2START)
{
openChild(item);
}
}
///
/// Carica file ini della configurazione richiesta
///
///
private void loadIniFile(string iniConfFile)
{
displayTaskAndLog(string.Format("Loading iniConfFile: {0}", iniConfFile));
IniFile fIni = new IniFile(iniConfFile);
// salvo valori letti da INI file...
branchName = fIni.ReadString("BRANCH", "NAME", "develop");
MPIP = fIni.ReadString("SERVER", "MPIP", "ND");
MPURL = fIni.ReadString("SERVER", "MPURL", "/MP/IO");
CMDALIVE = fIni.ReadString("SERVER", "CMDALIVE", "/IOB");
CMDREBO = fIni.ReadString("SERVER", "CMDREBO", "/IOB/sendRebootGateway?GWIP=");
CMDIOB2CALL = fIni.ReadString("SERVER", "CMDIOB2CALL", "/IOB/getIob2call?GWIP=");
MAXCNC= fIni.ReadInteger("IOB", "MAXCNC", 1);
string STARTLIST = fIni.ReadString("IOB", "STARTLIST", "");
if (STARTLIST != "")
{
IOB2START = new List();
string[] elenco = STARTLIST.Split(',');
foreach (var item in elenco)
{
IOB2START.Add(item);
}
}
// se NON sono in DEBUG faccio check update...
#if !(DEBUG)
// avvio autoupdater...
AutoUpdater.RunUpdateAsAdmin = utils.CRB("AUpdAsAdm");
AutoUpdater.Start(updateUrl);
#endif
}
#endregion
#region check comunicazione
///
/// Visualizzazione stato di comunicazione attiva con PLC
///
public bool commPlcActive
{
set
{
// se true --> comunica/verde, altrimenti grigio
lblApp.ForeColor = value ? Color.SeaGreen : Color.Black;
lblVers.ForeColor = value ? Color.SeaGreen : Color.DarkSlateGray;
statusStrip1.Refresh();
}
}
///
/// Effettua verifiche varie comunicazione verso PLC e verso server
///
private void checkCom()
{
// eseguo update se è passato almeno comCheckTOut secondi da ultimo check...
if (DateTime.Now.Subtract(lastComCheck).TotalSeconds > utils.CRI("comCheckTOut"))
{
lastComCheck = DateTime.Now;
// conta quanti child form di adapter verso PLC siano aperti !!!FARE!!! chiedere con un metodo che siano ATTIVI e contare quello...
int numPLC = this.MdiChildren.Count