<?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; howto</title>
	<atom:link href="http://iterat.ive.ly/index.php/tag/howto/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>Authlogic Perishable Token changes and breaks&#160;emails</title>
		<link>http://iterat.ive.ly/index.php/2010/09/21/authlogic-perishable-token-unexpectedly-changed-breaking-emails/</link>
		<comments>http://iterat.ive.ly/index.php/2010/09/21/authlogic-perishable-token-unexpectedly-changed-breaking-emails/#comments</comments>
		<pubDate>Wed, 22 Sep 2010 01:54:39 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[ruby on rails]]></category>
		<category><![CDATA[howto]]></category>
		<category><![CDATA[learning-ror]]></category>
		<category><![CDATA[ruby]]></category>
		<category><![CDATA[tip]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=524</guid>
		<description><![CDATA[Overall, I think Authlogic is pretty great.  It&#8217;s saved me a bunch of time that I don&#8217;t have to worry about user creation and user session maintenance.  But this one little doozy was causing some issues when sending out one-time-use emails like invites or password resets. The perishable_token is the suggested way to send out [...]]]></description>
			<content:encoded><![CDATA[<p>Overall, I think Authlogic is pretty great.  It&#8217;s saved me a bunch of time that I don&#8217;t have to worry about user creation and user session maintenance.  But this one little doozy was causing some issues when sending out one-time-use emails like invites or password resets.</p>
<p>The perishable_token is the suggested way to send out secured one-time-use emails because it&#8217;s updated every time the User model is updated (like, when the user logs in) so the email can&#8217;t be re-used to reset the password again for instance.  I&#8217;m using it in some pretty strange ways to handle proxy users (users who haven&#8217;t actually registered yet on our site), but this issue also is present for the password-reset case.</p>
<p>I noticed that some users were getting rejected after clicking the link in the email saying that the perishable token was no longer valid. &#8220;That can&#8217;t be right,&#8221; I thought to myself &#8211; because I know for a fact that some of those users hadn&#8217;t logged in.  But their token was still invalid. So after a little bit of troubleshooting, I realized the issue&#8230;.</p>
<p>The token is updated every time the User object is saved. Not just when they login.  And I have jobs running in the background to update the users with external data pulled from various APIs.  So my job was resetting the perishable_token for every user it touched.  Ok, so how did I fix the issue?  Simple really &#8211; I just took control of the maintenance of the perishable_token away from Authlogic and handled it myself.</p>
<p><span id="more-524"></span>So now, the token is reset at exactly two times: User creation and on a successful login.  No more craziness.</p>
<p>I added line 3 to the User model, to tell Authlogic to take a hike:</p>
<pre class="brush:ruby; toolbar:false; highlight:3">class User &lt; ActiveRecord::Base
  acts_at_authentic
  disable_perishable_token_maintenance(true)
  ...
end</pre>
<p>And also added line 4 to my UserSessions controller, to update the token on successful login:</p>
<pre class="brush:ruby; toolbar:false; highlight:4">def create
  @user_session = UserSession.new(params[:user_session])
  if @user_session.save
  @user_session.user.reset_perishable_token!
  flash[:notice] = "Login successful!"
  redirect_to root_url
end</pre>
<p>Finally, I added line 3 and 4 to the Users controller, to create a token in the first place:</p>
<pre class="brush:ruby; toolbar:false; highlight:3-4">def create
  @user = User.new(params[:user])
  @user.reset_perishable_token
  @user.reset_single_access_token
  if(@user.save)
    redirect_to account_path
  else
    render :action =&gt; :new
  end
end</pre>
<p>That&#8217;s it. Now my emails will still work even with jobs running and the user objects being updated in the background!</p>
<p><strong>Update 9/22:</strong> fixed an error on line 4 of the UserSessions controller above, was doing @user.reset_perishable_token! but should be @user_session.user.reset_perishable_token!</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2010/09/21/authlogic-perishable-token-unexpectedly-changed-breaking-emails/feed/</wfw:commentRss>
		<slash:comments>1</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>HOWTO: Export IIS7 Configuration to Another&#160;Webserver</title>
		<link>http://iterat.ive.ly/index.php/2009/06/10/howto-export-iis7-configuration-to-another-webserver/</link>
		<comments>http://iterat.ive.ly/index.php/2009/06/10/howto-export-iis7-configuration-to-another-webserver/#comments</comments>
		<pubDate>Wed, 10 Jun 2009 21:15:15 +0000</pubDate>
		<dc:creator>Christopher Gooley</dc:creator>
				<category><![CDATA[dot.net]]></category>
		<category><![CDATA[tech]]></category>
		<category><![CDATA[.net]]></category>
		<category><![CDATA[howto]]></category>
		<category><![CDATA[iis7]]></category>
		<category><![CDATA[infrastructure]]></category>
		<category><![CDATA[IT]]></category>
		<category><![CDATA[servers]]></category>
		<category><![CDATA[software]]></category>

		<guid isPermaLink="false">http://iterat.ive.ly/?p=140</guid>
		<description><![CDATA[IIS7 has this great new feature called Shared Configuration.  Except that it has a tendency to do horrible things which usually result in all the websites and application pools being removed from your server and your production website starting to serve 503 Service Unavailable errors. For an innexplicable reason, Microsoft decided to kill the Export [...]]]></description>
			<content:encoded><![CDATA[<p>IIS7 has this great new feature called Shared Configuration.  Except that it has a tendency to do horrible things which usually result in all the websites and application pools being removed from your server and your production website starting to serve 503 Service Unavailable errors.</p>
<p>For an innexplicable reason, Microsoft decided to kill the Export function from IIS7 in favor of this new feature.  But for those of us who don&#8217;t trust technology, we like to do things manually and to get a repeatable result that doesn&#8217;t update automatically when we least expect it.  Yes, I am the sort of person who wonders why the default Windows Update on servers is to Install and Reboot Automatically at 2am&#8230;</p>
<p>In any case, in a simple 3 step process you too can export and import your Internet Information Server 7 websites and app pools.<span id="more-140"></span></p>
<p>I will call the target server TWEB (this is the server where you want a duplicate configuration) and the source server SWEB (this is where the current configuration exists).</p>
<p>First, on TWEB make a backup copy of the files in C:\Windows\System32\inetsrv\config.  I just created a subfolder called &#8220;bak&#8221; and copied them.  <strong>This is very important.  If you forget or skip this step because backups are for sissies, you will be re-installing IIS7 in step 4.</strong></p>
<p>Second, copy the AppliationHost.config from SWEB into the C:\Windows\System32\inetsrv\config folder on TWEB.  Also copy any application files like your c:\websites folder or whatever over to TWEB in the appropriate location if you haven&#8217;t already.</p>
<p><img class="alignright" src="http://f.ive.ly/Aen.jpg" alt="" width="198" height="110" />Third, on TWEB open both the new ApplicationHost.config and the backup ApplicationHost.config from step 1 and locate the &lt;configProtectedData&gt; node in the backup.  Copy that node and replace it into the new config file.</p>
<p>Fourth, if you didn&#8217;t backup the existing config file, remove the IIS role and add it back, then start at step 1.</p>
<p><strong>Note:</strong> if you have custom accounts under which you&#8217;re running app pools (cuz you&#8217;re not using LocalSystem, right?) then you just need to go into the IIS Management Console and re-configure the passwords for those accounts.  They were encrypted with the other server&#8217;s AES keys so they won&#8217;t be valid on this server and the pools won&#8217;t start.</p>
<p>That&#8217;s it.  Hope that helps.  It should work the same for C# .NET applications (which is what I&#8217;m using) or just static websites or whatever.  But of course, you shouldn&#8217;t trust me.  Test it yourself first.</p>
<p>My new good-karma policy is that if I spend more than an hour tracking down a general bug or wacky configuration thing, I promise to blog the solution.</p>
]]></content:encoded>
			<wfw:commentRss>http://iterat.ive.ly/index.php/2009/06/10/howto-export-iis7-configuration-to-another-webserver/feed/</wfw:commentRss>
		<slash:comments>15</slash:comments>
		</item>
	</channel>
</rss>

