<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>No Znx! &#187; ms</title>
	<atom:link href="http://znx.no/tag/ms/feed/" rel="self" type="application/rss+xml" />
	<link>http://znx.no</link>
	<description>the pigeons!!!!</description>
	<lastBuildDate>Fri, 21 May 2010 16:05:24 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0</generator>
		<item>
		<title>Renaming Files In A Directory</title>
		<link>http://znx.no/2009/09/renaming-files/</link>
		<comments>http://znx.no/2009/09/renaming-files/#comments</comments>
		<pubDate>Wed, 02 Sep 2009 20:58:32 +0000</pubDate>
		<dc:creator>znx</dc:creator>
				<category><![CDATA[Scripts]]></category>
		<category><![CDATA[Windows]]></category>
		<category><![CDATA[ms]]></category>
		<category><![CDATA[powershell]]></category>

		<guid isPermaLink="false">http://znx.no/?p=159</guid>
		<description><![CDATA[So I had a problem on Windows in that I have lots of directories that are named correctly but I wish the files under them to be uniformly named. The solution was to use PowerShell, which is an extremely effective scripting tool for Windows, especially if you come from a UNIX shell background. There is [...]]]></description>
			<content:encoded><![CDATA[<p>So I had a problem on Windows in that I have lots of directories that are named correctly but I wish the files under them to be uniformly named.</p>
<p>The solution was to use <a href="http://www.microsoft.com/windowsserver2003/technologies/management/powershell/default.mspx">PowerShell</a>, which is an extremely effective scripting tool for Windows, especially if you come from a UNIX shell background.</p>
<p>There is actually quite a lot of documentation available for it and rather than go into detail I will simply show you the script:</p>

<div class="wp_syntax"><div class="code"><pre class="powershell" style="font-family:monospace;"><span style="color: #008000;">#</span>
<span style="color: #008000;"># RenameDirectoryFiles.ps1</span>
<span style="color: #008000;">#</span>
&nbsp;
<span style="color: #0000FF;">param</span><span style="color: #000000;">&#40;</span> <span style="color: #000000;">&#91;</span><span style="color: #008080;">string</span><span style="color: #000000;">&#91;</span><span style="color: #000000;">&#93;</span><span style="color: #000000;">&#93;</span><span style="color: #800080;">$paths</span> <span style="color: #000000;">&#41;</span>
<span style="color: #008080; font-weight: bold;">Set-PSDebug</span> <span style="color: #008080; font-style: italic;">-Strict</span>
&nbsp;
<span style="color: #0000FF;">foreach</span> <span style="color: #000000;">&#40;</span> <span style="color: #800080;">$path</span> <span style="color: #0000FF;">in</span> <span style="color: #800080;">$paths</span> <span style="color: #000000;">&#41;</span> <span style="color: #000000;">&#123;</span>
    <span style="color: #0000FF;">if</span> <span style="color: #000000;">&#40;</span> <span style="color: pink;">!</span><span style="color: #000000;">&#40;</span><span style="color: #008080; font-weight: bold;">Test-Path</span> <span style="color: #800080;">$path</span> <span style="color: #008080; font-style: italic;">-PathType</span> Container<span style="color: #000000;">&#41;</span> <span style="color: #000000;">&#41;</span> <span style="color: #000000;">&#123;</span>
        <span style="color: #008080; font-weight: bold;">Write-Error</span> <span style="color: #800000;">&quot;'$path' doesn't exist or isn't a directory&quot;</span>
        exit <span style="color: #000000;">1</span>
    <span style="color: #000000;">&#125;</span>
&nbsp;
    <span style="color: #800080;">$i</span> <span style="color: pink;">=</span> <span style="color: #000000;">0</span>
    <span style="color: #008080; font-weight: bold;">Get-ChildItem</span> <span style="color: #800080;">$path</span> <span style="color: pink;">|</span> <span style="color: #008080; font-weight: bold;">sort</span> FullName <span style="color: pink;">|</span> <span style="color: #0000FF;">foreach</span> <span style="color: #000000;">&#123;</span>
        <span style="color: #800080;">$tmp</span> <span style="color: pink;">=</span> <span style="color: #800000;">&quot;{0:000}&quot;</span> <span style="color: #FF0000;">-f</span> <span style="color: #800080;">$i</span>
        <span style="color: #800080;">$ext</span> <span style="color: pink;">=</span> <span style="color: #000080;">$_</span>.Extension
        <span style="color: #800080;">$newname</span> <span style="color: pink;">=</span> <span style="color: #800000;">&quot;$path - $tmp$ext&quot;</span>
        <span style="color: #008080; font-weight: bold;">Rename-Item</span> <span style="color: #000080;">$_</span>.fullname <span style="color: #800080;">$newname</span>
        <span style="color: #800080;">$newname</span>
        <span style="color: #800080;">$i</span> <span style="color: pink;">=</span> <span style="color: #800080;">$i</span> <span style="color: pink;">+</span> <span style="color: #000000;">1</span>
    <span style="color: #000000;">&#125;</span>
<span style="color: #000000;">&#125;</span></pre></div></div>

<p>So the usage is extremely simple:</p>
<pre>RenameDirectoryFiles.ps1 'My Directory'</pre>
<p>After which all the files under &#8216;My Directory&#8217; will be renamed to &#8216;My Directory &#8211; 000.fileextension&#8217;.</p>
]]></content:encoded>
			<wfw:commentRss>http://znx.no/2009/09/renaming-files/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Microsoft Business Productivity Racism?</title>
		<link>http://znx.no/2009/08/microsoft-business-productivity-racism/</link>
		<comments>http://znx.no/2009/08/microsoft-business-productivity-racism/#comments</comments>
		<pubDate>Tue, 25 Aug 2009 21:50:05 +0000</pubDate>
		<dc:creator>znx</dc:creator>
				<category><![CDATA[General]]></category>
		<category><![CDATA[Windows]]></category>
		<category><![CDATA[funny]]></category>
		<category><![CDATA[ms]]></category>
		<category><![CDATA[web]]></category>

		<guid isPermaLink="false">http://znx.no/?p=152</guid>
		<description><![CDATA[I was recently pointed to the English and Polish pages for the MS Business Productivity. The most striking thing about the difference between the pages is that one depicts a white individual in place of a black individual. What could be the purpose of altering the image, surely it isn&#8217;t racism, after all the Chinese [...]]]></description>
			<content:encoded><![CDATA[<p>I was recently pointed to the <a href='http://www.microsoft.com/businessproductivity/default.mspx'>English</a> and <a href='http://www.microsoft.com/poland/businessproductivity/default.mspx'>Polish</a> pages for the MS Business Productivity. The most striking thing about the difference between the pages is that one depicts a white individual in place of a black individual. What could be the purpose of altering the image, surely it isn&#8217;t racism, after all the Chinese individual is still in place.</p>
<p>Strange what goes through the brain of MS Business Productivity.</p>
<div id="attachment_153" class="wp-caption alignleft" style="width: 309px"><img class="size-full wp-image-153 " title="ms-diff1" src="http://znx.no/i/2009/08/ms-diff1.png" alt="Polish Alternative" width="299" height="158" /><p class="wp-caption-text">Polish Alternative</p></div>
<div id="attachment_154" class="wp-caption alignright" style="width: 310px"><img class="size-medium wp-image-154 " title="ms-diff2" src="http://znx.no/i/2009/08/ms-diff2-300x153.png" alt="English Alternative" width="300" height="153" /><p class="wp-caption-text">English Alternative</p></div>
]]></content:encoded>
			<wfw:commentRss>http://znx.no/2009/08/microsoft-business-productivity-racism/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>BigBrother Scripting</title>
		<link>http://znx.no/2009/03/bigbrother-scripting/</link>
		<comments>http://znx.no/2009/03/bigbrother-scripting/#comments</comments>
		<pubDate>Tue, 17 Mar 2009 22:40:13 +0000</pubDate>
		<dc:creator>znx</dc:creator>
				<category><![CDATA[Scripts]]></category>
		<category><![CDATA[Windows]]></category>
		<category><![CDATA[ms]]></category>
		<category><![CDATA[vbs]]></category>

		<guid isPermaLink="false">http://znx.no/?p=108</guid>
		<description><![CDATA[I was recently asked if it was possible to monitor the Event Log for a single event and ensure that it was occurring regularly. It is rare that I handle Windows scripting and when I do I normally find myself cursing it, haha! In this case we want to ensure that a print server is [...]]]></description>
			<content:encoded><![CDATA[<p>I was recently asked if it was possible to monitor the Event Log for a single event and ensure that it was occurring regularly. It is rare that I handle Windows scripting and when I do I normally find myself cursing it, haha! In this case we want to ensure that a print server is constantly printing through the day, we expect that at least 1 print job will occur every 15 minutes, if not then we&#8217;d like a warning. Obviously this check should only run during work hours.</p>
<p>So the first step is relatively simple, access the Event Log and look for a single event by its event code.</p>

<div class="wp_syntax"><div class="code"><pre class="vb" style="font-family:monospace;"><span style="color: #000080;">set</span> objWMIService = GetObject(<span style="color: #800000;">&quot;winmgmts:\root\cimv2&quot;</span>)
<span style="color: #000080;">set</span> colEvents = objWMIService.ExecQuery _
   (<span style="color: #800000;">&quot;Select * from Win32_NTLogEvent Where Logfile = 'System' and EventCode = 10&quot;</span>)</pre></div></div>

<p>What we did here was grab all the events with event code of 10 (a print job!). So if we count the number of events within a range then we will have basically completed a huge part of the work.</p>
<p>So next step is to make an interval that will be 15 minutes back from whatever time is current.</p>

<div class="wp_syntax"><div class="code"><pre class="vb" style="font-family:monospace;"><span style="color: #000080;">set</span> dtmStartDate = CreateObject(<span style="color: #800000;">&quot;WbemScripting.SWbemDateTime&quot;</span>)
dtmStartDate.SetVarDate DateAdd(<span style="color: #800000;">&quot;n&quot;</span>,-15,Now()),<span style="color: #000080;">True</span></pre></div></div>

<p>And applying that into our statement:</p>

<div class="wp_syntax"><div class="code"><pre class="vb" style="font-family:monospace;"><span style="color: #000080;">set</span> colEvents = objWMIService.ExecQuery _
   (<span style="color: #800000;">&quot;Select * from Win32_NTLogEvent Where Logfile = 'System' and EventCode = 10&quot;</span> _
   &amp;amp; <span style="color: #800000;">&quot; and TimeWritten &amp;gt;= '&quot;</span> &amp;amp; dtmStartDate &amp;amp; <span style="color: #800000;">&quot;'&quot;</span>)</pre></div></div>

<p>This means that we are now collecting the events that only occurred within the last fifteen minutes. So what next, well we need to have a statement to pass to BigBrother to indicate success or failure. Fortunately enough I have another script which monitors the cluster (thanks to the awesome DeadCat repository) and it has some code to help place the file that BigBrother collects.</p>

<div class="wp_syntax"><div class="code"><pre class="vb" style="font-family:monospace;"><span style="color: #000080;">const</span> HKLM = &amp;amp;H80000002
strBBExtPathNew = <span style="color: #800000;">&quot;SOFTWARE\Quest Software\BigBrother\bbnt\ExternalPath&quot;</span>
strBBExtPathOld = <span style="color: #800000;">&quot;SOFTWARE\BigBrother\bbnt\ExternalPath&quot;</span>
<span style="color: #000080;">set</span> oReg = GetObject(<span style="color: #800000;">&quot;winmgmts:\root\default:StdRegProv&quot;</span>)
&nbsp;
oReg.GetStringValue HKLM,strBBExtPathNew,,strExtPath
<span style="color: #000080;">if</span> isNull(strExtPath) <span style="color: #000080;">then</span>
  oReg.GetStringValue HKLM,strBBExtPathOld,,strExtPath
<span style="color: #000080;">end</span> <span style="color: #000080;">if</span>
<span style="color: #000080;">if</span> isNull(strExtPath) <span style="color: #000080;">then</span>
  WScript.Quit
<span style="color: #000080;">end</span> <span style="color: #000080;">if</span></pre></div></div>

<p><span id="more-108"></span>So now we have the path to put our file in, all we need to do now is write the file and add two simple checks to see that the time is within work ours (9-5).</p>

<div class="wp_syntax"><div class="code"><pre class="vb" style="font-family:monospace;"><span style="color: #000080;">On</span> <span style="color: #000080;">Error</span> <span style="color: #000080;">Resume</span> <span style="color: #000080;">Next</span>
&nbsp;
strState = <span style="color: #800000;">&quot;green Printing was active within the last 15 minutes&quot;</span>
strBBFileName = <span style="color: #800000;">&quot;print&quot;</span>
intEventCode = 10
&nbsp;
<span style="color: #008000;">' Find out where to put the BB log files
</span><span style="color: #000080;">const</span> HKLM = &amp;amp;H80000002
strBBExtPathNew = <span style="color: #800000;">&quot;SOFTWARE\Quest Software\BigBrother\bbnt\ExternalPath&quot;</span>
strBBExtPathOld = <span style="color: #800000;">&quot;SOFTWARE\BigBrother\bbnt\ExternalPath&quot;</span>
<span style="color: #000080;">set</span> oReg = GetObject(<span style="color: #800000;">&quot;winmgmts:\root\default:StdRegProv&quot;</span>)
&nbsp;
<span style="color: #008000;">' Check for the BB External Path, new then old otherwise quit
</span>oReg.GetStringValue HKLM,strBBExtPathNew,,strExtPath
<span style="color: #000080;">if</span> isNull(strExtPath) <span style="color: #000080;">then</span>
  oReg.GetStringValue HKLM,strBBExtPathOld,,strExtPath
<span style="color: #000080;">end</span> <span style="color: #000080;">if</span>
<span style="color: #000080;">if</span> isNull(strExtPath) <span style="color: #000080;">then</span>
  WScript.Quit
<span style="color: #000080;">end</span> <span style="color: #000080;">if</span>
&nbsp;
<span style="color: #008000;">' Get Computer name
</span><span style="color: #000080;">set</span> WshNetwork = WScript.CreateObject(<span style="color: #800000;">&quot;WScript.Network&quot;</span>)
strComputerName = WshNetwork
&nbsp;
<span style="color: #008000;">' Prepare file
</span><span style="color: #000080;">set</span> fso = CreateObject(<span style="color: #800000;">&quot;Scripting.FileSystemObject&quot;</span>)
<span style="color: #000080;">set</span> f = fso.OpenTextFile(strExtPath &amp;amp; <span style="color: #800000;">&quot;\&quot;</span> &amp;amp; strBBFileName, 8, <span style="color: #000080;">True</span>)
&nbsp;
<span style="color: #008000;">' Run between 9 - 5
</span><span style="color: #000080;">if</span> Hour(Now()) &amp;lt; 9 <span style="color: #000080;">then</span>
  strState = <span style="color: #800000;">&quot;green Not checking as we are outwith work hours&quot;</span>
  f.Write strState
  <span style="color: #000080;">set</span> fso = <span style="color: #000080;">Nothing</span>
  <span style="color: #000080;">set</span> f = <span style="color: #000080;">Nothing</span>
  WScript.Quit
<span style="color: #000080;">end</span> <span style="color: #000080;">if</span>
<span style="color: #000080;">if</span> Hour(Now()) &amp;gt; 17 <span style="color: #000080;">then</span>
  strState = <span style="color: #800000;">&quot;green Not checking as we are outwith work hours&quot;</span>
  f.Write strState
  <span style="color: #000080;">set</span> fso = <span style="color: #000080;">Nothing</span>
  <span style="color: #000080;">set</span> f = <span style="color: #000080;">Nothing</span>
  WScript.Quit
<span style="color: #000080;">end</span> <span style="color: #000080;">if</span>
&nbsp;
<span style="color: #008000;">' Get a date 15 minutes in the past.
</span><span style="color: #000080;">set</span> dtmStartDate = CreateObject(<span style="color: #800000;">&quot;WbemScripting.SWbemDateTime&quot;</span>)
dtmStartDate.SetVarDate DateAdd(<span style="color: #800000;">&quot;n&quot;</span>,-15,Now()),<span style="color: #000080;">True</span>
&nbsp;
<span style="color: #008000;">' Collect the events from eventlog within the last 15 minutes
</span><span style="color: #000080;">set</span> objWMIService = GetObject(<span style="color: #800000;">&quot;winmgmts:\root\cimv2&quot;</span>)
<span style="color: #000080;">Set</span> colEvents = objWMIService.ExecQuery _
   (<span style="color: #800000;">&quot;Select * from Win32_NTLogEvent Where Logfile = 'System' and &quot;</span> _
   &amp;amp; <span style="color: #800000;">&quot;EventCode = '&quot;</span> &amp;amp; intEventCode _
   &amp;amp; <span style="color: #800000;">&quot;' and TimeWritten &amp;gt;= '&quot;</span> &amp;amp; dtmStartDate &amp;amp; <span style="color: #800000;">&quot;'&quot;</span>)
&nbsp;
<span style="color: #008000;">' If no events then alert.
</span><span style="color: #000080;">if</span> colEvents.Count = 0 <span style="color: #000080;">then</span>
  strState = <span style="color: #800000;">&quot;red No print job within the last 15 minutes&quot;</span>
<span style="color: #000080;">end</span> <span style="color: #000080;">if</span>
&nbsp;
<span style="color: #008000;">' Output
</span>f.Write strState
&nbsp;
<span style="color: #000080;">set</span> fso = <span style="color: #000080;">Nothing</span>
<span style="color: #000080;">set</span> f = <span style="color: #000080;">Nothing</span>
WScript.Quit</pre></div></div>

<p>Obviously you can adjust this script to monitor for any regular event and it works well on Windows 2003 and XP machines. It is at this point I thought that I was finished. Testing this script on a Windows XP machine, no issues it was doing exactly what it was meant to. However the server I was intending on running it under was a Windows 2000 server. So I was forced to make some more changes to the script to allow it to run. The changes I made unfortunately make the script slightly harder to adjust to make it work for any event.</p>
<p>The first change was to the statement to collect the print job.</p>

<div class="wp_syntax"><div class="code"><pre class="vb" style="font-family:monospace;"><span style="color: #000080;">Set</span> colEvents = objWMIService.ExecQuery _
  (<span style="color: #800000;">&quot;Select * From Win32_NTLogEvent Where Type = 'information' &quot;</span> _
  &amp; <span style="color: #800000;">&quot;and EventCode = &quot;</span> &amp; intEventCode _
  &amp; <span style="color: #800000;">&quot;TimeWritten &gt;= '&quot;</span> &amp; dtmStartDate &amp; <span style="color: #800000;">&quot;'&quot;</span>)</pre></div></div>

<p>The next change I had to make was very strange, the Count method didn&#8217;t seem to exist (strange!?) so I was forced to loop to count:</p>

<div class="wp_syntax"><div class="code"><pre class="vb" style="font-family:monospace;"><span style="color: #008000;">' UGLY
</span><span style="color: #000080;">set</span> intCount = 0
<span style="color: #000080;">For</span> <span style="color: #000080;">Each</span> objEvent <span style="color: #000080;">in</span> colEvents
  intCount = intCount + 1
<span style="color: #000080;">Next</span>
<span style="color: #000080;">if</span> intCount = 0 <span style="color: #000080;">then</span>
  strState = <span style="color: #800000;">&quot;red No print job within the last 15 minutes&quot;</span>
<span style="color: #000080;">end</span> <span style="color: #000080;">if</span></pre></div></div>

<p>Those two changes allowed me to successfully monitor a single event. Same script in Linux would have taken me seconds! Anyway at least its a working model, let&#8217;s hope not a lot more requests come through for Windows issues, especially W2K ones!</p>
]]></content:encoded>
			<wfw:commentRss>http://znx.no/2009/03/bigbrother-scripting/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Better E-Mail Checking!</title>
		<link>http://znx.no/2008/12/better-e-mail-checking/</link>
		<comments>http://znx.no/2008/12/better-e-mail-checking/#comments</comments>
		<pubDate>Wed, 17 Dec 2008 23:12:18 +0000</pubDate>
		<dc:creator>znx</dc:creator>
				<category><![CDATA[Scripts]]></category>
		<category><![CDATA[exchange]]></category>
		<category><![CDATA[ms]]></category>

		<guid isPermaLink="false">http://znx.no/?p=60</guid>
		<description><![CDATA[A mate of mine was reading this and made some great comments about it! First up there is a Bash version of expect (THANK GOD!). Secondly fetchmail maybe a better solution to grabbing the mail to see if it was received, another good comment! Unfortunately for me I was working on a system with the [...]]]></description>
			<content:encoded><![CDATA[<p>A <a title="Dustybin" href="http://www.thinkdebian.org/">mate of mine</a> was reading this and made some great comments about it! First up there is a Bash version of <a title="BASH Version of Expect" href="http://empty.sourceforge.net">expect</a> (THANK GOD!). Secondly fetchmail maybe a better solution to grabbing the mail to see if it was received, another good comment! Unfortunately for me I was working on a system with the tools that were available to me, that means no fetchmail and no empty installed.</p>
<p>Interestingly it didn&#8217;t initially work 100% of the time, after a little bit of testing it looked like Microsoft were temporarily throwing away some of the test e-mails. Interesting as it must mean that they look for repetitious e-mails in a bid to fight SPAM. We of course simply contacted MS and got it sorted and now the e-mails come in every hour.</p>
<p>What this does show us though, is that under UNIX/Linux there is a lot of different solutions that can be made, but sometimes you have to work with the tools that are there.</p>
]]></content:encoded>
			<wfw:commentRss>http://znx.no/2008/12/better-e-mail-checking/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>E-Mail Checking</title>
		<link>http://znx.no/2008/12/e-mail-checking/</link>
		<comments>http://znx.no/2008/12/e-mail-checking/#comments</comments>
		<pubDate>Thu, 04 Dec 2008 22:11:31 +0000</pubDate>
		<dc:creator>znx</dc:creator>
				<category><![CDATA[Scripts]]></category>
		<category><![CDATA[exchange]]></category>
		<category><![CDATA[ms]]></category>

		<guid isPermaLink="false">http://znx.no/?p=55</guid>
		<description><![CDATA[At my work we have two domains and recently one of those domains was blacklisted, thanks to some phishing e-mails hitting their marks. So I was tasked today to setup an automated e-mail send and check. To ensure that we can send between our domains. First up I checked to see that I was able [...]]]></description>
			<content:encoded><![CDATA[<p>At my work we have two domains and recently one of those domains was blacklisted, thanks to some phishing e-mails hitting their marks. So I was tasked today to setup an automated e-mail send and check. To ensure that we can send between our domains.</p>
<p>First up I checked to see that I was able to get a POP3 connection to the other domain, as it is hosted by Microsoft for us. Whilst I was able to connect via POP3 I was unable to login. A quick check revealed that only POP3S was being accepted. This meant that I was going to need to utilize the simple s_client tool available with OpenSSL.</p>
<p>So to testing:</p>

<div class="wp_syntax"><div class="code"><pre class="bash" style="font-family:monospace;">$ openssl s_client <span style="color: #660033;">-connect</span> SERVER:<span style="color: #000000;">995</span>
.... blah blah ....
+OK The POP3 Service is ready.
USER test.user<span style="color: #000000; font-weight: bold;">@</span>example.com
^C
$</pre></div></div>

<p>Hrmm, what&#8217;s going on here, the server isn&#8217;t responding to my USER. A quick brain check and I spotted my issue, line endings!</p>

<div class="wp_syntax"><div class="code"><pre class="bash" style="font-family:monospace;">$ openssl s_client <span style="color: #660033;">-connect</span> SERVER:<span style="color: #000000;">995</span> <span style="color: #660033;">-crlf</span>
.... blah blah ....
+OK The POP3 Service is ready.
USER test.user<span style="color: #000000; font-weight: bold;">@</span>example.com
+OK
PASS mypassword
+OK User successfully logged in.
STAT
+OK <span style="color: #000000;">49</span> <span style="color: #000000;">2758446</span>
QUIT
DONE</pre></div></div>

<p>That&#8217;s more like it. Now I know that I can connect, logged and run arbitrary commands. It may be perfectly OK to manually check like this but that isn&#8217;t the reason we started this, we want an automated solution.</p>
<p>The most obvious solution here is <strong>expect</strong>, ugh TCL! With the above information it is easy to write a simple expect script:</p>

<div class="wp_syntax"><div class="code"><pre class="tcl" style="font-family:monospace;"><span style="color: #808080; font-style: italic;">#!/usr/bin/env expect</span>
spawn openssl s_client -connect SERVER:<span style="color: #ff4500;">995</span> -crlf
expect <span style="color: #483d8b;">&quot;+OK The POP3 service is ready.&quot;</span>
send <span style="color: #483d8b;">&quot;USER test.user@example.com<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;+OK&quot;</span>
send <span style="color: #483d8b;">&quot;PASS mypassword<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;+OK User successfully logged on.&quot;</span>
send <span style="color: #483d8b;">&quot;QUIT<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;DONE&quot;</span>
expect <span style="color: #008000;">eof</span></pre></div></div>

<p>Simple enough, send a command and expect a response. Obviously it helps if you understand the protocol that you are dealing with. Running that script happily logs in and then quits. Sweet, we are halfway there already!</p>
<p>So to recap, I plan on sending an e-mail from the first domain to my test account on the second domain and then check that the e-mail actually arrived. Thus proving that the e-mail was getting through without issue. So when I do this I will wish to get the newest e-mail in my INBOX, which may not the be the first. So the script needs some modifying.</p>

<div class="wp_syntax"><div class="code"><pre class="tcl" style="font-family:monospace;"><span style="color: #808080; font-style: italic;">#!/usr/bin/env expect</span>
spawn openssl s_client -connect SERVER:<span style="color: #ff4500;">995</span> -crlf
expect <span style="color: #483d8b;">&quot;+OK The POP3 service is ready.&quot;</span>
send <span style="color: #483d8b;">&quot;USER test.user@example.com<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;+OK&quot;</span>
send <span style="color: #483d8b;">&quot;PASS mypassword<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;+OK User successfully logged on.&quot;</span>
send <span style="color: #483d8b;">&quot;STAT<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect -re <span style="color: #483d8b;">&quot;OK (.*) .*&quot;</span> <span style="color: black;">&#123;</span>
  <span style="color: #ff7700;font-weight:bold;">set</span> number <span style="color: #ff3333;">$expect_out</span><span style="color: black;">&#40;</span><span style="color: #ff4500;">1</span>,<span style="color: #008000;">string</span><span style="color: black;">&#41;</span>
<span style="color: black;">&#125;</span>
send <span style="color: #483d8b;">&quot;TOP $number 1<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;<span style="color: #000099; font-weight: bold;">\.</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;+OK&quot;</span>
send <span style="color: #483d8b;">&quot;QUIT<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;DONE&quot;</span>
expect <span style="color: #008000;">eof</span></pre></div></div>

<p>Now expect will grab the number of e-mails in the INBOX and request the headers of the newest one. So the final step is integrating this with a simple check. Lets just use a shell script to check with:</p>

<div class="wp_syntax"><div class="code"><pre class="bash" style="font-family:monospace;"><span style="color: #666666; font-style: italic;">#!/bin/sh</span>
<span style="color: #007800;">TS</span>=<span style="color: #000000; font-weight: bold;">`</span><span style="color: #c20cb9; font-weight: bold;">date</span> +<span style="color: #000000; font-weight: bold;">%</span>s<span style="color: #000000; font-weight: bold;">`</span>
<span style="color: #7a0874; font-weight: bold;">echo</span> <span style="color: #ff0000;">&quot;Subject: TESTING <span style="color: #007800;">$TS</span>
&nbsp;
Hi,
&nbsp;
This is a test please do not delete me!
&nbsp;
Thanks&quot;</span> <span style="color: #000000; font-weight: bold;">|</span> mail test.user<span style="color: #000000; font-weight: bold;">@</span>example.com
<span style="color: #c20cb9; font-weight: bold;">sleep</span> <span style="color: #000000;">60</span>
expect collect.exp <span style="color: #000000; font-weight: bold;">|</span> <span style="color: #c20cb9; font-weight: bold;">grep</span> <span style="color: #007800;">$TS</span> <span style="color: #000000; font-weight: bold;">&amp;&amp;</span> \
 <span style="color: #7a0874; font-weight: bold;">echo</span> <span style="color: #ff0000;">&quot;Success The E-Mail Arrived!&quot;</span> <span style="color: #000000; font-weight: bold;">||</span>\
 <span style="color: #7a0874; font-weight: bold;">echo</span> <span style="color: #ff0000;">&quot;Failure The E-Mail Was Not Found!&quot;</span></pre></div></div>

<p>That works, a test and we have a success! We find the TS in the subject line of the e-mail. There is a minor problem here, what happens if I e-mail the test and in-between I receive some other e-mails, hrmm! OK so why don&#8217;t we dump the headers of the first few e-mails, we certainly don&#8217;t expect a rush of e-mails on a test account within a minute. Let&#8217;s change the expect script just a bit more:</p>

<div class="wp_syntax"><div class="code"><pre class="tcl" style="font-family:monospace;"><span style="color: #808080; font-style: italic;">#!/usr/bin/env expect</span>
&nbsp;
spawn openssl s_client -connect SERVER:<span style="color: #ff4500;">995</span> -crlf
expect <span style="color: #483d8b;">&quot;+OK The POP3 service is ready.&quot;</span>
send <span style="color: #483d8b;">&quot;USER test.user@example.com<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;+OK&quot;</span>
send <span style="color: #483d8b;">&quot;PASS mypassword<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;+OK User successfully logged on.&quot;</span>
send <span style="color: #483d8b;">&quot;STAT<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect -re <span style="color: #483d8b;">&quot;OK (.*) .*&quot;</span> <span style="color: black;">&#123;</span>
  <span style="color: #ff7700;font-weight:bold;">set</span> number <span style="color: #ff3333;">$expect_out</span><span style="color: black;">&#40;</span><span style="color: #ff4500;">1</span>,<span style="color: #008000;">string</span><span style="color: black;">&#41;</span>
<span style="color: black;">&#125;</span>
send <span style="color: #483d8b;">&quot;TOP $number 1<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;<span style="color: #000099; font-weight: bold;">\.</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;+OK&quot;</span>
<span style="color: #ff7700;font-weight:bold;">set</span> number <span style="color: black;">&#91;</span><span style="color: #ff7700;font-weight:bold;">expr</span> <span style="color: #ff3333;">$number</span>-<span style="color: #ff4500;">1</span><span style="color: black;">&#93;</span>
send <span style="color: #483d8b;">&quot;TOP $number 1<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;<span style="color: #000099; font-weight: bold;">\.</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;+OK&quot;</span>
<span style="color: #ff7700;font-weight:bold;">set</span> number <span style="color: black;">&#91;</span><span style="color: #ff7700;font-weight:bold;">expr</span> <span style="color: #ff3333;">$number</span>-<span style="color: #ff4500;">1</span><span style="color: black;">&#93;</span>
send <span style="color: #483d8b;">&quot;TOP $number 1<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;<span style="color: #000099; font-weight: bold;">\.</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;+OK&quot;</span>
send <span style="color: #483d8b;">&quot;QUIT<span style="color: #000099; font-weight: bold;">\r</span>&quot;</span>
expect <span style="color: #483d8b;">&quot;DONE&quot;</span>
expect <span style="color: #008000;">eof</span></pre></div></div>

<p>Placing the shell script into a crontab and we are done. Yet another example of how simple scripting can achieve anything.</p>
]]></content:encoded>
			<wfw:commentRss>http://znx.no/2008/12/e-mail-checking/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>WinXP on VMware</title>
		<link>http://znx.no/2008/09/winxp-on-vmware/</link>
		<comments>http://znx.no/2008/09/winxp-on-vmware/#comments</comments>
		<pubDate>Tue, 09 Sep 2008 16:26:52 +0000</pubDate>
		<dc:creator>znx</dc:creator>
				<category><![CDATA[Windows]]></category>
		<category><![CDATA[install]]></category>
		<category><![CDATA[ms]]></category>
		<category><![CDATA[vmware]]></category>

		<guid isPermaLink="false">http://znx.no/?p=24</guid>
		<description><![CDATA[So I recently showed you how easy it was to install VMware under Redhat. Now lets look at how easy it is to install Windows XP as a guest OS. First you will need to get a hold of your Windows XP CD ready for the installation, put it into the CD-Rom. Open up the [...]]]></description>
			<content:encoded><![CDATA[<p>So I recently showed you how easy it was to install VMware under Redhat. Now lets look at how easy it is to install Windows XP as a guest OS.</p>
<p>First you will need to get a hold of your Windows XP CD ready for the installation, put it into the CD-Rom.</p>
<p>Open up the VMware console and select <strong>File &gt; New &gt; Virtual Machine</strong>. This will open us the Wizard that will walk us through the installation. Click <strong>Next</strong> and then select <strong>Typical</strong> and again click <strong>Next</strong>. Select Windows XP from the list of operating systems available, you can normally leave the location as its default but remember that you need at least 8Gb (the default) per guest OS that you are installing. I normally choose a bridged network setup, with most network layouts now there is a DHCP server and its easy to add another IP to your network. You can however set it to share its IP with the host system. As you go through the next steps, selecting the defaults is normally good enough. You can tweak if you wish but I am happy to settle for the defaults. </p>
<p>Once all that is complete it will make 8Gb of space available for your install. At this point you can start the guest system and it will then boot from the Windows CD. Continue as normal through the Windows install and you should wind up with a Windows XP installation.</p>
<p>Once it is all up and running I do highly suggest that you install VMware Tools, available by doing <strong>VM &gt; VMware Tools</strong>. The installer should then pop up and start. You should see the VMware icon in the lower corner by the clock.</p>
<p>Poke around and have fun. All the other OS installs are carried out in much the same manner.</p>
<p>That&#8217;s it, a working XP guest installation!</p>
]]></content:encoded>
			<wfw:commentRss>http://znx.no/2008/09/winxp-on-vmware/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Exchange Restores</title>
		<link>http://znx.no/2008/09/exchange-restores/</link>
		<comments>http://znx.no/2008/09/exchange-restores/#comments</comments>
		<pubDate>Thu, 04 Sep 2008 15:16:44 +0000</pubDate>
		<dc:creator>znx</dc:creator>
				<category><![CDATA[Windows]]></category>
		<category><![CDATA[exchange]]></category>
		<category><![CDATA[ms]]></category>
		<category><![CDATA[rant]]></category>

		<guid isPermaLink="false">http://znx.no/?p=7</guid>
		<description><![CDATA[Exchange is a massive enterprise tool and as such you&#8217;d expect it to provide a simple method for restoring mail folders. No such luck! Instead a restore on exchange is quite a long process. First up you need to discover the storage group that your mailbox is in. This requires a quick search on an [...]]]></description>
			<content:encoded><![CDATA[<p>Exchange is a massive enterprise tool and as such you&#8217;d expect it to provide a simple method for restoring mail folders. No such luck! Instead a restore on exchange is quite a long process.</p>
<p>First up you need to discover the storage group that your mailbox is in. This requires a quick search on an active directory server. Once you have that you can go on to create a &#8216;recovery storage group&#8217; linking it to the correct storage group.</p>
<p>Then you start up your TSM restore and recover the storage group (we use TSM as our backup). On our setup that means that you are restoring approximately 20Gb of data. Once thats done (it can take a while), we can then mount the recovery group. At this point we are left with one of two options: copy all the mail and folders into your existing mail account effectively doubling your mail, or you can merge the contents back into your mail so only copying what is missing.</p>
<p>My issue is that neither of these options are really what a use wants. If we copy the mail back, then we effectively double the amount of mail that a user has. If we merge the data back, it can merge e-mails back into folders that maybe the user will not look at, thus leaving behind stray meant-to-be-deleted e-mails. Nine times out of ten all the user has lost is a single folder or a single mail.</p>
<p>The solution to this is to add another step into the process, extract the mailbox from the recovery group into a PST file, then merge the folder out of the PST file back into the mailbox in the main storage group. But even here there is a problem, if you don&#8217;t know the exact folder name you can&#8217;t find out what it is and therefore cannot restore it.</p>
<p>In reality what is needed here is a solution that allows the administrators the ability to extract individual folders within a mailbox. It is obvious that the exchange restores are built with the intent of only being used in a situation of disaster, total loss of a storage group or something similar. However almost all the restores undertaken will be for single users.</p>
<p>Looking back to the old method we used with exim makes this look even more silly. As there we could simply find the file representing the mail folder and restore it. Done!</p>
]]></content:encoded>
			<wfw:commentRss>http://znx.no/2008/09/exchange-restores/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
