using System; using System.Collections.Generic; using System.Data.SqlClient; using System.Diagnostics; using System.Linq; using System.Text; using System.Threading.Tasks; using Tango.Core; using Tango.Core.Commands; using Tango.Core.Helpers; using Tango.PPC.Common; using Tango.PPC.Common.Application; 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; 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, } 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 start command. /// public RelayCommand StartCommand { get; set; } /// /// Gets or sets the complete command. /// public RelayCommand CompleteCommand { 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 = "localhost\\SQLEXPRESS"; SerialNumber = "1111"; StartCommand = new RelayCommand(StartSetup, () => !String.IsNullOrWhiteSpace(HostAddress) && !String.IsNullOrWhiteSpace(SerialNumber) && State == MachineSetupStates.None); CompleteCommand = new RelayCommand(CompleteSetup, () => State == MachineSetupStates.Completed); applicationManager.SetupRequired += ApplicationManager_SetupRequired; } #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) { LogManager.Log("SetupRequired event received. Navigating to MachineSetupView..."); NavigationManager.NavigateTo(NavigationView.MachineSetupView); } #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); }); } } /// /// Starts the setup. /// private async void StartSetup() { 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."); } catch (Exception ex) { LogManager.Log(ex, "Machine setup failed."); State = MachineSetupStates.Failed; await NotificationProvider.ShowInfo(ex.Message); } } /// /// Completes the setup. /// private void CompleteSetup() { String updater_exe = AssemblyHelper.GetCurrentAssemblyFolder() + "\\Tango.PPC.Updater.exe"; LogManager.Log("Completing machine setup..."); LogManager.Log($"Executing '{updater_exe}' with arguments '{_setup_result.UpdatePackagePath}'..."); Process.Start(updater_exe, _setup_result.UpdatePackagePath); LogManager.Log("Terminating application process!"); Environment.Exit(0); } #endregion } }