Replacement Eyehome software using Ruby on Rails
data:image/s3,"s3://crabby-images/ca784/ca7841f8971ba9a163a8c125c44878797f5e53a2" alt=""
Hmmm. HTTP. HTML. Sounds like a job for... Ruby on Rails!
data:image/s3,"s3://crabby-images/5982e/5982eb0ec0025aa57e5be591d72b7c242155d24b" alt=""
This is how an earlier version of the MyHome looks on my TV downstairs (you can see that this picture was taken around Mothers Day):
data:image/s3,"s3://crabby-images/e640f/e640f988e01585ddfb97438b8742570d66b00b8f" alt=""
data:image/s3,"s3://crabby-images/4bd64/4bd649b76ca0e2c1f45c0af23c3e0a7d8a17621d" alt=""
- There's a "breadcrumb" UI element in the left pane, where it says "Location". This allows jumping back up the directory tree quickly from the remote.
- There's a "Categories" section on the left hand side as well. This is a listing of all the genres of all the movies in the current folder. Selecting a genre will display only the movies tagged with that genre. So if I want to watch a "Western", I'll get a shorter list with Tombstone and Blazing Saddles in it.
- The current folder is displayed as "Movies for Adults" in this screenshot, but the actual folder name on disk is "Parents" (vs the "Kids") folder. This is accomplished via metadata sotred with each folder (in a YAML file; Ruby likes yaml), as is the next feature: access control.
- The lock in the upper-right indicates that an access code has been entered, as the "Parents" folder is restricted.
- Note that "The Aviator" is appearing with movies whose titles begin with "A". The MyHome software generates a "sortable title" for each item that does things such as move "The" to the end.
- The item names are not just the filenames minus the ".avi" -- although it falls back to that in the absence of available metadata. It's the full title of the movie plus the year it was released (or the date in the case of TV series, plus season and episode).
data:image/s3,"s3://crabby-images/84d62/84d62f83ea086d1d97d96313ff6eac9cfcebe277" alt=""
Choosing an item displays details for the item. As seen in the next screenshot, it displays a boxshot/cover art, the title, a plot synopsis, IMDB rating, genres, MPAA rating and other details.
data:image/s3,"s3://crabby-images/15a5d/15a5dab6b7c18d40554123e1f0533619130c9e97" alt=""
To help me obtain the metadata, I have also written a Cocoa (Mac OS X) application that does the following:
- accepts a drag-and-drop of a video file
- looks it up by title in IMDB
- renames the file with the "canonical IMDB name" (title plus year)
- saves a plist containing the IMDB info.
By storing the metadata in text files alongside the real movie files, I can realize a few advantages.
- I can edit the metadata using a text editor if I want to. This isn't a big advantage, but it's a small one. For most things, the editing built into the rails app keeps me from having to.
- I don't depend on any special access to manage the movie files. I can zip into the fileserver via nfs, smb or afp and rearrange, copy or delete stuff as I see fit. I can also ssh into the fileserver and use cli tools.
- The deployment footprint of the rails app is small. It doesn't require a database.
<< Home