<?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"
	>

<channel>
	<title>davidb dives in</title>
	<atom:link href="http://blacka.com/david/feed/" rel="self" type="application/rss+xml" />
	<link>http://blacka.com/david</link>
	<description>various musings and babblings.</description>
	<pubDate>Sun, 03 Aug 2008 17:25:38 +0000</pubDate>
	<generator>http://wordpress.org/?v=2.6</generator>
	<language>en</language>
			<item>
		<title>I has iPhone</title>
		<link>http://blacka.com/david/archives/2008/08/i-has-iphone/</link>
		<comments>http://blacka.com/david/archives/2008/08/i-has-iphone/#comments</comments>
		<pubDate>Sun, 03 Aug 2008 17:25:38 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[General]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2008/08/i-has-iphone/</guid>
		<description><![CDATA[After a mere 2.5 hour wait in line, assisted by jet-lag, I have acquired the 3G iPhone.  More later.
]]></description>
			<content:encoded><![CDATA[<p>After a mere 2.5 hour wait in line, assisted by jet-lag, I have acquired the 3G iPhone.  More later.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2008/08/i-has-iphone/feed/</wfw:commentRss>
		</item>
		<item>
		<title>python-rwhoisd</title>
		<link>http://blacka.com/david/archives/2008/06/python-rwhoisd/</link>
		<comments>http://blacka.com/david/archives/2008/06/python-rwhoisd/#comments</comments>
		<pubDate>Sat, 21 Jun 2008 22:28:37 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[General]]></category>

		<guid isPermaLink="false">http://blacka.com/david/?p=75</guid>
		<description><![CDATA[Back in 2003, as an exercise to help me learn Python, I wrote python-rwhoisd.  Why an RWhois server?  I had been the main developer and sole maintainer of the C reference version since 1996, and I had been thinking about writing a replacement in a nicer language ever since.  So I pretty [...]]]></description>
			<content:encoded><![CDATA[<p>Back in 2003, as an exercise to help me learn <a href="http://python.org">Python</a>, I wrote <a href="http://blacka.com/software/python-rwhoisd">python-rwhoisd</a>.  Why an <a href="http://www.rwhois.net">RWhois</a> server?  I had been the main developer and sole maintainer of the<a href="http://http://www.rwhois.net/#Downloads"> C reference version</a> since 1996, and I had been thinking about writing a replacement in a nicer language ever since.  So I pretty familiar with the protocol and problem space, and it was complicated enough to be able to sink your teeth into it, yet not so hard that you couldn&#8217;t do it fairly quickly.  Basically, a great learning project.</p>

<p>Back then, I wanted this project to be unquestionably <em>mine</em>.  I was paranoid enough to believe that if I used any of my employer&#8217;s equipment, network access, or time that my employer might claim ownership.  Why they would want to is anyone&#8217;s guess.</p>

<p>So I was very careful to only work on python-rwhoisd at home, on my own time, on my own equipment.  The initial version took me two weeks of nights and weekends.  Hm.  That makes it sound like I was furiously coding into the wee hours.  I was actually only spending a few hours each day on it.</p>

<p>Python was a joy to use.  My day job was in Java (and Perl) and it felt extremely liberating to be able to write so much code with so little typing.  My favorite part was discovering that as I learned more about Python, my code kept getting smaller without getting less readable.  Amazing!</p>

<p>Even though I had basically just written python-rwhoisd to learn a new programming language, I was planning on releasing it.  I didn&#8217;t think that many folks would want it.  RWhois wasn&#8217;t (and still isn&#8217;t) a popular protocol.  But some of my colleagues were evangelizing <a href="http://http://www.ietf.org/rfc/rfc3981.txt">IRIS</a> at the time, and urged me to not release.  They thought that it would muddy the waters, so to speak.  So I didn&#8217;t release it, and then I basically forgot about it.</p>

<p>Fast forward five years.  Just two weeks ago I suddenly wanted to learn how to use <a href="http://git.or.cz">Git</a>.  I played around with tutorial-like git repositories, but it wasn&#8217;t enough.  I needed something real to work on.  I was casting about for a project that I could use, and I ran across python-rwhoisd, mouldering in a local CVS repository.</p>

<p>I had things that I thought should be improved about python-rwhoisd before attempting to release it again.  The main thing was to add IPv6 indexing support, which I had done for the C version several years before.  While this wasn&#8217;t a perfect project for learning Git in all of its glory (for that, I would need collaborators to merge with), it was good enough.  Several days later, I&#8217;d added the IPv6 indexing and search support, and it was time to <a href="http://lists.verisignlabs.com/pipermail/rwhois/2008-June/002232.html">release it</a>.</p>

<p>While I don&#8217;t expect there to be any major outpouring of interest over python-rwhoisd, it still should be easier to run than the C version (at least, for small datasets), and it should be possible to get it working on Windows without too much effort.</p>

<p>Get it <a href="http://blacka.com/software/python-rwhoisd">here</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2008/06/python-rwhoisd/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Running UNBOUND at home.</title>
		<link>http://blacka.com/david/archives/2008/05/running-unbound-at-home/</link>
		<comments>http://blacka.com/david/archives/2008/05/running-unbound-at-home/#comments</comments>
		<pubDate>Fri, 30 May 2008 11:59:38 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[DNS]]></category>

		<guid isPermaLink="false">http://blacka.com/david/?p=74</guid>
		<description><![CDATA[I finally got around the setting up unbound as my home resolver.  I should have done this months ago, when it was in beta or before, since I had access to it.  I kick myself.  I feel bad.  Oh well, let&#8217;s get on with it.

My initial impressions:
It will be nice once [...]]]></description>
			<content:encoded><![CDATA[<p>I finally got around the setting up <a href="http://unbound.net">unbound</a> as my home resolver.  I <em>should</em> have done this months ago, when it was in beta or before, since I had access to it.  I kick myself.  I feel bad.  Oh well, let&#8217;s get on with it.</p>

<p>My initial impressions:
<ol><li>It will be nice once there are distribution packages for unbound.  I spent more time that I would like (which is zero) figuring out where to put the log file, pid file, etc.  Of course, I was installing it on a machine running Fedora Core 5&#8230;</li><li>I was forwarding a zone to a nameserver running on localhost:20053.  There is a gotcha to doing this, as, by default unbound won&#8217;t send <em>any</em> queries to localhost.  You have to add a &#8216;do-not-query-localhost: no&#8217; config line to fix it.  Maybe this is something unbound-checkconf could detect?</li><li>unbound&#8217;s configuration defaults leave it locked down fairly tightly.  I had it running, but on my other machines, it seemed so slow &#8212; turns out, my queries were timing out and I was hitting my ISP nameserver.  Make sure you add your networks to the &#8216;access-control:&#8217; config parameters.</li><li>I turned up the logging to debug some of my issues.  Looking at the log was <em>uncanny</em>.</li></ol>Anyway, it didn&#8217;t take all that long to set up.  Hopefully relatively soon I (or someone else) will write up how to configure unbound to run in a few different scenarios.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2008/05/running-unbound-at-home/feed/</wfw:commentRss>
		</item>
		<item>
		<title>wordpress upgrade (2.5)</title>
		<link>http://blacka.com/david/archives/2008/04/wordpress-upgrade-25/</link>
		<comments>http://blacka.com/david/archives/2008/04/wordpress-upgrade-25/#comments</comments>
		<pubDate>Wed, 09 Apr 2008 12:07:29 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[Blogs]]></category>

		<guid isPermaLink="false">http://blacka.com/david/?p=73</guid>
		<description><![CDATA[I realized that I was running a now-ancient version of wordpress, so I upgraded.  It was easy. Yay wordpress 2.5!
]]></description>
			<content:encoded><![CDATA[<p>I realized that I was running a now-ancient version of wordpress, so I upgraded.  It was easy. Yay wordpress 2.5!</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2008/04/wordpress-upgrade-25/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Duke 71, Belmont 70</title>
		<link>http://blacka.com/david/archives/2008/03/duke-71-belmont-70/</link>
		<comments>http://blacka.com/david/archives/2008/03/duke-71-belmont-70/#comments</comments>
		<pubDate>Fri, 21 Mar 2008 01:22:28 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[Fun]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2008/03/duke-71-belmont-70/</guid>
		<description><![CDATA[I feel sick, but not as sick as I could feel.

Update: Duke 67, WVU 73.  Sigh.
]]></description>
			<content:encoded><![CDATA[<p>I feel sick, but not as sick as I could feel.</p>

<p><strong>Update</strong>: Duke 67, WVU 73.  Sigh.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2008/03/duke-71-belmont-70/feed/</wfw:commentRss>
		</item>
		<item>
		<title>RFC 5155</title>
		<link>http://blacka.com/david/archives/2008/03/rfc-5155/</link>
		<comments>http://blacka.com/david/archives/2008/03/rfc-5155/#comments</comments>
		<pubDate>Tue, 11 Mar 2008 13:23:12 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[DNS]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2008/03/rfc-5155/</guid>
		<description><![CDATA[Ben Laurie celebrates the publication of  RFC 5155.  I hadn&#8217;t gotten around to blogging about it, but I&#8217;m also pretty happy that this RFC finally made it out.

Ben says:

It turns out that in general, to prove the nonexistence of a name using NSEC you have to show at most two records, one to [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.links.org">Ben Laurie</a> celebrates the publication of  <a href="http://feeds.feedburner.com/~r/links/ZvUZ/~3/249426532/">RFC 5155</a>.  I hadn&#8217;t gotten around to blogging about it, but I&#8217;m also pretty happy that <a href="http://www.ietf.org/rfc/rfc5155.txt">this RFC</a> finally made it out.</p>

<p>Ben says:</p>

<blockquote>It turns out that in general, to prove the nonexistence of a name using NSEC you have to show at most two records, one to prove the name itself doesn&#8217;t exist, and the other to show that you didn&#8217;t delegate some parent of it. Often the same record can do both.

In NSEC3, it turns out, you have to show at most three records. And if you can understand why, then you understand DNS better than almost anyone else on the planet.</blockquote>

<p>One of the fascinating things about working on NSEC3 was that it forced us to <em>really understand</em> how existence in DNS works.  Basically, we had to develop the general form of the theory when we already had a special case (in NSEC).  So, after we figured out how NSEC3 had to work, we actually knew more about how NSEC worked.</p>

<p>For me and our co-editor Roy, this RFC culminates the 2nd round of working on the some of the problems that NSEC3 solves.  The first effort was &#8220;DNSSEC Opt-In&#8221;, now published as an experimental RFC, <a href="http://www.ietf.org/rfc/rfc4956.txt">RFC 4956</a>.  (That effort was also tied up in DNS minutiae and political wrangling and ultimately failed to make the IETF standards track).  For us, it feels more like the culmination of 7 years of work.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2008/03/rfc-5155/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Internet Draft Ideas (DNS related)</title>
		<link>http://blacka.com/david/archives/2008/03/internet-draft-ideas-dns-related/</link>
		<comments>http://blacka.com/david/archives/2008/03/internet-draft-ideas-dns-related/#comments</comments>
		<pubDate>Mon, 10 Mar 2008 04:07:29 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[DNS]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2008/03/internet-draft-ideas-dns-related/</guid>
		<description><![CDATA[I&#8217;m at the IETF this week, and so I get to turn my brain to thinking about IETF-y things, like Internet Drafts that I think should (and could) be written.

Idea #1: Cache Poisoning Resilience

This would be a draft that describes steps beyond RFC 2181 that a resolver must do to protect itself from cache poisoning. [...]]]></description>
			<content:encoded><![CDATA[<p>I&#8217;m at the IETF this week, and so I get to turn my brain to thinking about IETF-y things, like Internet Drafts that I think should (and could) be written.</p>

<p><span style="text-decoration:underline;"><strong>Idea #1: Cache Poisoning Resilience</strong></span></p>

<p>This would be a draft that describes steps beyond <a href="http://www.ietf.org/rfc/rfc2181.txt">RFC 2181</a> that a resolver must do to protect itself from cache poisoning.  (RFC 2181 addresses this problem by introducing credibility rules in section 5.4.1.)  Modern caching resolvers need to do more to protect themselves from name poisoning attacks like malicious CNAME chains.  I would expect this draft to be able to lay out a few simple rules like:</p>

<ul><li>Discard any RRs in a response that are &#8220;irrelevant&#8221; (i.e., answer RRs that do not match qname/sname, addtional RRs that don&#8217;t match names in the RDATA of answer and authority RRs, etc.)</li><li>Discard any RRs in a response that are not at or below the queried zone.</li></ul>

<p><span style="text-decoration:underline;"><strong>Idea #2: Authoritative Servers Should Not Chase CNAMEs</strong></span></p>

<p>This is a draft discouraging authoritative servers from chasing CNAMEs out-of-zone (or, optionally, at all), based on conclusions presented in draft idea #1.  This draft could either side-step or confront other possibly controversial things about CNAME processing, like whether or not the authority section should apply the head or the tail of a CNAME chain.</p>

<p><span style="text-decoration:underline;"><strong>Idea #3: DNS Name Compression Standards
</strong></span></p>

<p>A draft mandating the DNS name compression only be done in one direction.  Virtually all (or perhaps even <em>actually</em> all) implementations have DNS compression pointers only pointing to earlier in the message.  This draft would propose that forward-pointing compression pointers should be treated as format errors.  This would accomplish two things:</p>

<ol><li>Simplify what implementers need to support when parsing messages, and</li><li>outlaw any possibility of having to deal with a compression pointer loop. </li></ol>

<p>And, in the process, effectively codify standard practice.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2008/03/internet-draft-ideas-dns-related/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Bachelor Chow</title>
		<link>http://blacka.com/david/archives/2007/12/bachelor-chow/</link>
		<comments>http://blacka.com/david/archives/2007/12/bachelor-chow/#comments</comments>
		<pubDate>Thu, 20 Dec 2007 03:45:17 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[Fun]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2007/12/bachelor-chow/</guid>
		<description><![CDATA[It has been ages since I&#8217;ve blogged, and at least one of my four subscribers reminds me of this regularly.  So, here goes.

I&#8217;ve come home pretty late from work, and I&#8217;m pretty uninspired when it comes to assembling some sort of dinner.  After staring at the fridge fruitlessly for a while, I&#8217;m struck [...]]]></description>
			<content:encoded><![CDATA[<p>It has been ages since I&#8217;ve blogged, and at least one of my four subscribers reminds me of this regularly.  So, here goes.</p>

<p>I&#8217;ve come home pretty late from work, and I&#8217;m pretty uninspired when it comes to assembling some sort of dinner.  After staring at the fridge fruitlessly for a while, I&#8217;m struck by an inspiration of sorts.  I&#8217;ll make <a href="http://www.urbandictionary.com/define.php?term=bachelor+chow">bachelor chow</a>.  Now, I have no idea what is in the original bachelor chow (nor do I want to know), but my bachelor chow is just the name I&#8217;ve given to the worst thing that I cook for myself on purpose.</p>

<p>So, here is the basic recipe:</p>

<p>Makes one serving:
  3-4 oz. pasta, preferably penne, but anything will suffice
  1/4 jar pasta sauce, any tomato-based variety
   shredded cheese.  I use Sargento&#8217;s 4-cheese mexican.</p>

<ol>
<li>Cook the pasta.  You can salt the water, but I&#8217;ve been running periodic experiments with not salting the water, and so far, I can&#8217;t really tell the difference.  It is even less important with this recipe, since taste is clearly not high on the agenda.</li>
<li>Prior to completely cooking the pasta through, drain the pasta.  Overcooking it is OK, undercooking it sucks, though, so err to the side of too long.  Deposit the pasta into a microwave-safe plate or bowl.   You know, the dish you are going to serve this on.</li>
<li>Optionally stir in a little bit of olive oil and salt (preferably kosher or sea salt).  You can stop right here and have a pretty good dish, even if it is nutritionally unbalanced. It is only going to get worse from here.</li>
<li>Pour the (cold) pasta sauce over the pasta.  Do not stir it in, just let it sit on top.</li>
<li>Sprinkle the shredded cheese on top.  Again, no stirring.</li>
<li>Microwave on high for 2-3 minutes, until the cheese has melted.</li>
<li>Enjoy.  Or, at least, Tolerate.</li>
</ol>

<p>This recipe violates almost every thing I&#8217;ve learned about cooking, but it takes me back to my just-out-of-college days when I was equally as lazy and less polluted by cookbooks, <a href="http://www.cooksillustrated.com/">Cooks Illustrated</a>, and <a href="http://www.foodnetwork.com/">Food Network</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2007/12/bachelor-chow/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Quest for Anti-Aliased Emacs</title>
		<link>http://blacka.com/david/archives/2007/08/quest-for-anti-aliased-emacs/</link>
		<comments>http://blacka.com/david/archives/2007/08/quest-for-anti-aliased-emacs/#comments</comments>
		<pubDate>Fri, 31 Aug 2007 18:55:50 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[Software Development]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2007/08/quest-for-anti-aliased-emacs/</guid>
		<description><![CDATA[In contemplating a move back to Linux for my day job, or at least a future where more of my work is done directly on my Linux box, I began to pine for decent anti-aliased fonts for emacs.

Both the windows and mac builds of emacs 22 have this support built-in.  Although, good luck trying [...]]]></description>
			<content:encoded><![CDATA[<p>In contemplating a move back to Linux for my day job, or at least a future where more of my work is done directly on my Linux box, I began to pine for decent anti-aliased fonts for emacs.</p>

<p>Both the <a href="http://ourcomments.org/Emacs/EmacsW32.html">windows</a> and <a href="http://homepage.mac.com/zenitani/emacs-e.html">mac</a> builds of emacs 22 have this support built-in.  Although, good luck trying to figure out how to change the font to what you want, at least in Carbon Emacs.  Fortunately the default font of Monaco is pretty good (albeit not perfect).  I don&#8217;t have a lot of experience with EmacsW32, even though I do have it installed somewhere.</p>

<p>At first, I was puzzled as to why emacs just didn&#8217;t come with anti-aliased fonts on Fedora 7 by default.  Some web searches led me to believe that support was to be merged in before emacs 22.1, and there I was, running 22.1.  Alas, I had misread the interweb.  If support has been merged in, it has been merged in <em>after</em> 22.1.  Since 22.1 is the latest stable version of emacs (as of this writing), it isn&#8217;t all that surprising that Fedora 7 doesn&#8217;t have this.</p>

<p>Ah, well, time to move to the bleeding edge.  Concise instructions for building a CVS version of emacs with anti-aliased fonts can be found on the <a href="http://www.emacswiki.org/cgi-bin/wiki/XftGnuEmacs">XftGnuEmacs</a> page.  I didn&#8217;t have a whole lot of trouble building and installing this version, but what I really want is a Fedora 7 package to <em>replace</em> the delivered packages.  If I were running <a href="http://peadrop.com/blog/2007/01/06/pretty-emacs/">Ubuntu</a>, this wouldn&#8217;t be much of a problem.</p>

<p>So far, my attempts to hack the existing source RPM for emacs haven&#8217;t met with much success.  It doesn&#8217;t help that emacs take a while to compile, and I keep having to completely start over.  <del datetime="2007-09-13T01:38:50+00:00">I&#8217;ll update this entry if I ever get an rpm built</del>.  </p>

<p><strong>Update</strong>:  I&#8217;ve managed to work through the major issues, so here is the <a href="/files/emacs-23.0.0-u2.20070901cvs.fc7.src.rpmu2.20070901cvs.fc7.src.rpm">source RPM</a> for Fedora 7.  I&#8217;ve put some actual binaries <a href="/files/emacs-xft-rpms">here</a>.  This version doesn&#8217;t replace the stock emacs-22.1.  Instead it installs into <code>/usr/local</code>, but can easily be made the default version via the <em>alternatives</em> command:</p>

<blockquote> <code>alternatives --set emacs /usr/local/bin/emacs-23.0.0</code></blockquote>

Now that I have a working version of emacs with anti-aliased font support, I&#8217;ve been <a href="http://www.lowing.org/fonts/">hunting down</a> what font to actually use.  <a href="http://www.gnome.org/fonts/">Bitstream Vera Sans Mono</a> is a good default, but at the moment I&#8217;m trying out <a href="http://www.ms-studio.com/FontSales/anonymous.html">Anonymous</a>.

For the curious, the bit of elisp that I&#8217;m using to set the fonts is this:

<blockquote>
<pre>
(if (eq window-system 'x)
    ;; if we have the Xft-enabled version of emacs...
    (if (>= emacs-major-version 23)
    (progn
      ;; note: Anonymous doesn't come with Fedora.  You can get it here:
      ;; http://www.ms-studio.com/FontSales/anonymous.html
      (set-default-font "Anonymous-10")
      (setq bvsm10 "Bitstream Vera Sans Mono-10")
      ;; unfortunately, anonymous doesn't have bold or italic
      ;; so, use bitstream vera sans mono for that
      (set-face-font 'bold (concat bvsm10 ":weight=bold"))
      (set-face-font 'italic (concat bvsm10 ":slant=oblique"))
      (set-face-font 'bold-italic
             (concat bvsm10 ":weight=bold:slant=oblique"))
      ;; ...and no proportional font, for that matter
      (set-face-font 'variable-pitch "Bitstream Vera Sans-10")
      (add-to-list 'default-frame-alist '(font . "Anonymous-10")))
      ;; otherwise...
      (progn
    (set-default-font
     "-*-lucidatypewriter-medium-r-*-*-14-140-*-*-*-*-*-*"))
      )
  )
</pre>
</blockquote>

<p>I&#8217;m doing it this way (instead of in X resources) so that launching emacs-22.1 will still work.  If you stick with <em>Bitstream Vera Sans Mono</em> (or <em>DejaVu LGC Sans Mono</em> which is very similar), then you won&#8217;t have to bother with overriding the <strong>bold</strong>, <em>italic</em>, and <strong><em>bold-italic</em></strong> font settings as those will basically just work once you set the default font.  You would still have to deal with overriding the proportional font, however.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2007/08/quest-for-anti-aliased-emacs/feed/</wfw:commentRss>
		</item>
		<item>
		<title>twittering</title>
		<link>http://blacka.com/david/archives/2007/08/twittering/</link>
		<comments>http://blacka.com/david/archives/2007/08/twittering/#comments</comments>
		<pubDate>Sat, 18 Aug 2007 02:48:20 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[General]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2007/08/twittering/</guid>
		<description><![CDATA[Meaningless stream of comments here.
]]></description>
			<content:encoded><![CDATA[<p>Meaningless stream of comments <a href="http://twitter.com/dblacka">here</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2007/08/twittering/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Why the bluetooth headset hate?</title>
		<link>http://blacka.com/david/archives/2007/07/why-the-bluetooth-headset-hate/</link>
		<comments>http://blacka.com/david/archives/2007/07/why-the-bluetooth-headset-hate/#comments</comments>
		<pubDate>Thu, 19 Jul 2007 00:21:24 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[General]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2007/07/why-the-bluetooth-headset-hate/</guid>
		<description><![CDATA[Over the past few days I&#8217;ve read not one, but two articles expressing the hate toward bluetooth headsets.  And for both articles, I realized that it was misplaced hate.  The authors (and commenters) actually hate the way that some people use them.  That is, the whole standing around and talking to yourself [...]]]></description>
			<content:encoded><![CDATA[<p>Over the past few days I&#8217;ve read not <a href="http://www.37signals.com/svn/posts/516-blinking-bluetooth-headsets">one</a>, but <a href="http://arstechnica.com/journals/apple.ars/2007/07/18/iphone-bluetooth-headset-shipping-soon-look-20-less-ridiculous-than-when-using-other-models">two</a> articles expressing the hate toward bluetooth headsets.  And for both articles, I realized that it was misplaced hate.  The authors (and commenters) actually hate the way that some people use them.  That is, the whole standing around and talking to yourself thing.</p>

<p>Fair enough, but some of us just want bluetooth headsets so we don&#8217;t have to keep buying special, vendor specific headsets, and yet also don&#8217;t want to hold the phone up to our ear for the whole hour-long conference call.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2007/07/why-the-bluetooth-headset-hate/feed/</wfw:commentRss>
		</item>
		<item>
		<title>The updated irony</title>
		<link>http://blacka.com/david/archives/2007/07/the-updated-irony/</link>
		<comments>http://blacka.com/david/archives/2007/07/the-updated-irony/#comments</comments>
		<pubDate>Sat, 14 Jul 2007 21:11:20 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[General]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2007/07/the-updated-irony/</guid>
		<description><![CDATA[Since I was thwarted in my one lame attempt to get an iPhone, I ended up getting a standard-ish Nokia flip phone.  This was supposed to be my &#8220;backup phone&#8221;.  I&#8217;m not sure when I would have used the backup phone (when I sent my iPhone in for service?  When I didn&#8217;t [...]]]></description>
			<content:encoded><![CDATA[<p>Since I was <a href="http://blacka.com/david/archives/2007/07/the-irony/">thwarted in my one lame attempt</a> to get an <a href="http://www.apple.com/iphone/">iPhone</a>, I ended up getting a standard-ish <a href="http://reviews.cnet.com/cell-phones/nokia-6102-cingular-wireless/4505-6454_7-31517958.html">Nokia flip phone</a>.  This was supposed to be my &#8220;backup phone&#8221;.  I&#8217;m not sure when I would have used the backup phone (when I sent my iPhone in for service?  When I didn&#8217;t want to take the iPhone with me to a dangerous neighborhood?), but it didn&#8217;t seem too wasteful to have a unit to use when the primary phone wasn&#8217;t working.</p>

<p>Of course, now that I&#8217;ve had this Nokia for a few days, I keep liking it more.  It fits in my pocket.  I can sync it with the Mac via bluetooth.  It gets decent reception.  It sounds fine.  I can use a custom ringtone.  (I&#8217;m not at the moment, however).  It ain&#8217;t perfect, but it is working for me.</p>

<p>I do miss the calendaring, password safe, and games from the Treo.  But, I never did really use that thing to its full potential, so stepping down from the smartphone is working out fine.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2007/07/the-updated-irony/feed/</wfw:commentRss>
		</item>
		<item>
		<title>The irony</title>
		<link>http://blacka.com/david/archives/2007/07/the-irony/</link>
		<comments>http://blacka.com/david/archives/2007/07/the-irony/#comments</comments>
		<pubDate>Thu, 05 Jul 2007 15:38:42 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[General]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2007/07/the-irony/</guid>
		<description><![CDATA[Yesterday, my trusty Treo 650 decided to go crazy.  OK, I think, I had it for two years, time for something new.  Time for an iPhone!  Alas, today is a day when the iPhone appears to be mostly out of stock. 

So, let me describe the particular form of crazy that my [...]]]></description>
			<content:encoded><![CDATA[<p>Yesterday, my trusty Treo 650 decided to go crazy.  OK, I think, I had it for two years, time for something new.  Time for an iPhone!  Alas, today is a day when the iPhone appears to be <a href="http://daringfireball.net/linked/2007/july#thu-05-sold_out">mostly out of stock</a>. </p>

<p>So, let me describe the particular form of crazy that my Treo has become.  I first noticed it last night.  I was outside, and it was raining (although not directly on me).  I look at the Treo, and it is, for some reason, trying to sync via cable.  Cancel.  It tries to sync again.  It is in an endless loop of syncing.  It is acting like it has the sync cable plugged in, and the sync button permanently pressed.  After several resets to no avail, I give up and remove the battery for a few hours.  Now it doesn&#8217;t try to sync all the time (although, it still tries sometimes), but it also doesn&#8217;t turn on when asked, either.</p>

<p>I&#8217;ve tried everything up to and including the data-erasing hard reset with no change.  Hopefully, I&#8217;ll be able to get an iPhone soonish.  I don&#8217;t want one bad enough to get it from ebay&#8230;</p>

<p><strong>Update</strong>: instead of getting an iPhone, I&#8217;ve gotten a <a href="http://seap.forum.nokia.com/devices/6102i">Nokia 6102i</a> with no contract.  Nothing at all like an iPhone, but it <em>is</em> a credible phone.  I may change my mind if I&#8217;ve got to take it overseas, though.  By paying for the phone and not getting a new contract, I do still reserve the right to get an iPhone in the not-too-distant future.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2007/07/the-irony/feed/</wfw:commentRss>
		</item>
		<item>
		<title>Red Sweater Software Spam Filtering Lets Me Down; Red Sweater Tries Real Hard</title>
		<link>http://blacka.com/david/archives/2007/05/red-sweater-software-lets-me-down/</link>
		<comments>http://blacka.com/david/archives/2007/05/red-sweater-software-lets-me-down/#comments</comments>
		<pubDate>Wed, 02 May 2007 02:48:01 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[Macintoshia]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2007/05/red-sweater-software-lets-me-down/</guid>
		<description><![CDATA[Step&#8230;
Discover Black Ink.  It has a 30-day trial periodTry for 30 days.  Like in the beginning, like at the end.Buy it.  I go the the online store and pay via paypal.Wait for 3 days.  See credit card charge go through.During this time, fail to check the spam traps.Wait for 4 more [...]]]></description>
			<content:encoded><![CDATA[<p>Step&#8230;
<ol><li>Discover <a href="http://www.red-sweater.com/blackink/">Black Ink</a>.  It has a 30-day trial period</li><li>Try for 30 days.  Like in the beginning, like at the end.</li><li>Buy it.  I go the the <a href="http://www.red-sweater.com/store/">online store</a> and pay via paypal.</li><li>Wait for 3 days.  See credit card charge go through.</li><li><em>During this time, fail to check the spam traps</em>.</li><li>Wait for 4 more days.  Nothing from Red Sweater Software.</li><li>Send email to support@red-sweater.com asking for actual registration code.</li><li>Wait 3 more days.  Silence.</li><li><em>Discover that somehow, searching for &#8220;red-sweater&#8221; in Mail.app doesn&#8217;t find mail in the spam folders</em>.</li><li><em>Eventually find 3 emails from Daniel Jalkut with your registration code</em>.</li></ol>Hmm.. The online store page says &#8220;&#8230;usually within a few minutes&#8221;.  Is two weeks to wait long enough?  I guess after that I&#8217;ll be reversing the charges.  Or something.</p>

<p><strong>Update</strong>: All fixed now.  I am somewhat amazed that posting to my blog was an effective means of communication.  I&#8217;m guessing this reflects more on Red Sweater Software&#8217;s customer service diligence than anything else.</p>

<p><strong>Update[2]</strong>:  So my friend Sean summed this whole event up as: &#8220;You posted to your blog, Daniel Jalkut read it, said &#8216;check your spam box, dumbass&#8217;, and now you look like an idiot.&#8221; Yep.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2007/05/red-sweater-software-lets-me-down/feed/</wfw:commentRss>
		</item>
		<item>
		<title>The Good and Bad of DNSSEC SO</title>
		<link>http://blacka.com/david/archives/2007/04/the-good-and-bad-of-dnssec-so/</link>
		<comments>http://blacka.com/david/archives/2007/04/the-good-and-bad-of-dnssec-so/#comments</comments>
		<pubDate>Sun, 29 Apr 2007 15:15:03 +0000</pubDate>
		<dc:creator>davidb</dc:creator>
		
		<category><![CDATA[DNS]]></category>

		<guid isPermaLink="false">http://blacka.com/david/archives/2007/04/the-good-and-bad-of-dnssec-so/</guid>
		<description><![CDATA[Late last year, Mike StJohns transcribed one of his DNSSEC-related rants into Internet-Draft form (recently expired).  The name of his proposal, &#8220;Signature Only DNSSEC&#8221; has been referred to as &#8220;DNSSEC SO&#8221; in shorthand.

Mike&#8217;s idea was soundly rejected by the IETF working group that it was presented to, DNSEXT.  I&#8217;ll outline some theories why [...]]]></description>
			<content:encoded><![CDATA[<p>Late last year, Mike StJohns transcribed one of his DNSSEC-related rants into Internet-Draft <a href="http://tools.ietf.org/html/draft-stjohns-dnssec-sigonly-00" title="form">form</a> (recently expired).  The name of his proposal, &#8220;Signature Only DNSSEC&#8221; has been referred to as &#8220;DNSSEC SO&#8221; in shorthand.</p>

<p>Mike&#8217;s idea was soundly rejected by the IETF working group that it was presented to, <a href="http://tools.ietf.org/wg/dnsext/">DNSEXT</a>.  I&#8217;ll outline some theories why in a bit.  But, its rejection was not because it was a horrible idea.  In fact, from some points of view, it is a pretty good idea.  In a nutshell, DNSSEC SO says:
<ul><li> Drop the NSEC (née NXT) or NSEC3 records, and just concentrate on being able to positively verify records, and</li><li> because successful chains of trust through zones don&#8217;t actually involve NSEC records, this can coexist with standard DNSSEC.</li></ul>The draft certainly talks about other things (like off-tree chains of trust) which are interesting too, but this is the main thrust.  By eliminating the NSEC records (what MSJ calls &#8220;Provable Non-Existence&#8221;, or PNE), you&#8217;ve simplified DNSSEC and, in one fell swoop, eliminated all of the angst generated by the NSEC records (leading to things like <a href="http://tools.ietf.org/html/draft-ietf-dnsext-nsec3-10">NSEC3</a> and <a href="http://www1.tools.ietf.org/html/draft-ietf-dnsext-dnssec-online-signing-01">on-line NSEC generation</a>).  This isn&#8217;t to say that DNSSEC SO removes all of the Hard from DNSSEC, but it does go a long way.</p>

<p>However, let&#8217;s take a look at the main purposes  of DNSSEC:<span style="font-size:12pt;">
</span><ol><li>Protect legacy and security-unaware Internet applications from DNS spoofing attacks, and</li><li>Enable new applications to use DNS as security scaffolding.</li></ol>Purpose #1 is why (I believe) that DNSSEC was pursued in the first place.  Purpose #2 was thought of later as a compelling reason to continue.  Or rather, #2 is the reason why we would have wide-scale deployment of DNS in the absence of a highly publicized attack on the DNS.</p>

<p>And now we can see why DNSSEC SO was rejected: it is utterly useless for purpose #1.  And, since most new applications have to live an world without universal DNSSEC deployment (SO or otherwise), DNSSEC SO isn&#8217;t as useful for purpose #2 as it might be.  Let me explain.</p>

<p>Standard  DNSSEC (including things like NSEC3) says that DNS responses, after being validated, fall into one of three states (actually four, but never mind): SECURE, INSECURE, and BOGUS.  That is: it validated and was signed; it wasn&#8217;t signed, but that was proven to be OK; and it failed to validated (for any reason).  When a response is BOGUS, the response is withheld from the application.  Thus, an unaware application is spared from the effects of the spoofing attack.</p>

<p>DNSSEC SO says that responses, after validation, only fall into two states: SECURE and NOT SECURE.   That is: it validated and it was signed; or it wasn&#8217;t signed or didn&#8217;t validate.  So spoofing attacks just get passed on the unaware client, which can&#8217;t distinguish them from normal DNS responses.</p>

<p>OK, so what about purpose #2?  Imagine an application that might be aware of DNSSEC and might really want to use it for security scaffolding.  Let&#8217;s call it <a href="http://www.dkim.org/">DKIM</a>, an application that looks up cryptographic keys in DNS for the purpose of deciding to accept or reject email.  It might decide that it is <em>only</em> going to use DKIM keys that have been signed and verified by DNSSEC.  This is great, and, in fact, DNSSEC SO works here just fine.</p>

<p>However, at this point in time, DKIM cannot afford to restrict itself to only using keys signed with DNSSEC.  Even with DNSSEC SO, it is going to take a while to get enough infrastructure in place so that any zone that wants to can be signed and trusted.  And DKIM needs as many email senders and receivers to use it as possible.</p>

<p>&#8230;</p>

<p>So why was DNSSEC SO rejected by the IETF?  I suppose that everyone who spoke up saying &#8220;No&#8221; has his/her own reason, but my belief was that it was because DNSSEC SO rejects the initial requirement for DNSSEC, and that the initial requirement (purpose #1, above) is still valid.  Also, the working group was obviously tired of working on DNSSEC, and DNSSEC SO represented another 6 to 12 month round of effort for what seemed like little gain.  In other words, &#8220;too little, too late&#8221;.</p>
]]></content:encoded>
			<wfw:commentRss>http://blacka.com/david/archives/2007/04/the-good-and-bad-of-dnssec-so/feed/</wfw:commentRss>
		</item>
	</channel>
</rss>
