using System; using System.Collections.Generic; using System.Data.SqlClient; using System.Diagnostics; using System.IO; using System.Linq; using System.Text; using System.Threading.Tasks; using Tango.Core; using Tango.Core.Commands; using Tango.Core.Helpers; using Tango.Integration.Operation; using Tango.Logging; using Tango.PMR.Connection; using Tango.PPC.Common; using Tango.PPC.Common.Application; using Tango.PPC.Common.Connection; using Tango.PPC.Common.MachineSetup; using Tango.PPC.Common.Navigation; using Tango.PPC.UI.ViewsContracts; using Tango.Settings; using Tango.SharedUI.Helpers; using Tango.SQLExaminer; using Tango.Transport.Adapters; namespace Tango.PPC.UI.ViewModels { /// /// Represents the machine setup view ViewModel. /// /// public class MachineSetupViewVM : PPCViewModel { /// /// Represents the various machine setup view states. /// public enum MachineSetupStates { None, Working, Completed, Failed, } public enum MachineSetupView { WelcomeView, WiFiSelectionView, WiFiTestView, SetupWelcomeView, SetupProgressView, SetupCompletedView, SetupFailedView, } private MachineSetupResult _setup_result; #region Properties /// /// Gets or sets the machine setup manager. /// public IMachineSetupManager MachineSetupManager { get; set; } private String _serialNumber; /// /// Gets or sets the serial number. /// public String SerialNumber { get { return _serialNumber; } set { _serialNumber = value; RaisePropertyChangedAuto(); InvalidateRelayCommands(); } } private String _hostAddress; /// /// Gets or sets the host address. /// public String HostAddress { get { return _hostAddress; } set { _hostAddress = value; RaisePropertyChangedAuto(); InvalidateRelayCommands(); } } private String _log; /// /// Gets or sets the log. /// public String Log { get { return _log; } set { _log = value; RaisePropertyChangedAuto(); } } private MachineSetupStates _state; /// /// Gets or sets the state. /// public MachineSetupStates State { get { return _state; } set { _state = value; RaisePropertyChangedAuto(); InvalidateRelayCommands(); } } #endregion #region Commands /// /// Gets or sets the complete command. /// public RelayCommand CompleteCommand { get; set; } /// /// Gets or sets the navigate to WiFi command. /// public RelayCommand NavigateToWiFiCommand { get; set; } /// /// Gets or sets the install command. /// public RelayCommand InstallCommand { get; set; } /// /// Gets or sets the restart command. /// public RelayCommand RestartCommand { get; set; } #endregion #region Constructors /// /// Initializes a new instance of the class. /// /// The application manager. /// The machine setup manager. public MachineSetupViewVM(IPPCApplicationManager applicationManager, IMachineSetupManager machineSetupManager) { MachineSetupManager = machineSetupManager; //MachineSetupManager.ProgressLog += (x, msg) => AppendLog(msg); MachineSetupManager.ProgressStep += (x, step) => AppendLog(Environment.NewLine + "-----------" + step.ToDescription().ToUpper() + "-----------" + Environment.NewLine); HostAddress = Settings.MachineServiceAddress; SerialNumber = ""; CompleteCommand = new RelayCommand(CompleteSetup, () => State == MachineSetupStates.Completed); applicationManager.SetupRequired += ApplicationManager_SetupRequired; NavigateToWiFiCommand = new RelayCommand(EnsureWiFi); InstallCommand = new RelayCommand(Install); RestartCommand = new RelayCommand(() => { NavigateTo(MachineSetupView.WelcomeView); }); } #endregion #region Event Handlers /// /// Handles the SetupRequired event of the ApplicationManager. /// /// The source of the event. /// The instance containing the event data. private void ApplicationManager_SetupRequired(object sender, EventArgs e) { if (!LogManager.Categories.Contains(LogCategory.Debug)) { LogManager.Categories.Add(LogCategory.Debug); } var logger = new SimpleStringLogger(); LogManager.RegisterLogger(logger); logger.LogReceived += Logger_LogReceived; LogManager.Log("SetupRequired event received. Navigating to MachineSetupView..."); NavigationManager.NavigateTo(NavigationView.MachineSetupView); } private void Logger_LogReceived(object sender, LogItemBase e) { AppendLog(e.Message); } #endregion #region Private Methods /// /// Appends the log. /// /// The MSG. private void AppendLog(String msg) { if (msg != null && !msg.Contains("SQL Examiner")) { InvokeUI(() => { View.AppendLog(msg + Environment.NewLine); }); } } /// /// Completes the setup. /// private void CompleteSetup() { String updater_exe = Path.Combine(_setup_result.UpdatePackagePath, "Tango.PPC.Updater.exe"); LogManager.Log("Completing machine setup..."); LogManager.Log($"Executing '{updater_exe}' with arguments '{PathHelper.GetStartupPath()}'..."); Process.Start(updater_exe, PathHelper.GetStartupPath()); LogManager.Log("Terminating application process!"); Environment.Exit(0); } /// /// Navigates to the specified view. /// /// The view. private Task NavigateTo(MachineSetupView view) { return View.NavigateTo(view); } #endregion #region WiFi private async void EnsureWiFi() { await NavigateTo(MachineSetupView.WiFiTestView); await Task.Delay(2000); bool connected = await ConnectivityProvider.CheckInternetConnection(); if (connected) { await NavigateTo(MachineSetupView.SetupWelcomeView); } else { await NavigateTo(MachineSetupView.WiFiSelectionView); await ConnectivityProvider.RefreshAvailableWiFiNetworks(); ConnectivityProvider.ConnectionStateChanged += ConnectivityProvider_ConnectionStateChanged; } } private void ConnectivityProvider_ConnectionStateChanged(object sender, Common.Connectivity.ConnectionStateEventArgs e) { if (e.IsConnected) { ConnectivityProvider.ConnectionStateChanged -= ConnectivityProvider_ConnectionStateChanged; EnsureWiFi(); } } #endregion #region Setup private async void Install() { await NavigateTo(MachineSetupView.SetupProgressView); LogManager.Log("Starting machine setup..."); State = MachineSetupStates.Working; try { _setup_result = await MachineSetupManager.Setup(SerialNumber, HostAddress); Settings.ApplicationState = ApplicationStates.SemiSetup; Settings.Save(); State = MachineSetupStates.Completed; LogManager.Log("Machine setup completed."); CompleteSetup(); } catch (Exception ex) { LogManager.Log(ex, "Machine setup failed."); State = MachineSetupStates.Failed; await NavigateTo(MachineSetupView.SetupFailedView); } } #endregion } }