The Raconteurs Get What Prince Does Not

I received the following email from The Raconteurs today:

We are in the process of creating a live section of our website and need your assistance. We’ll have different areas where you can view video footage and photos from tour dates as well as hear select audio for some shows.

Here’s where we need your help, we’ve been scouring youtube for some video content that fans have shot at past shows and we’ll be adding some of that footage to the site. If you have footage you haven’t yet added to youtube please add it and feel free to send a link to the video for review to , be sure to include show date, venue, city name and video credit.

Jack White and company understand the value of their fans recording content and making it available on YouTube. Their aim isn’t to necessarily sell more records (recall that this is the band that broke all the rules for their most recent album, Consolers of the Lonely), it is to bring in people to their live shows.

Contrast this with how Prince handles his fans, and the differences couldn’t be more stark. Can you imagine Prince emailing his fan base and asking “If you have footage you haven’t yet added to youtube please add it…”?


Great EC2/S3 Tool

(cross-posted to the BaconMarathon blog)

Tim Kay of ActiveBuddy fame has been working on aws, which he says provides “simple access to Amazon EC2 and S3”. I ran into Tim a while ago and we chatted about aws – around the same time, I also heard about it from Mike.

As all the BaconMarathon apps are running on EC2 and using S3 for storage, I’ve been looking for an easier way to interface with S3 in particular. I finally got around to trying out aws the other day and found it be more than advertised. Finally, I had one simple command to examine buckets on S3:

aws ls

That was it. Creating buckets, puts and gets are just as simple:

aws mkdir BUCKET
aws get BUCKET

We’re now using aws to push our MySQL backups to S3 on a scheduled basis – a simple change to our existing backup jobs.

Technorati Tags: ,,,

Dialogs and Asynchronous Calls in Facebook

(Cross-posting to the BaconMarathon blog)

One feature of BaconMarathon's Top3Clicks Facebook application allows users to construct free-form item searches. The search queries are augmented and are used as we attempt to find items that are relevant to the user. To make this work, lots of things are going on in the back-end. The UI output is a list of items displayed in the rotator.

Like any application, we need to make this process as fast as possible, while providing the user visual cues to let them know the application is working quickly to provide a result. One of the strongest pieces of feedback we have had is in this area - and something we've tried to tackle in several different ways.

Our design goals were as follows:

  • call the back-end asynchronously
  • provide cues to the user via a UI dialog
  • tear-down (hide) the dialog when the back-end has completed its' tasks and refresh the UI with the latest information

Yesterday, we rolled out our latest iteration (shown below), which utilizes FBJS and Ajax. 



Using this post as a basis, we made a number of tweaks, most notably the ondone function of the asynchronous call (via handles the form submission and actual tear-down of the dialog. Implementing it was non-trivial as the FBML Test Console didn't seem to like any calls we made. Unfortunately, the onerror function does not provide any information about the cause of failure. Firebug was a large help -- make sure to use it if you are debugging FBJS.

Our current implementation looks something like this:


function showItemDialog() {    var title = 'Add Item'     var ok = 'Cancel'     //create dialog     var dialog = new Dialog().showMessage(title,add_dialog_fbml,ok);     var ajax = new Ajax();     ajax.responseType = Ajax.FBML;     ajax.requireLogin = true;     //ondone function, called when post returns     ajax.ondone = function(data) {         frm = document.getElementById(searchForm);         if (frm) { frm.submit(); }     dialog.hide();     };
  //onconfirm actually does nothing     dialog.onconfirm = function() { };     //grab input value and use in call     var item = document.getElementById('item').getValue();     var params={'item':item};"",params);


<form method="get" action= name="search" id="searchForm">  <input type=text name=item id=item>
<fb:js_string var="add_dialog_fbml">  <div id="add_dialog">    <div class="dialog_loading">      <img src=""/> Retrieving item info ...    </div>  </div></fb:js_string>
Try it out and let us know what you think!

3 Good Books for Facebook Developers

(Note this is cross-posted to the BaconMarathon blog)

If you are building an app for Facebook, good information can be hard to find. The Developer Docs do a decent job at getting you up to speed, but don't dive too deep.

A few of my favorite books at the moment are:

1. Facebook Application Development - most heavily used book in my collection. Solid examples, minimal errata.


2. Facebook Applications - Good sample app in the last third of the book that goes beyond simple implementation.



3. Facebook API Developers Guide - Great kick-starter, super quick read. Doesn't dive deep, but lays it out in a readily consumable fashion.

One overall issue - I haven't found a book that uses anything other than PHP. As we're using Java for our BaconMarathon apps, we've had to do a bit of "translation", but it hasn't slowed things down much.