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; } }
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; }
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); }
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); }