Пример #1
0
        private void RunScript(List <ScriptDto> listScript)
        {
            try
            {
                if (String.IsNullOrWhiteSpace(appArgs.ScriptId) || !listScript.Any(r => r.Id.Equals(appArgs.ScriptId)))
                {
                    log.Error("Identifiant du script absent ou non reconnu ('{0}' : {1})", appArgs.ScriptId,
                              String.Join(", ", listScript.Select(r => r.Id)));
                    appExitCode = EnumExitCode.NoScriptOrNotKnown;

                    return;
                }

                ScriptDto scriptDto = listScript.FirstOrDefault(r => r.Id.Equals(appArgs.ScriptId));
                log.Info("Script à lancer (id: {0}, script: {1})", scriptDto.Id, scriptDto.Path);

                ScriptRunner sRun = new ScriptRunner(scriptDto);
                _handler += new EventHandler(sRun.HandleUnusalExit);
                SetConsoleCtrlHandler(_handler, true);
                sRun.Run(appArgs.ScriptArgsInput);
            }
            catch (Exception e)
            {
                log.Error("Erreur inattendue : {0}", e.Message);
                ExceptionHandlingUtils.LogAndHideException(e, isWarnMsgAndDebugStack: true);
                appExitCode = EnumExitCode.ErrorScriptRunner;

                return;
            }
        }
Пример #2
0
        private void Run(string[] args)
        {
            ExceptionHandlingUtils.Logger = log;
            log.Debug("Démarrage du programme");

            AppArgParser parser = new AppArgParser();

            appArgs = parser.ParseDirect(args);
            log.Debug("Paramètres: {0}", appArgs);

            // Console.SetWindowPosition();

            try
            {
                XmlParser        xmlParser  = new XmlParser(appArgs.XmlFile);
                List <ScriptDto> listScript = xmlParser.GetListScripts();
                log.Debug("Scripts disponibles: {0}", String.Join(", ", listScript.Select(r => r.Id)));

                switch (appArgs.Mode)
                {
                case EnumModeLancement.NoMode:
                    ShowSyntax(parser);
                    break;

                case EnumModeLancement.RunScript:
                    RunScript(listScript);
                    break;

                case EnumModeLancement.ListScript:
                    ListScript(listScript);
                    break;

                case EnumModeLancement.NewScriptInit:
                    InitNewScript(listScript);
                    break;

                case EnumModeLancement.InteractiveLaunch:
                    RunScriptInteractive(listScript);
                    break;
                }
            }
            catch (Exception e)
            {
                ExceptionHandlingUtils.LogAndHideException(e);
                if (appArgs.HaltOnError)
                {
                    Console.WriteLine("Appuyez sur une touche pour continuer");
                    Console.ReadKey();
                }
            }

            Environment.ExitCode = (int)appExitCode;
        }
Пример #3
0
        public bool HandleUnusalExit(Program.CtrlType sig)
        {
            log.Info("Fermeture non prévue détectée");

            if (_runningProcess != null && !_runningProcess.HasExited)
            {
                try
                {
                    _runningProcess.Kill();
                }
                catch (Exception e)
                {
                    ExceptionHandlingUtils.LogAndHideException(e, "Erreur lors de la tenative d'arrêt du processus :");
                    throw e;
                }
            }

            return(true);
        }
Пример #4
0
        private bool LaunchProcess(string scriptArgLine)
        {
            _runningProcess = null;
            try
            {
                ProcessStartInfo pInfo = new ProcessStartInfo();
                pInfo.FileName = "powershell.exe";
                if (scriptArgLine != null)
                {
                    pInfo.Arguments = scriptArgLine;
                }

                if (!String.IsNullOrWhiteSpace(scriptDto.Wd))
                {
                    pInfo.WorkingDirectory = scriptDto.Wd;
                }

                if (scriptDto.PowershellParams.WithAdmin)
                {
                    pInfo.Verb = "runas";
                }

                if (IsOutputYes(scriptDto.PowershellParams.OutputToFileEnum))
                {
                    pInfo.RedirectStandardOutput = true;
                    pInfo.RedirectStandardError  = true;
                    pInfo.UseShellExecute        = false;
                    oufFilename = String.Format("outFile-{0}-{1:yyyy-MM-dd HHmmss}.txt", scriptDto.Id, DateTime.Now);
                    log.Debug("Sortie enregistrée dansle fchier {0}", oufFilename);
                }


                _runningProcess           = new Process();
                _runningProcess.StartInfo = pInfo;
                if (IsOutputYes(scriptDto.PowershellParams.OutputToFileEnum))
                {
                    _runningProcess.OutputDataReceived += new DataReceivedEventHandler(OutputHandler);
                    _runningProcess.ErrorDataReceived  += new DataReceivedEventHandler(OutputHandler);
                }

                _runningProcess.Start();
                log.Info("Processus démarré -> id: {0}", _runningProcess.Id);
                if (IsOutputYes(scriptDto.PowershellParams.OutputToFileEnum))
                {
                    _runningProcess.BeginOutputReadLine();
                    _runningProcess.BeginErrorReadLine();
                }

                if (scriptDto.PowershellParams.WaitSeconds > 0)
                {
                    _runningProcess.WaitForExit(scriptDto.PowershellParams.WaitSeconds * 1000);
                    if (!_runningProcess.HasExited)
                    {
                        _runningProcess.Kill();
                    }
                }
                else
                {
                    _runningProcess.WaitForExit();
                }



                log.Info("Script exit-code: {0}", _runningProcess.ExitCode);
                return(true);
            }
            catch (Exception e)
            {
                log.Error("Erreur lors du lancement du script : {0}", e.Message);
                return(false);
            }
            finally
            {
                if (_runningProcess != null && !_runningProcess.HasExited)
                {
                    try
                    {
                        _runningProcess.Kill();
                    }
                    catch (Exception e)
                    {
                        ExceptionHandlingUtils.LogAndHideException(e, "Erreur lors de la tenative d'arrêt du processus :");
                    }
                }
                if (outputFile != null && scriptDto.PowershellParams.OutputToFileEnum == EnumTypeOutput.Yes)
                {
                    FlushOutputFile();
                }
            }

            return(false);
        }