<?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>Code Iteratively &#187; software</title>
	<atom:link href="http://iterat.ive.ly/index.php/tag/software/feed/" rel="self" type="application/rss+xml" />
	<link>http://iterat.ive.ly</link>
	<description>Hi there. I&#039;m Christopher Gooley. I build technology. I like to share technology musings and products on this blog. I also like to ramble about non-technology topics. Besides coding, this is my main outlet for sharing and creativity.</description>
	<lastBuildDate>Mon, 19 Dec 2011 23:23:19 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0.1</generator>
		<item>
		<title>HOW TO: Get your web browser gestures back in OS X&#160;Lion</title>
		<link>http://iterat.ive.ly/index.php/2011/07/25/how-to-get-your-web-browser-gestures-back-in-os-x-lion/</link>
		<comments>http://iterat.ive.ly/index.php/2011/07/25/how-to-get-your-web-browser-gestures-back-in-os-x-lion/#comments</comments>
		<pubDate>Mon, 25 Jul 2011 17:30:14 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[quickie]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[uncategorized]]></category>
		<category><![CDATA[howto]]></category>
		<category><![CDATA[lion]]></category>
		<category><![CDATA[osx]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=622</guid>
		<description><![CDATA[If you&#8217;re like me and have a magic mouse and use the internet much, you&#8217;ve probably gotten used to using the two-finger swipe to navigate forward and back in your history in Firefox and Chrome instead of using the back button. Apple has changed the default behavior in OS X Lion to swipe between fullscreen [...]]]></description>
			<content:encoded><![CDATA[<p>If you&#8217;re like me and have a magic mouse and use the internet much, you&#8217;ve probably gotten used to using the two-finger swipe to navigate forward and back in your history in Firefox and Chrome instead of using the back button.  Apple has changed the default behavior in OS X Lion to swipe between fullscreen apps. Which means suddenly when you&#8217;re trying to go back to the previous page, you end up looking at your dashboard or something dumb.</p>
<p>To get your two-finger swipe navigation back, just go into the Mouse preferences and over to the More Gestures section. Change the first option (Swipe between pages) to use two fingers.</p>
<p><img src="http://iterat.ive.ly/wp-content/uploads/2011/07/Screen-Shot-2011-07-25-at-10.23.22-AM.png" alt="" title="Screen Shot 2011-07-25 at 10.23.22 AM" width="380" height="304" class="aligncenter size-full wp-image-624" /></p>
<p>This will disable the full-screen swiping and get you back up and running. Doing the same thing on your laptop should work as well, except you&#8217;ll pick three-finger swiping instead of two.</p>
<p>Enjoy.</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2011/07/25/how-to-get-your-web-browser-gestures-back-in-os-x-lion/feed/</wfw:commentRss>
		<slash:comments>5</slash:comments>
		</item>
		<item>
		<title>Four Steps to Turbocharge Rails + AJAX Development with Nginx and&#160;Foreman</title>
		<link>http://iterat.ive.ly/index.php/2011/06/30/four-steps-to-turbocharge-local-ajax-rails-development-with-nginx-and-foreman/</link>
		<comments>http://iterat.ive.ly/index.php/2011/06/30/four-steps-to-turbocharge-local-ajax-rails-development-with-nginx-and-foreman/#comments</comments>
		<pubDate>Fri, 01 Jul 2011 05:54:30 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[programming]]></category>
		<category><![CDATA[ruby on rails]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[tech]]></category>
		<category><![CDATA[earbits]]></category>
		<category><![CDATA[howto]]></category>
		<category><![CDATA[rails3]]></category>
		<category><![CDATA[ruby]]></category>
		<category><![CDATA[ruby-on-rails]]></category>
		<category><![CDATA[source]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=579</guid>
		<description><![CDATA[If you&#8217;re developing a chatty AJAX app on Rails and using a single mongrel to run it on your workstation, you probably are a bit annoyed with delays waiting for requests to be fulfilled one-at-a-time. So, here I&#8217;ll walk through the steps to run your own &#8220;cluster&#8221; on your OS X workstation using Foreman and [...]]]></description>
			<content:encoded><![CDATA[<p>If you&#8217;re developing a chatty AJAX app on Rails and using a single mongrel to run it on your workstation, you probably are a bit annoyed with delays waiting for requests to be fulfilled one-at-a-time.  So, here I&#8217;ll walk through the steps to run your own &#8220;cluster&#8221; on your OS X workstation using Foreman and Nginx.</p>
<p>In the course of building the frontend application for <a href="http://www.earbits.com/play">Earbits</a>, I&#8217;ve been constantly annoyed with the responsiveness of my local development server.  As a pretty complex AJAX application, there are lots of little (and some bigger) calls to the Rails backend APIs to do <a href="#slow-things">lots of potentially slow things</a>. This means that there are lots of calls that are originating in the browser and being served by one mongrel, so the server ends up handling requests too slowly. Which leads to me being frustrated.  Which leads to me finding a nice solution to the problem.</p>
<p><span id="more-579"></span><br />
<h4>Warning: This May Not Apply To You</h4>
<p>If you have slow running requests that have to run in series, or if you&#8217;re not doing AJAX-y things, this isn&#8217;t going to help you much.  This setup is only useful if your app sends a bunch of parallel requests to the backend. For instance, if after your main page loads, you need to do AJAX requests to a) load the user&#8217;s friends, b) get their comment history, c) calculate some suggestions, and d) check to see if you should show a popup promo to the user, then this might help you out.  But if you need the results of request (a) to get (b) and the results of (b) to get (c), then you&#8217;re out of luck and this will be a waste of your time.</p>
<p>Ok, ready to do this?</p>
<h2>Step 1 &#8211; Install Nginx</h2>
<p>This is much simpler if you have <a href="http://www.macports.org/">macports</a> installed.  So go do that first if you haven&#8217;t already. If the first step below doesn&#8217;t do anything, you don&#8217;t have macports. Once you have macports, it&#8217;s a simple two-command process to install nginx.</p>
<p><code>$ sudo port -d selfupdate<br />
$ sudo port install nginx +ssl +debug</code></p>
<p>Now, while nginx is installing you can open a new terminal window and keep going. The install will take a few minutes.</p>
<h2>Step 2 &#8211; Configure Foreman</h2>
<p><a href="http://blog.daviddollar.org/2011/05/06/introducing-foreman.html">Foreman</a> is a great tool released by David Dollar to make running web processes and workers crazy easy.  It uses a Procfile to define the different things it controls and you should refer to his blog or a Google search to learn about the finer points of Foreman.  We use a pretty simplistic file here as an example.</p>
<p>To get started just run:<br />
<code>$ gem install foreman</code></p>
<p>Then create a file called Procfile in the root of your project using the text editor of your choice.  My Procfile has just one line that define a web process using the standard Rails server:</p>
<pre class="brush:html;">
web:    bundle exec rails server -p $PORT
</pre>
<h2>Step 3 &#8211; Configure Nginx</h2>
<p>Now that nginx is probably finished installing, we can get it configured to act as a local Load Balancer for our Rails server. I&#8217;m going to set it up using port 80 locally. If you are running an HTTP server locally already on port 80, then you should adjust your configuration accordingly.  But if you&#8217;re not using port 80, Rails redirects might cause you some headaches.  So I suggest you stick with the standard port.</p>
<p>First, you&#8217;ll need to find your nginx.conf configuration file.  If you used macports to install it, it&#8217;s probably in <code>/opt/local/etc/nginx/nginx.conf</code> but if you can&#8217;t find it, run <code>nginx -V</code> to see where it&#8217;s hiding.</p>
<p>If you&#8217;re not familiar with nginx at all, there are two main directives that you&#8217;ll be using, <code>server</code> and <code>upstream</code>. The server directive defines the front-end part of nginx (i.e. where it listens for incoming requests).  The upstream directive defines the back-end (i.e. where to send requests so that Rails can handle them).  Both of these snippets should exist within the <code>http</code> section of your config file. <em>I&#8217;ll provide a complete nginx.conf at the end of this section so that you can just replace the default file and then tweak it if necessary.</em></p>
<h4>Upstream section</h4>
<p>This is the configuration that I&#8217;m using, I will explain it in a second:</p>
<pre class="brush:plain;">
upstream foreman4000 {
  server localhost:4000;
  server localhost:4001;
  server localhost:4002;
  server localhost:4003;
  server localhost:4004;
}
</pre>
<p>Here on line 1 we&#8217;re defining the upstream which we will reference later. Note that &#8220;foreman4000&#8243; is just an arbitrary name used to reference it within the config. Then since we plan on running 5 web processes starting at port 4000, we list out each of the ports where our Foreman will be listening for requests.</p>
<h4>Server section</h4>
<p>This will define a server so that nginx will listen to requests on port 80 and direct them to the <code>upstream</code> we created above (line 6).  We also pass the real IP of the request and the hostname along to the server (lines 7-9, in case you need either of these bits of data.</p>
<pre class="brush:plain;">
 server {
    listen       80;
    server_name  localhost;
    access_log  /opt/local/var/log/nginx/foreman4000.access.log  main;
    location / {
      proxy_pass http://foreman4000;
      proxy_set_header Host $host;
      proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header X-Forwarded-For $remote_addr;
    }
 }
</pre>
<h4>Test the config</h4>
<p>After you&#8217;re done making the changes above (or if you <a href="http://ive.ly/cPj" target="_blank">download my nginx.conf example file</a>), you should run <code>$ sudo nginx -t</code> to test the config and make sure it&#8217;s all good. If it fails, double check everything. If it&#8217;s good, you&#8217;re ready to start it up.</p>
<h2>Step 4 &#8211; Start your Engines</h2>
<p>Now all we have to do is start everything up. In your Rails project directory:<br />
<code>$ sudo nginx<br />
$ foreman start -p 4000 -c web=5</code></p>
<p>Note: I use the non-standard port 4000 as the starting point so that other random servers can run on 3000 (rails default) and 5000 (foreman default) without conflicting with this setup.</p>
<p>If it&#8217;s working you should be able to open up http://localhost in your browser and your Rails site should load. In the terminal running Foreman, you should see it handing requests to each of the 5 web processes (web.1 &#8211; web.5) like this:</p>
<p><a href="http://iterat.ive.ly/wp-content/uploads/2011/06/Screen-shot-2011-06-30-at-9.34.04-PM.png"><img src="http://iterat.ive.ly/wp-content/uploads/2011/06/Screen-shot-2011-06-30-at-9.34.04-PM.png" alt="" title="Screen shot 2011-06-30 at 9.34.04 PM" width="336" height="226" class="aligncenter size-full wp-image-597" /></a></p>
<p>Now, enjoy your new, super-responsive AJAX server! I know I do.</p>
<h2 id="slow-things">Notes and Extras</h2>
<p>There are a few reasons my local development environment is slow.  Firstly, I&#8217;m using a <a href="https://mongohq.com/home" target="_blank">hosted mongodb</a> that is shared among a few of our developers so that we can more easily collaborate on work. It makes it possible for me to add a new feature and seed the database with some good example data, then hand it off to our UI guy to style it up with zero configuration on his end other than a <code>git pull</code>. Secondly, we make heavy use of the Facebook Graph APIs which can at times be sluggish over my mere-mortal internet connection.  Getting someone&#8217;s friends might take a full second, posting something to a wall might take a couple seconds.  You can imagine how with just one process running, it would get a bit slow.</p>
<p>The third reason our site is slow in development is the simple fact that it&#8217;s designed to be chatty.  Instead of large monolithic views getting rendered for the user, we do a lot of client-side template rendering using <a href="http://documentcloud.github.com/underscore/" target="_blank">underscore.js</a> based on json data requested by the client app (which leverages <a href="http://documentcloud.github.com/backbone/" target="_blank">backbone.js</a> for much of the interaction logic).  In production, this works great because we can fire up a bunch of web processes and everything scales on out.  But in development, between the slow database access and the numerous calls, things can take seemingly forever to fully load.  But not anymore!</p>
<p>BTW &#8211; if you haven&#8217;t tried <a href="http://www.earbits.com/play" title="free online radio">Earbits</a> out for your online radio needs, you absolutely should. Great way to discover new music, share with your friends and really just have a great time. And you should stop listening to so much Genesis anyway. It&#8217;s time for something fresher.</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2011/06/30/four-steps-to-turbocharge-local-ajax-rails-development-with-nginx-and-foreman/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Whirlfood &#8211; social suggestions for food &amp; nightlife&#160;[beta]</title>
		<link>http://iterat.ive.ly/index.php/2010/09/08/whirlfood-social-suggestions-for-food-nightlife-beta/</link>
		<comments>http://iterat.ive.ly/index.php/2010/09/08/whirlfood-social-suggestions-for-food-nightlife-beta/#comments</comments>
		<pubDate>Wed, 08 Sep 2010 18:06:45 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[software]]></category>
		<category><![CDATA[foursquare]]></category>
		<category><![CDATA[learning-ror]]></category>
		<category><![CDATA[location]]></category>
		<category><![CDATA[ruby]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=496</guid>
		<description><![CDATA[Well, this is the site that I&#8217;ve been working on in my learning Ruby on Rails series. It&#8217;s called Whirlfood (pending a better name) and it is going to be a social suggestion site that helps you pick places to eat and where to go out with friends. But while we&#8217;re working on the algorithm, [...]]]></description>
			<content:encoded><![CDATA[<p>Well, this is the site that I&#8217;ve been working on in my learning Ruby on Rails series.  It&#8217;s called Whirlfood (pending a better name) and it is going to be a social suggestion site that helps you pick places to eat and where to go out with friends.  </p>
<p>But while we&#8217;re working on the algorithm, it just does some neato analytics on your data. We&#8217;ll be adding more analytics once we get the friend import stuff working &#8211; we we can analyze how you interact with your friends and look for trends.  Then we&#8217;ll really start to tackle the suggestion engine.  We have what we think are some pretty cool ideas for that part.</p>
<p><center><strong>Stats Dashboard</strong><br/><a href="http://f.ive.ly/AeH.jpg"><img src="http://iterat.ive.ly/wp-content/uploads/2010/09/whirlfood-preview-1.jpg" alt="" title="whirlfood-preview-1" width="400" height="272" class="aligncenter size-full wp-image-498" /></a></center></p>
<p><center><strong>Fullscreen Map View</strong><br/><a href="http://f.ive.ly/AeI.jpg"><img src="http://iterat.ive.ly/wp-content/uploads/2010/09/whirlfood-preview-2.jpg" alt="" title="whirlfood-preview-2" width="400" height="292" class="aligncenter size-full wp-image-500" /></a></center></p>
<p>This is just a quickie screenshot set of what the stats look like for me (and I&#8217;ve only been using Foursquare for 2 weeks while building this app).  If you want to sign up and play with it, let me know and I&#8217;ll get you the link to the beta site!</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2010/09/08/whirlfood-social-suggestions-for-food-nightlife-beta/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Upgrading your Authlogic Gem for&#160;Rails3</title>
		<link>http://iterat.ive.ly/index.php/2010/09/03/upgrading-your-authlogic-gem-for-rails3/</link>
		<comments>http://iterat.ive.ly/index.php/2010/09/03/upgrading-your-authlogic-gem-for-rails3/#comments</comments>
		<pubDate>Fri, 03 Sep 2010 08:45:17 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[ruby on rails]]></category>
		<category><![CDATA[howto]]></category>
		<category><![CDATA[rails3]]></category>
		<category><![CDATA[ruby]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[tip]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=431</guid>
		<description><![CDATA[If you&#8217;re using Authlogic in Rails3 (or if you&#8217;re upgrading your existing app from 2.3.8 to Rails3) you really need to be using the rails3 branch of the Authlogic gem. If you&#8217;re using Bundler, this is super-easy because you just need to update your Gemfile. In your Gemfile, update the authlogic line to be: gem [...]]]></description>
			<content:encoded><![CDATA[<p>If you&#8217;re using Authlogic in Rails3 (or if you&#8217;re upgrading your existing app from 2.3.8 to Rails3) you really need to be using the <a href="http://github.com/odorcicd/authlogic/tree/rails3">rails3 branch</a> of the Authlogic gem.  If you&#8217;re using <a href="http://gembundler.com/">Bundler</a>, this is super-easy because you just need to update your Gemfile.</p>
<p>In your Gemfile, update the authlogic line to be:</p>
<pre class="brush:ruby;gutter:false">
gem 'authlogic', :git => 'git://github.com/odorcicd/authlogic.git', :branch => 'rails3'
</pre>
<p>Now you should run <code>$ bundle install</code> to grab the new gem. Then, there are just a few more deprecated things in Rails3 that you&#8217;ll need to change in your upgraded app. I&#8217;ll try to enumerate here from memory, so please forgive me if I forget something.</p>
<p><span id="more-431"></span>First, you need to update your ApplicationController because #requesturi is outdated.  Replace it with #fullpath:</p>
<pre class="brush:ruby;gutter:false;">
def store_location
  session[:return_to] = request.fullpath
end
</pre>
<p>Second, you need to drop the filter_parameter_logging setting from your ApplicationController because it&#8217;s now handled in the new application.rb file.  Just remember to add the :password_confirmation field to the default array like so:</p>
<pre class="brush:ruby;gutter:false;">
# Configure sensitive parameters which will be filtered from the log file.
config.filter_parameters += [:password, :password_confirmation]
</pre>
<p>Third, if your migration script (or the steps you followed manually) didn&#8217;t get rid of the /config/initializers/cookie_verification_secret.rb file, delete it now.  Cookie secrets are now handled in the /config/initializers/secret_token.rb file.</p>
<p>Fourth, the f.error_message construct isn&#8217;t available anymore in core rails, so you should take this opportunity to create your own better more customizable error messages.  If you really really want to keep using f.error_message you can install the dynamic_form plugin, but don&#8217;t do that.  Railscast.com did a very nice explanation of <a href="http://asciicasts.com/episodes/211-validations-in-rails-3">how to create your own shared _error_messages.html.erb view</a> (along with some other validation-related stuff.)</p>
<p>Finally, you need to make sure your generated pages include the csrf_meta_tag. <a href="http://iterat.ive.ly/index.php/2010/09/03/invalidauthenticitytoken-on-logout-attempt-using-authlogic/">Check out my previous post</a> if you&#8217;re getting an InvalidAuthenticityToken error when you hit the Logout link.</p>
<p>That should be all you need to do to have Authlogic working in Rails3 without deprecated warnings.</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2010/09/03/upgrading-your-authlogic-gem-for-rails3/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>InvalidAuthenticityToken on Logout when using&#160;Authlogic</title>
		<link>http://iterat.ive.ly/index.php/2010/09/03/invalidauthenticitytoken-on-logout-attempt-using-authlogic/</link>
		<comments>http://iterat.ive.ly/index.php/2010/09/03/invalidauthenticitytoken-on-logout-attempt-using-authlogic/#comments</comments>
		<pubDate>Fri, 03 Sep 2010 08:07:46 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[ruby on rails]]></category>
		<category><![CDATA[howto]]></category>
		<category><![CDATA[rails3]]></category>
		<category><![CDATA[ruby]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[tip]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=416</guid>
		<description><![CDATA[This one took me a while to debug. When upgrading my existing application to Rails 3 almost everything was working fine except whenever I would click the Logout link I would get an error because Rails couldn&#8217;t verify that the UserSessionsController#destroy request was valid from my app. This is the error message shown: ActionController::InvalidAuthenticityToken in [...]]]></description>
			<content:encoded><![CDATA[<p>This one took me a while to debug. When upgrading my existing application to Rails 3 almost everything was working fine except whenever I would click the Logout link I would get an error because Rails couldn&#8217;t verify that the UserSessionsController#destroy request was valid from my app.</p>
<p>This is the error message shown:<br />
<code>ActionController::InvalidAuthenticityToken in User sessionsController#destroy</code></p>
<p><code>actionpack (3.0.0) lib/action_controller/metal/ request_forgery_protection.rb:96:in `verify_authenticity_token'</code></p>
<p>And the solution is simple, you just need to add the new csrf_meta_tag helper to your generated page (probably in the /views/layouts/application.html.erb file).</p>
<p><span id="more-416"></span></p>
<pre class="brush:html;highlight:7">
...
&lt;head&gt;
  &lt;meta http-equiv="content-type" content="text/html;charset=UTF-8" /&gt;
  &lt;title&gt;Some Title&lt;/title&gt;
  &lt;%= stylesheet_link_tag :all %&gt;
  &lt;%= javascript_include_tag :defaults %&gt;
  &lt;%= csrf_meta_tag %&gt;
&lt;/head&gt;
...
</pre>
<p>Line 7 is the one you care about and need to have in your html.erb file.</p>
<p>This helper includes the appropriate meta tags which make the authenticity_token available to the handleMethod javascript function.  In Rails3, links generated with the link_to helper which use a :method other than GET get passed through that handleMethod function in rails.js.  That function creates a temporary form, sets some parameters and submits it.  And if you&#8217;re using protect_from_forgery (you should be) all non-GET requests are checked to prevent Cross Site Request Forgery (CSRF).  So, if those meta tags don&#8217;t exist on your page, the handleMethod function doesn&#8217;t know what your authenticity_token is, and the request will be rejected with the error above.</p>
<p>Line 5 below is an example of my main nav logout link that was causing the problem when clicked.  No change was required to this code after doing the above fix.</p>
<pre class="brush:ruby;highlight:5">
&lt;% if !current_user %&gt;
  &lt;%= link_to "Log In", new_user_session_path %&gt; |
  &lt;%= link_to "Register", new_account_path %&gt; |
&lt;% else %&gt;
  &lt;%= link_to "Logout", user_session_path, :method =&gt; :delete %&gt; |
&lt;% end %&gt;
</pre>
<p>This isn&#8217;t specific to Authlogic&#8217;s logout click &#8211; any time you are using link_to now in Rails3 with non-GET methods, it uses unobtrusive javascript. And if you&#8217;re missing the csrf_meta_tag helper, any unobtrusive javascript posts will fail to validate. </p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2010/09/03/invalidauthenticitytoken-on-logout-attempt-using-authlogic/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Coming Soon: Earbits Radio iPhone&#160;App</title>
		<link>http://iterat.ive.ly/index.php/2010/09/01/coming-soon-earbits-radio-iphone-app/</link>
		<comments>http://iterat.ive.ly/index.php/2010/09/01/coming-soon-earbits-radio-iphone-app/#comments</comments>
		<pubDate>Thu, 02 Sep 2010 03:12:45 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[asides]]></category>
		<category><![CDATA[cool stuff]]></category>
		<category><![CDATA[earbits]]></category>
		<category><![CDATA[iphone]]></category>
		<category><![CDATA[software]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=390</guid>
		<description><![CDATA[Earbits is a new 24&#215;7 commercial-free, subscription-free free internet radio service that just launched last Friday. Once it&#8217;s fully baked, it&#8217;s going to have some really cool artist discovery tools and great utilities for bands who want to get their music heard. I&#8217;ve been involved in the minor capacity of building the actual player used [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://earbits.com">Earbits</a> is a new 24&#215;7 commercial-free, subscription-free free internet radio service that just launched last Friday. Once it&#8217;s fully baked, it&#8217;s going to have some really cool artist discovery tools and great utilities for bands who want to get their music heard.</p>
<p>I&#8217;ve been involved in the minor capacity of building the actual player used on the website and for embedded players on partner websites. It&#8217;s been a nice refresher of using my javascript skills. And now, I&#8217;m expanding my role into building the first mobile Earbits app for the iPhone. Since I&#8217;ve been trying to learn Ruby on Rails over the past week or so, I decided that I might as well also try and learn Objective-C and that whole mess too.</p>
<p>Keeps life interesting.  But here&#8217;s the teaser shot taken right after the first time I actually deployed the radio app to my iPhone.</p>
<p><center><img class="aligncenter size-full wp-image-391" title="earbits-iphone-blog" src="http://iterat.ive.ly/wp-content/uploads/2010/09/earbits-iphone-blog.jpg" alt="" width="312" height="469" /></center></p>
<p>Hope to have a beta version done in a week or so, depending on API availability, and get it into the App Store sometime in September.</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2010/09/01/coming-soon-earbits-radio-iphone-app/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>A User Friend Relationship Model in&#160;Rails</title>
		<link>http://iterat.ive.ly/index.php/2010/08/31/a-user-friend-relationship-model-in-rails/</link>
		<comments>http://iterat.ive.ly/index.php/2010/08/31/a-user-friend-relationship-model-in-rails/#comments</comments>
		<pubDate>Wed, 01 Sep 2010 03:30:22 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[ruby on rails]]></category>
		<category><![CDATA[learning-ror]]></category>
		<category><![CDATA[ruby]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[source]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=341</guid>
		<description><![CDATA[In building my first Ruby on Rails app, I needed to create a facebook / social-networking style friend relationship between users. The simple requirements were that it the friendship should require approval (e.g. a friend request followed by an accept or ignore) and it should be lightweight (not using two records for a single relationship). [...]]]></description>
			<content:encoded><![CDATA[<p>In building my first Ruby on Rails app, I needed to create a facebook / social-networking style friend relationship between users. The simple requirements were that it the friendship should require approval (e.g. a friend request followed by an accept or ignore) and it should be lightweight (not using two records for a single relationship).</p>
<p>This method and code is inspired by two <a href="http://www.railsforum.com/viewtopic.php?id=16760">blog</a> <a href="http://railscasts.com/episodes/163-self-referential-association">posts</a>, which got me started but neither of which really fulfilled my complete requirement. The first used two records per friendship and the second was a twitter-style friend/follower without the approval process.</p>
<p>So, here I break down my Friendship model which hopefully you will find useful and/or insightful as a complete solution or a starting point for your own implementation.</p>
<p><span id="more-341"></span><br />
First step is to generate a new model that we&#8217;ll call Friendship.  A Friendship will connect two users, tracking who made the request, who the friend is, and whether the request has been approved. So we generate it like so:</p>
<pre class="brush:ruby; gutter:false; toolbar:false">$ script/generate model Friendship user_id:integer friend_id:integer approved:boolean</pre>
<p>This will create the db migration script and the app/models/friendship.rb file which we&#8217;re going to edit to include relationships to the User model. When first created, the Friendship model will be mostly empty so we need to add two lines.</p>
<pre class="brush:ruby">class Friendship &lt; ActiveRecord::Base
  belongs_to :user
  belongs_to :friend, :class_name =&gt; "User", :foreign_key =&gt; "friend_id"
end</pre>
<p>The first line is obviously creating a relationship to the User model, but the second line is a little more complex. It also needs to create a relationship to the User model (there isn&#8217;t a Friend model) but we want to refer to this as the friend. So we have to specify both the :class_name and the :foreign_key so that Rails knows how to hook up this :friend field to actual models.</p>
<p>Now that we have a Friendship, we need to configure the User model to allow for these self-referential relationship through the Friendship model. Before we hit the code, let&#8217;s walk through the concepts here that define the state of friendships and friends.</p>
<p>A friendship is a two-way relationship which is initiated by one user and approved by the other user. So, we have two states of a friendship (not-approved-yet or approved) and we have two directions of friendship relative to the current user: friendships requested <strong>by</strong> the current user (we&#8217;ll call these &#8220;direct&#8221; friendships), and friendships requested <strong>to</strong> the current user (we&#8217;ll call these &#8220;inverse&#8221; friendships).</p>
<p>So using this terminology, we have 4 possible states of Friendship:<br />
1) direct approved<br />
2) indirect approved<br />
3) direct not-approved<br />
4) indirect not-approved</p>
<p>States #1 and #2 are simply what we will be calling &#8220;friends&#8221; &#8211; they are approved relationships, no matter the direction.  Because we don&#8217;t care who requested the friendship once it&#8217;s approved, we will group these together.</p>
<p>State #3 is what we call &#8220;pending friends&#8221; &#8211; other users whom the current user has requested to be friends with and which are awaiting the other user&#8217;s approval. These are out of the control of the current user, and just waiting to be approved or rejected.</p>
<p>State #4 is what we&#8217;ll call &#8220;requested friends&#8221; &#8211; other users who have requested that the current user be their friend, and are awaiting the current user&#8217;s approval. These are the actionable items for the current user to approve. Ignoring a friend request simply deletes the non-approved Friendship, which is the Facebook method (doesn&#8217;t tell the other person they were rejected, but allows them to send another request if they want.)</p>
<p>Now that we have that groundwork, here is the User model:</p>
<pre class="brush:ruby;class-name:'nowrap'">class User &lt; ActiveRecord::Base
  [...]
  has_many :friendships
  has_many :inverse_friendships, :class_name =&gt; "Friendship", :foreign_key =&gt; "friend_id"
  has_many :direct_friends, :through =&gt; :friendships, :conditions =&gt; "approved = true", :source =&gt; :friend
  has_many :inverse_friends, :through =&gt; :inverse_friendships, :conditions =&gt; "approved = true", :source =&gt; :user

  has_many :pending_friends, :through =&gt; :friendships, :conditions =&gt; "approved = false", :foreign_key =&gt; "user_id", :source =&gt; :user
  has_many :requested_friendships, :class_name =&gt; "Friendship", :foreign_key =&gt; "friend_id", :conditions =&gt; "approved = false"

  def friends
    direct_friends | inverse_friends
  end
  [...]
end</pre>
<p>The first two lines are pretty self-explanatory as the first references our &#8220;direct&#8221; Friendships and the second our &#8220;inverse&#8221; Friendships which we&#8217;ll be using as the basis of all of our friend lists.  Lines 5 and 6 simply create our direct and inverse friend lists, only looking at friendships which have been approved. These are states #1 and #2 from our discussion above and are complete, approved bi-directional friends lists.</p>
<p>Line 8 here creates the list of pending friends (state #3 above) by looking for direct friendships which have not been approved.  Then finally in line 9 we handle state #4 which are the &#8220;requested friendship&#8221; waiting for us to approve them, by taking all the non-approved Friendships where the current user is the target of the request (which is why we specify the foreign_key of &#8220;friend_id&#8221;).</p>
<p>And finally, because it would be a hassle to deal with two lists of approved friends, we create a method to simply combine them under the name of &#8220;friends&#8221;, in lines 11-13.</p>
<p>That&#8217;s it! You should be able to create and manage facebook-style friend requests now.</p>
<p>I&#8217;m not going to cover creation of the Friendship controller here in this post, but I may in the future if people would find it helpful.  In short, the controller needs to handle just five actions: index, create, approve, ignore, delete.  In my implementation, all actions except for index are used only for ajax calls through link_to_remote, so they&#8217;re pretty lightweight.</p>
<p><strong>Updated</strong>: the direct_friends line in the User model above was incorrectly using &#8220;:source =&gt; :user&#8221; when it should be &#8220;:source =&gt; :friend&#8221; so that the returned models are the Friends you requested, not yourself the requestor.</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2010/08/31/a-user-friend-relationship-model-in-rails/feed/</wfw:commentRss>
		<slash:comments>12</slash:comments>
		</item>
		<item>
		<title>Annoying Zune Behavior &#8211; Ordering &#8220;By&#160;Rating&#8221;</title>
		<link>http://iterat.ive.ly/index.php/2010/08/29/annoying-zune-behavior-ordering-by-rating/</link>
		<comments>http://iterat.ive.ly/index.php/2010/08/29/annoying-zune-behavior-ordering-by-rating/#comments</comments>
		<pubDate>Sun, 29 Aug 2010 19:27:28 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[quickie]]></category>
		<category><![CDATA[interface]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[zune]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=332</guid>
		<description><![CDATA[I want to sort my music &#8220;By Rating&#8221; in the Zune media player software. This is natural. But what&#8217;s wrong with this track order here? Yeah, the software puts the songs which have ratings above the songs without ratings, which in itself isn&#8217;t a bad idea. But this means that if you just start playing [...]]]></description>
			<content:encoded><![CDATA[<p>I want to sort my music &#8220;By Rating&#8221; in the Zune media player software. This is natural. But what&#8217;s wrong with this track order here?</p>
<p><img class="aligncenter size-full wp-image-333" title="zune-rating-order" src="http://iterat.ive.ly/wp-content/uploads/2010/08/zune-rating-order.jpg" alt="" width="400" height="193" /></p>
<p>Yeah, the software puts the songs which <em>have <span style="font-style: normal;">ratings </span></em>above the songs without ratings, which in itself isn&#8217;t a bad idea. But this means that if you just start playing down the list of your favorite songs <strong>right after your favorite songs it&#8217;s going to play the songs you hate the most.</strong> Then it continues with the rest of your library in alphabetical order.</p>
<p>Come on, Microsoft&#8230; you can do better. Just put the most hated tracks at the bottom of the playlist when I sort by rating.</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2010/08/29/annoying-zune-behavior-ordering-by-rating/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Rails Deployment: Engine Yard or&#160;Heroku?</title>
		<link>http://iterat.ive.ly/index.php/2010/08/29/rails-deployment-engine-yard-or-heroku/</link>
		<comments>http://iterat.ive.ly/index.php/2010/08/29/rails-deployment-engine-yard-or-heroku/#comments</comments>
		<pubDate>Sun, 29 Aug 2010 17:46:53 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[question]]></category>
		<category><![CDATA[ruby on rails]]></category>
		<category><![CDATA[learning-ror]]></category>
		<category><![CDATA[ruby]]></category>
		<category><![CDATA[software]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=324</guid>
		<description><![CDATA[As I&#8217;m thinking about beta launching my first Rails app, I need to decide how to do the deploy.  Heroku and Engine Yard stand out as the most popular hosts, from what I see. Heroku also has a free option, which appeals to me.  Is one much better than the other? Long-term, I will probably [...]]]></description>
			<content:encoded><![CDATA[<p>As I&#8217;m thinking about beta launching my first Rails app, I need to decide how to do the deploy.  Heroku and Engine Yard stand out as the most popular hosts, from what I see. Heroku also has a free option, which appeals to me.  Is one much better than the other?</p>
<p>Long-term, I will probably host the app myself at my colo, but to keep things simple at first I don&#8217;t want to learn the intricacies of Rails hosting right now&#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2010/08/29/rails-deployment-engine-yard-or-heroku/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Chart: A Very Productive&#160;Evening</title>
		<link>http://iterat.ive.ly/index.php/2010/08/28/chart-a-productive-evening/</link>
		<comments>http://iterat.ive.ly/index.php/2010/08/28/chart-a-productive-evening/#comments</comments>
		<pubDate>Sat, 28 Aug 2010 11:22:17 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[asides]]></category>
		<category><![CDATA[cool stuff]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[graphic]]></category>
		<category><![CDATA[meta]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=302</guid>
		<description><![CDATA[This is what learning a new language looks like: 50% time writing code, 25% time using chrome for research, and 10% time in firefox running and debugging the app. Clipped from RescueTime which is a fantastic freemium app that tracks everything you do on all of your computers and then does analysis of how you spend your time. Pretty [...]]]></description>
			<content:encoded><![CDATA[<p>This is what learning a new language looks like: <strong>50% </strong>time writing code, <strong>25%</strong> time using chrome for research, and <strong>10% </strong>time in firefox running and debugging the app.</p>
<p><img class="aligncenter" src="http://f.ive.ly/Aev.jpg" alt="" width="400" height="260" /></p>
<p>Clipped from <a href="http://rescuetime.com">RescueTime</a> which is a fantastic freemium app that tracks everything you do on all of your computers and then does analysis of how you spend your time.</p>
<p>Pretty cool, huh?</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2010/08/28/chart-a-productive-evening/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

