{"id":1996,"date":"2018-01-20T11:33:59","date_gmt":"2018-01-20T16:33:59","guid":{"rendered":"http:\/\/www.wildow.com\/blog\/?p=1996"},"modified":"2018-01-20T11:33:59","modified_gmt":"2018-01-20T16:33:59","slug":"run-ninite-pro-with-nice-logs-from-maxfocus","status":"publish","type":"post","link":"http:\/\/www.wildow.com\/blog\/?p=1996","title":{"rendered":"Run Ninite Pro with Nice Logs from MAXfocus"},"content":{"rendered":"<header class=\"entry-header\">\n<h1 class=\"entry-title\"><a href=\"https:\/\/www.mcbsys.com\/blog\/2014\/12\/run-ninite-pro-with-nice-logs-from-maxfocus\/\">Run Ninite Pro with Nice Logs from MAXfocus<\/a><\/h1>\n<div class=\"entry-meta\"><span class=\"posted-on\">POSTED ON\u00a0<a href=\"https:\/\/www.mcbsys.com\/blog\/2014\/12\/run-ninite-pro-with-nice-logs-from-maxfocus\/\" rel=\"bookmark\"><time class=\"entry-date published\" datetime=\"2014-12-16T15:37:19+00:00\">DECEMBER 16, 2014<\/time><\/a><\/span><span class=\"byline\">\u00a0BY\u00a0<span class=\"author vcard\"><a class=\"url fn n\" href=\"https:\/\/www.mcbsys.com\/blog\/author\/mark_berry\/\" rel=\"author\">MARK BERRY<\/a><\/span><\/span><\/div>\n<\/header>\n<div class=\"entry-content\">\n<p>I\u2019ve deployed\u00a0<a href=\"https:\/\/ninite.com\/pro\" target=\"_blank\" rel=\"noopener\">Ninite Pro<\/a>\u00a0to update non-Windows applications on computers that I manage. I\u2019m running it in silent mode but I wanted some decent logging so I can review what it did. This is especially useful when run from the MAXfocus dashboard as a Scheduled Task:\u00a0 the output is visible from the dashboard.<\/p>\n<p>The script takes two parameters:<\/p>\n<p><strong>Param 1<\/strong>\u00a0Path to local or network copy of NiniteOne.exe.<\/p>\n<p><strong>Param 2<\/strong>\u00a0Optional path to a NiniteDownloads cache.\u00a0 This can be on a network share, in which case the MAXfocus agent must run as a user with network access (not as the default SYSTEM account).\u00a0 Defaults to\u00a0<code>%temp%\\NiniteDownloads<\/code>\u00a0if not specified.\u00a0 Fails if not accessible.<\/p>\n<p>Example (type on one line):<\/p>\n<p><code>NiniteUpdate.cmd \"%SystemDrive%\\Scripts\\Helpers\" \"\\\\SRV01\\NiniteDownloads\"<\/code><\/p>\n<h3>Behavior<\/h3>\n<p>Ninite is run three times:\u00a0 first in\u00a0<code>\/audit<\/code>\u00a0mode, then in\u00a0<code>\/updateonly<\/code>\u00a0mode, then again in\u00a0<code>\/audit<\/code>\u00a0mode. Output is written to the\u00a0<code>NiniteUpdateSummary.log<\/code>\u00a0file in the same folder as the script. \u201cNot installed\u201d messages are omitted, so you get a nice summary of what\u00a0<em>is<\/em>\u00a0installed. When the script completes, the\u00a0<code>NiniteUpdateSummary.log<\/code>\u00a0file is written to stdout (which is what is displayed in the MAXfocus dashboard). Additionally, the full result of the final audit (including the \u201cNot installed\u201d messages) is saved as\u00a0<code>NiniteAuditAfterUpdate.log<\/code>.<\/p>\n<p>There is a hard-coded variable in the script called\u00a0<strong>CommonParams<\/strong>\u00a0that excludes Microsoft programs (I use Microsoft Update for those), some other programs that were not updating, and TeamViewer (since that update can clobber the MAXfocus Take Control function). I also set it to \/disableshortcuts. You may want to adjust these parameters and exclusions; see the\u00a0<a href=\"https:\/\/ninite.com\/help\/features\/switches.html\" target=\"_blank\" rel=\"noopener\">Ninite command-line switch reference<\/a>\u00a0and their\u00a0<a href=\"https:\/\/ninite.com\/applist\/pro.html\" target=\"_blank\" rel=\"noopener\">list of apps<\/a>.<\/p>\n<h3>Sample Output<\/h3>\n<p>If you run this script from MAXfocus, you\u2019ll want to run it as an automated task\u2014it\u2019s too long to run as a DSC check. I let it run for an hour. After it completes, the Automated Task window will look like this:<\/p>\n<p><a href=\"https:\/\/www.mcbsys.com\/wp-content\/uploads\/2014\/12\/NinitePro-Automated-Task-Output.png\" target=\"_blank\" rel=\"noopener\"><img loading=\"lazy\" decoding=\"async\" title=\"NinitePro Automated Task Output\" src=\"https:\/\/www.mcbsys.com\/wp-content\/uploads\/2014\/12\/NinitePro-Automated-Task-Output_thumb.png\" alt=\"NinitePro Automated Task Output\" width=\"479\" height=\"291\" border=\"0\" \/><\/a><\/p>\n<p>If you scroll in the\u00a0<strong>Details<\/strong>\u00a0area, you\u2019ll see the full output:<\/p>\n<p><code>--------------------------------------------------------------<br \/>\nNinite -<\/code>\u00a0<code>Audit before updating - Tue 12\/16\/2014 - 4:00:51.31<br \/>\nPartial<br \/>\nAir : OK -<\/code>\u00a0<code>15.0.0.356<br \/>\nFirefox : OK - 34.0.5<br \/>\nFlash : Update - 15.0.0.246 -&gt;<\/code>\u00a0<code>16.0.0.235<br \/>\nReader : Update - 10.1.7 -&gt; 11.0.10<br \/>\nSkype : Update -<\/code>\u00a0<code>6.22.0.107 -&gt;<\/code>\u00a0<code>7.0.0.102<br \/>\n--------------------------------------------------------------<\/code>\u00a0<code><br \/>\nNinite - Update Only - Tue 12\/16\/2014 - 4:00:59.83<br \/>\nOK<br \/>\nFlash :<\/code>\u00a0<code>OK<br \/>\nSkype : OK<br \/>\nReader :<\/code>\u00a0<code>OK<br \/>\n--------------------------------------------------------------<br \/>\nNinite<\/code>\u00a0<code>- Audit after updating - Tue 12\/16\/2014 - 4:07:55.61<br \/>\nOK<br \/>\nAir : OK -<\/code>\u00a0<code>15.0.0.356<br \/>\nFirefox : OK - 34.0.5<br \/>\nFlash : OK - 16.0.0.235<br \/>\nReader : OK -<\/code>\u00a0<code>11.0.10<br \/>\nSkype : OK -<\/code>\u00a0<code>7.0.0.102<br \/>\n--------------------------------------------------------------<\/code>\u00a0<code><br \/>\nExiting with ExitCode 0<\/code><\/p>\n<h3>The Script<\/h3>\n<p>Save this as NiniteUpdate.cmd. For easier reading and editing, open it in\u00a0<a href=\"http:\/\/notepad-plus-plus.org\/download\" target=\"_blank\" rel=\"noopener\">Notepad++<\/a>.\u00a0See comments in the script re. various updates since its initial release.<\/p>\n<div id=\"scid:C89E2BDB-ADD3-4f7a-9810-1B7EACF446C1:444e0ee5-7f77-438e-bff1-44505b8824e3\" class=\"wlWriterEditableSmartContent\">\n<div>\n<div id=\"highlighter_163144\" class=\"syntaxhighlighter nogutter  plain\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"plain plain\">@echo off<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"plain plain\">REM Run Ninite \/updateonly on the local computer, optionally caching to local or network path.<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"plain plain\">REM Copyright 2015 by Mark Berry, MCB Systems, www.mcbsys.com.\u00a0 <\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"plain plain\">REM Free for personal or commercial use.\u00a0 May not be sold.<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"plain plain\">REM No warranties.\u00a0 Use at your own risk.<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"plain plain\">REM Param 1:\u00a0 Path to local or network copy of NiniteOne.exe.\u00a0 <\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"plain plain\">REM\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 Path only; assumes \"NiniteOne.exe\" for program name.<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"plain plain\">REM Param 2:\u00a0 Path to NiniteDownloads cache.\u00a0 Can be on a network share.\u00a0 Defaults <\/code><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"plain plain\">REM\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 to %temp%\\NiniteDownloads if not specified.\u00a0 Fails if not accessible.<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number14 index13 alt1\"><code class=\"plain plain\">REM Assumes you have administrative permissions on the local PC.<\/code><\/div>\n<div class=\"line number15 index14 alt2\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number16 index15 alt1\"><code class=\"plain plain\">REM Creates\/replaces NiniteUpdateSummary.log in %ProgramPath%.<\/code><\/div>\n<div class=\"line number17 index16 alt2\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number18 index17 alt1\"><code class=\"plain plain\">REM 12\/11\/2014 Initial script.<\/code><\/div>\n<div class=\"line number19 index18 alt2\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number20 index19 alt1\"><code class=\"plain plain\">REM 12\/13\/2014 Modify to create and save NiniteUpdateSummary.log as combined log file.<\/code><\/div>\n<div class=\"line number21 index20 alt2\"><code class=\"plain plain\">REM\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 Individual Ninite runs write to NiniteTemp.log, deleted after use.<\/code><\/div>\n<div class=\"line number22 index21 alt1\"><code class=\"plain plain\">REM\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 Final audit saved to NiniteAuditAfterUpdate.log.<\/code><\/div>\n<div class=\"line number23 index22 alt2\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number24 index23 alt1\"><code class=\"plain plain\">REM 12\/16\/2014 Add exclusions for Avast and AVG (can't update security software), CCleaner <\/code><\/div>\n<div class=\"line number25 index24 alt2\"><code class=\"plain plain\">REM\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 (vendor doesn't allow update) and Messenger (discontinued).<\/code><\/div>\n<div class=\"line number26 index25 alt1\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number27 index26 alt2\"><code class=\"plain plain\">REM 01\/31\/2015 Exclude \".NET 3.5.2\", a new Microsoft program.<\/code><\/div>\n<div class=\"line number28 index27 alt1\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number29 index28 alt2\"><code class=\"plain plain\">REM 03\/16\/2015 Print program and cache path at beginning of NiniteUpdateSummary.log.<\/code><\/div>\n<div class=\"line number30 index29 alt1\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number31 index30 alt2\"><code class=\"plain plain\">REM 04\/02\/2015 Show parameters in log.\u00a0 <\/code><\/div>\n<div class=\"line number32 index31 alt1\"><code class=\"plain plain\">REM\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 Don't try to write to log if log path (%ProgramPath%) not found.<\/code><\/div>\n<div class=\"line number33 index32 alt2\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number34 index33 alt1\"><code class=\"plain plain\">REM 04\/27\/2015 - Fix bug that was putting cache in C:\\Program Files (x86)\\Advanced Monitoring Agent\\scripts\\-logfile<\/code><\/div>\n<div class=\"line number35 index34 alt2\"><code class=\"plain plain\">REM\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 folder when no cache location was specified and script was run from Max RM.<\/code><\/div>\n<div class=\"line number36 index35 alt1\"><code class=\"plain plain\">REM\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 - Set default cache location to NiniteOne.exe folder (param 1) + \\NiniteDownloads.<\/code><\/div>\n<div class=\"line number37 index36 alt2\"><code class=\"plain plain\">REM<\/code><\/div>\n<div class=\"line number38 index37 alt1\"><code class=\"plain plain\">REM 11\/04\/2015 - Max RM agent 9.12.3 introduced a bug that encloses parameters in single quotation marks if they<\/code><\/div>\n<div class=\"line number39 index38 alt2\"><code class=\"plain plain\">REM\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 were passed in double quotation marks.\u00a0 Strip out single quotation marks around parameters.<\/code><\/div>\n<div class=\"line number40 index39 alt1\"><\/div>\n<div class=\"line number41 index40 alt2\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number42 index41 alt1\"><code class=\"plain plain\">REM Set up variables<\/code><\/div>\n<div class=\"line number43 index42 alt2\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number44 index43 alt1\"><code class=\"plain plain\">REM This script can be adapted to run another program by modifying the next two lines<\/code><\/div>\n<div class=\"line number45 index44 alt2\"><code class=\"plain plain\">set ProgramExe=NiniteOne.exe<\/code><\/div>\n<div class=\"line number46 index45 alt1\"><code class=\"plain plain\">REM Exit with 0; exceptions below<\/code><\/div>\n<div class=\"line number47 index46 alt2\"><code class=\"plain plain\">set \/A exitcode=0<\/code><\/div>\n<div class=\"line number48 index47 alt1\"><\/div>\n<div class=\"line number49 index48 alt2\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number50 index49 alt1\"><code class=\"plain plain\">REM Check for parameters<\/code><\/div>\n<div class=\"line number51 index50 alt2\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number52 index51 alt1\"><code class=\"plain plain\">if ###%1###==###### goto NoParam1<\/code><\/div>\n<div class=\"line number53 index52 alt2\"><code class=\"plain plain\">goto Param1Found<\/code><\/div>\n<div class=\"line number54 index53 alt1\"><\/div>\n<div class=\"line number55 index54 alt2\"><code class=\"plain plain\">:NoParam1<\/code><\/div>\n<div class=\"line number56 index55 alt1\"><code class=\"plain plain\">echo.<\/code><\/div>\n<div class=\"line number57 index56 alt2\"><code class=\"plain plain\">echo Missing parameter(s)<\/code><\/div>\n<div class=\"line number58 index57 alt1\"><code class=\"plain plain\">echo.<\/code><\/div>\n<div class=\"line number59 index58 alt2\"><code class=\"plain plain\">echo Usage:\u00a0 NiniteUpdate.cmd PathToNinite [NiniteDownloadsCache]<\/code><\/div>\n<div class=\"line number60 index59 alt1\"><code class=\"plain plain\">echo.<\/code><\/div>\n<div class=\"line number61 index60 alt2\"><code class=\"plain plain\">echo\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 Example:<\/code><\/div>\n<div class=\"line number62 index61 alt1\"><code class=\"plain plain\">echo.<\/code><\/div>\n<div class=\"line number63 index62 alt2\"><code class=\"plain plain\">echo\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 NiniteUpdate.cmd \"C:\\Scripts\\Helpers\" \"\\\\SRV01\\NiniteDownloads\"<\/code><\/div>\n<div class=\"line number64 index63 alt1\"><code class=\"plain plain\">echo.<\/code><\/div>\n<div class=\"line number65 index64 alt2\"><code class=\"plain plain\">set \/A exitcode=1001<\/code><\/div>\n<div class=\"line number66 index65 alt1\"><code class=\"plain plain\">goto End<\/code><\/div>\n<div class=\"line number67 index66 alt2\"><\/div>\n<div class=\"line number68 index67 alt1\"><code class=\"plain plain\">:Param1Found<\/code><\/div>\n<div class=\"line number69 index68 alt2\"><code class=\"plain plain\">REM Strip double quotation marks, if any, from parameter<\/code><\/div>\n<div class=\"line number70 index69 alt1\"><code class=\"plain plain\">set ProgramPath=%~1<\/code><\/div>\n<div class=\"line number71 index70 alt2\"><code class=\"plain plain\">REM Now strip single quotation marks, if any, added by Max RM caller bug. <\/code><\/div>\n<div class=\"line number72 index71 alt1\"><code class=\"plain plain\">REM See http:\/\/ss64.com\/nt\/syntax-dequote.html.<\/code><\/div>\n<div class=\"line number73 index72 alt2\"><code class=\"plain plain\">set ProgramPath=###%ProgramPath%###<\/code><\/div>\n<div class=\"line number74 index73 alt1\"><code class=\"plain plain\">set ProgramPath=%ProgramPath:'###=%<\/code><\/div>\n<div class=\"line number75 index74 alt2\"><code class=\"plain plain\">set ProgramPath=%ProgramPath:###'=%<\/code><\/div>\n<div class=\"line number76 index75 alt1\"><code class=\"plain plain\">set ProgramPath=%ProgramPath:###=%<\/code><\/div>\n<div class=\"line number77 index76 alt2\"><\/div>\n<div class=\"line number78 index77 alt1\"><code class=\"plain plain\">if ###%2###==###### goto NoParam2<\/code><\/div>\n<div class=\"line number79 index78 alt2\"><code class=\"plain plain\">REM Max RM adds a -logfile parameter as the last parameter.\u00a0 Ignore that.<\/code><\/div>\n<div class=\"line number80 index79 alt1\"><code class=\"plain plain\">if ###%2###==###-logfile### goto NoParam2<\/code><\/div>\n<div class=\"line number81 index80 alt2\"><code class=\"plain plain\">goto Param2Found<\/code><\/div>\n<div class=\"line number82 index81 alt1\"><\/div>\n<div class=\"line number83 index82 alt2\"><code class=\"plain plain\">:NoParam2<\/code><\/div>\n<div class=\"line number84 index83 alt1\"><code class=\"plain plain\">set CachePath=%ProgramPath%\\NiniteDownloads<\/code><\/div>\n<div class=\"line number85 index84 alt2\"><code class=\"plain plain\">goto EchoParams<\/code><\/div>\n<div class=\"line number86 index85 alt1\"><\/div>\n<div class=\"line number87 index86 alt2\"><code class=\"plain plain\">:Param2Found<\/code><\/div>\n<div class=\"line number88 index87 alt1\"><code class=\"plain plain\">REM Strip double quotation marks, if any, from parameter<\/code><\/div>\n<div class=\"line number89 index88 alt2\"><code class=\"plain plain\">set CachePath=%~2<\/code><\/div>\n<div class=\"line number90 index89 alt1\"><code class=\"plain plain\">REM Now strip single quotation marks, if any, added by Max RM caller bug. <\/code><\/div>\n<div class=\"line number91 index90 alt2\"><code class=\"plain plain\">REM See http:\/\/ss64.com\/nt\/syntax-dequote.html.<\/code><\/div>\n<div class=\"line number92 index91 alt1\"><code class=\"plain plain\">set CachePath=###%CachePath%###<\/code><\/div>\n<div class=\"line number93 index92 alt2\"><code class=\"plain plain\">set CachePath=%CachePath:'###=%<\/code><\/div>\n<div class=\"line number94 index93 alt1\"><code class=\"plain plain\">set CachePath=%CachePath:###'=%<\/code><\/div>\n<div class=\"line number95 index94 alt2\"><code class=\"plain plain\">set CachePath=%CachePath:###=%<\/code><\/div>\n<div class=\"line number96 index95 alt1\"><\/div>\n<div class=\"line number97 index96 alt2\"><code class=\"plain plain\">:EchoParams<\/code><\/div>\n<div class=\"line number98 index97 alt1\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number99 index98 alt2\"><code class=\"plain plain\">REM Echo parsed parameters<\/code><\/div>\n<div class=\"line number100 index99 alt1\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number101 index100 alt2\"><code class=\"plain plain\">REM echo\u00a0\u00a0 ProgramPath: %ProgramPath%<\/code><\/div>\n<div class=\"line number102 index101 alt1\"><code class=\"plain plain\">REM echo\u00a0\u00a0\u00a0 ProgramExe: %ProgramExe%<\/code><\/div>\n<div class=\"line number103 index102 alt2\"><code class=\"plain plain\">REM echo\u00a0\u00a0\u00a0\u00a0 CachePath: %CachePath%<\/code><\/div>\n<div class=\"line number104 index103 alt1\"><code class=\"plain plain\">REM echo.<\/code><\/div>\n<div class=\"line number105 index104 alt2\"><\/div>\n<div class=\"line number106 index105 alt1\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number107 index106 alt2\"><code class=\"plain plain\">REM Check for program path<\/code><\/div>\n<div class=\"line number108 index107 alt1\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number109 index108 alt2\"><code class=\"plain plain\">if exist \"%ProgramPath%\" goto ProgramPathExists<\/code><\/div>\n<div class=\"line number110 index109 alt1\"><code class=\"plain plain\">echo Program path \"%ProgramPath%\" does not exist. Exiting.<\/code><\/div>\n<div class=\"line number111 index110 alt2\"><code class=\"plain plain\">set \/A exitcode=1002<\/code><\/div>\n<div class=\"line number112 index111 alt1\"><code class=\"plain plain\">goto End<\/code><\/div>\n<div class=\"line number113 index112 alt2\"><\/div>\n<div class=\"line number114 index113 alt1\"><code class=\"plain plain\">:ProgramPathExists<\/code><\/div>\n<div class=\"line number115 index114 alt2\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number116 index115 alt1\"><code class=\"plain plain\">REM Check for program executable<\/code><\/div>\n<div class=\"line number117 index116 alt2\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number118 index117 alt1\"><code class=\"plain plain\">if exist \"%ProgramPath%\\%ProgramExe%\" goto ProgramExists<\/code><\/div>\n<div class=\"line number119 index118 alt2\"><code class=\"plain plain\">echo Program executable \"%ProgramPath%\\%ProgramExe%\" does not exist. Exiting.<\/code><\/div>\n<div class=\"line number120 index119 alt1\"><code class=\"plain plain\">set \/A exitcode=1003<\/code><\/div>\n<div class=\"line number121 index120 alt2\"><code class=\"plain plain\">goto End<\/code><\/div>\n<div class=\"line number122 index121 alt1\"><\/div>\n<div class=\"line number123 index122 alt2\"><code class=\"plain plain\">:ProgramExists<\/code><\/div>\n<div class=\"line number124 index123 alt1\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number125 index124 alt2\"><code class=\"plain plain\">REM Check for cache path<\/code><\/div>\n<div class=\"line number126 index125 alt1\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number127 index126 alt2\"><code class=\"plain plain\">REM First try to create it if it doesn't exist<\/code><\/div>\n<div class=\"line number128 index127 alt1\"><code class=\"plain plain\">if not exist \"%CachePath%\" md \"%CachePath%\"<\/code><\/div>\n<div class=\"line number129 index128 alt2\"><code class=\"plain plain\">REM If it still doesn't exist, e.g. if it's on an inaccessible network share, fail<\/code><\/div>\n<div class=\"line number130 index129 alt1\"><code class=\"plain plain\">if exist \"%CachePath%\" goto CachePathExists<\/code><\/div>\n<div class=\"line number131 index130 alt2\"><code class=\"plain plain\">echo Downloads cache path \"%CachePath%\" does not exist and could not create it. Exiting.<\/code><\/div>\n<div class=\"line number132 index131 alt1\"><code class=\"plain plain\">set \/A exitcode=1004<\/code><\/div>\n<div class=\"line number133 index132 alt2\"><code class=\"plain plain\">goto End<\/code><\/div>\n<div class=\"line number134 index133 alt1\"><\/div>\n<div class=\"line number135 index134 alt2\"><code class=\"plain plain\">:CachePathExists<\/code><\/div>\n<div class=\"line number136 index135 alt1\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number137 index136 alt2\"><code class=\"plain plain\">REM Run Ninite three times with various parameters<\/code><\/div>\n<div class=\"line number138 index137 alt1\"><code class=\"plain plain\">REM ===========================================================================================<\/code><\/div>\n<div class=\"line number139 index138 alt2\"><code class=\"plain plain\">set CommonParams=\/silent \"%ProgramPath%\\NiniteTemp.log\" \/disableshortcuts \/exclude \".NET\" \".NET 3.5\" \".NET 4\" \".NET 4.5\" \".NET 4.5.1\" \".NET 4.5.2\" Avast AVG CCleaner Essentials Messenger Office OneDrive OpenOffice Silverlight SkyDrive TeamViewer<\/code><\/div>\n<div class=\"line number140 index139 alt1\"><code class=\"plain plain\">set CacheParam=\/cachepath \"%CachePath%\"<\/code><\/div>\n<div class=\"line number141 index140 alt2\"><\/div>\n<div class=\"line number142 index141 alt1\"><code class=\"plain plain\">REM Send all output to NiniteUpdateSummary.log file.\u00a0 First redirect overwrites previous log; the rest append.<\/code><\/div>\n<div class=\"line number143 index142 alt2\"><code class=\"plain plain\">set LogFullPath=%ProgramPath%\\NiniteUpdateSummary.log<\/code><\/div>\n<div class=\"line number144 index143 alt1\"><\/div>\n<div class=\"line number145 index144 alt2\"><code class=\"plain plain\">echo NiniteUpdate.cmd &gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number146 index145 alt1\"><code class=\"plain plain\">echo. &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number147 index146 alt2\"><code class=\"plain plain\">echo\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 Program: %ProgramPath%\\%ProgramExe% &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number148 index147 alt1\"><code class=\"plain plain\">echo\u00a0\u00a0 Cache param: %CacheParam% &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number149 index148 alt2\"><code class=\"plain plain\">echo Common params: %CommonParams% &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number150 index149 alt1\"><code class=\"plain plain\">echo\u00a0\u00a0\u00a0\u00a0\u00a0 Log file: %LogFullPath% &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number151 index150 alt2\"><\/div>\n<div class=\"line number152 index151 alt1\"><code class=\"plain plain\">echo. &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number153 index152 alt2\"><code class=\"plain plain\">echo -------------------------------------------------------------- &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number154 index153 alt1\"><code class=\"plain plain\">echo Ninite - \/audit before updating - %date% - %time% &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number155 index154 alt2\"><code class=\"plain plain\">echo. &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number156 index155 alt1\"><code class=\"plain plain\">\"%ProgramPath%\\%ProgramExe%\" \/audit %CommonParams% %CacheParam%<\/code><\/div>\n<div class=\"line number157 index156 alt2\"><code class=\"plain plain\">set \/a errorcode=%errorlevel%<\/code><\/div>\n<div class=\"line number158 index157 alt1\"><code class=\"plain plain\">if %errorcode% EQU 0 goto Continue1<\/code><\/div>\n<div class=\"line number159 index158 alt2\"><code class=\"plain plain\">echo Running first %ProgramExe% \/audit failed with ErrorLevel %errorcode%.\u00a0 Exiting.<\/code><\/div>\n<div class=\"line number160 index159 alt1\"><code class=\"plain plain\">set \/A exitcode=1100+%errorcode%<\/code><\/div>\n<div class=\"line number161 index160 alt2\"><code class=\"plain plain\">goto PrintLogAndEnd<\/code><\/div>\n<div class=\"line number162 index161 alt1\"><\/div>\n<div class=\"line number163 index162 alt2\"><code class=\"plain plain\">:Continue1<\/code><\/div>\n<div class=\"line number164 index163 alt1\"><code class=\"plain plain\">REM Print lines that do NOT contain the string \": Not installed\"<\/code><\/div>\n<div class=\"line number165 index164 alt2\"><code class=\"plain plain\">type \"%ProgramPath%\\NiniteTemp.log\" | find \/V \": Not installed\" &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number166 index165 alt1\"><code class=\"plain plain\">del \"%ProgramPath%\\NiniteTemp.log\"<\/code><\/div>\n<div class=\"line number167 index166 alt2\"><code class=\"plain plain\">echo. &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number168 index167 alt1\"><code class=\"plain plain\">echo -------------------------------------------------------------- &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number169 index168 alt2\"><code class=\"plain plain\">echo Ninite - \/updateonly - %date% - %time% &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number170 index169 alt1\"><code class=\"plain plain\">echo. &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number171 index170 alt2\"><code class=\"plain plain\">\"%ProgramPath%\\%ProgramExe%\" \/updateonly %CommonParams% %CacheParam%<\/code><\/div>\n<div class=\"line number172 index171 alt1\"><code class=\"plain plain\">set \/a errorcode=%errorlevel%<\/code><\/div>\n<div class=\"line number173 index172 alt2\"><code class=\"plain plain\">if %errorcode% EQU 0 goto Continue2<\/code><\/div>\n<div class=\"line number174 index173 alt1\"><code class=\"plain plain\">echo Running %ProgramExe% \/updateonly failed with ErrorLevel %errorcode%.\u00a0 Exiting.<\/code><\/div>\n<div class=\"line number175 index174 alt2\"><code class=\"plain plain\">set \/A exitcode=1100+%errorcode%<\/code><\/div>\n<div class=\"line number176 index175 alt1\"><code class=\"plain plain\">goto PrintLogAndEnd<\/code><\/div>\n<div class=\"line number177 index176 alt2\"><\/div>\n<div class=\"line number178 index177 alt1\"><code class=\"plain plain\">:Continue2<\/code><\/div>\n<div class=\"line number179 index178 alt2\"><code class=\"plain plain\">type \"%ProgramPath%\\NiniteTemp.log\" &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number180 index179 alt1\"><code class=\"plain plain\">del \"%ProgramPath%\\NiniteTemp.log\"<\/code><\/div>\n<div class=\"line number181 index180 alt2\"><code class=\"plain plain\">echo. &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number182 index181 alt1\"><code class=\"plain plain\">echo -------------------------------------------------------------- &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number183 index182 alt2\"><code class=\"plain plain\">echo Ninite - \/audit after updating - %date% - %time% &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number184 index183 alt1\"><code class=\"plain plain\">echo. &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number185 index184 alt2\"><code class=\"plain plain\">\"%ProgramPath%\\%ProgramExe%\" \/audit %CommonParams% %CacheParam%<\/code><\/div>\n<div class=\"line number186 index185 alt1\"><code class=\"plain plain\">set \/a errorcode=%errorlevel%<\/code><\/div>\n<div class=\"line number187 index186 alt2\"><code class=\"plain plain\">if %errorcode% EQU 0 goto Continue3<\/code><\/div>\n<div class=\"line number188 index187 alt1\"><code class=\"plain plain\">echo Running second %ProgramExe% \/audit failed with ErrorLevel %errorcode%.\u00a0 Exiting.<\/code><\/div>\n<div class=\"line number189 index188 alt2\"><code class=\"plain plain\">set \/A exitcode=1100+%errorcode%<\/code><\/div>\n<div class=\"line number190 index189 alt1\"><code class=\"plain plain\">goto PrintLogAndEnd<\/code><\/div>\n<div class=\"line number191 index190 alt2\"><\/div>\n<div class=\"line number192 index191 alt1\"><code class=\"plain plain\">:Continue3<\/code><\/div>\n<div class=\"line number193 index192 alt2\"><code class=\"plain plain\">type \"%ProgramPath%\\NiniteTemp.log\" | find \/V \": Not installed\" &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number194 index193 alt1\"><code class=\"plain plain\">REM Save final full log as NiniteAuditAfterUpdate.log (delete old audit first)<\/code><\/div>\n<div class=\"line number195 index194 alt2\"><code class=\"plain plain\">del \"%ProgramPath%\\NiniteAuditAfterUpdate.log\"<\/code><\/div>\n<div class=\"line number196 index195 alt1\"><code class=\"plain plain\">ren \"%ProgramPath%\\NiniteTemp.log\" \"NiniteAuditAfterUpdate.log\"<\/code><\/div>\n<div class=\"line number197 index196 alt2\"><\/div>\n<div class=\"line number198 index197 alt1\"><code class=\"plain plain\">:PrintLogAndEnd<\/code><\/div>\n<div class=\"line number199 index198 alt2\"><code class=\"plain plain\">echo. &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number200 index199 alt1\"><code class=\"plain plain\">echo -------------------------------------------------------------- &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number201 index200 alt2\"><code class=\"plain plain\">echo. &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number202 index201 alt1\"><code class=\"plain plain\">REM Type log to stdout so it will appear in Max RM dashboard<\/code><\/div>\n<div class=\"line number203 index202 alt2\"><code class=\"plain plain\">type \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number204 index203 alt1\"><code class=\"plain plain\">echo Exiting with ExitCode %exitcode% &gt;&gt; \"%LogFullPath%\"<\/code><\/div>\n<div class=\"line number205 index204 alt2\"><\/div>\n<div class=\"line number206 index205 alt1\"><code class=\"plain plain\">:End<\/code><\/div>\n<div class=\"line number207 index206 alt2\"><code class=\"plain plain\">REM Display ExitCode in stdout even if log file not available<\/code><\/div>\n<div class=\"line number208 index207 alt1\"><code class=\"plain plain\">echo Exiting with ExitCode %exitcode%<\/code><\/div>\n<div class=\"line number209 index208 alt2\"><code class=\"plain plain\">exit \/b %exitcode%<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"excerpt":{"rendered":"<p>Run Ninite Pro with Nice Logs from MAXfocus POSTED ON\u00a0DECEMBER 16, 2014\u00a0BY\u00a0MARK BERRY I\u2019ve deployed\u00a0Ninite Pro\u00a0to update non-Windows applications on computers that I manage. I\u2019m running it in silent mode but I wanted some decent logging so I can review &#8230; <a class=\"more-link\" href=\"http:\/\/www.wildow.com\/blog\/?p=1996\">Read More &raquo;<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-1996","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"_links":{"self":[{"href":"http:\/\/www.wildow.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/1996","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.wildow.com\/blog\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.wildow.com\/blog\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.wildow.com\/blog\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/www.wildow.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1996"}],"version-history":[{"count":1,"href":"http:\/\/www.wildow.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/1996\/revisions"}],"predecessor-version":[{"id":1997,"href":"http:\/\/www.wildow.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/1996\/revisions\/1997"}],"wp:attachment":[{"href":"http:\/\/www.wildow.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1996"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.wildow.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1996"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.wildow.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1996"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}