Nitobi
About Nitobi
Services
Products
Home -> Blogs -> Brian@Nitobi

Brian@Nitobi

Rogers Wireless Customer Service Failure

June 17th, 2008

My wallet and phone were stolen from the YWCA gym right out of my locker. The thief must have used bolt cutters when nobody was around. It was a real disappointment but the staff where helpful and after hours on various automated systems I had a police case number, my credit cards canceled and my phone locked so nobody could make long distance calls.

The bank was helpful and sympathetic. The credit card companies took it upon themselves to call me and the police to follow up about fraudulent charge attempts.

However, Rogers Wireless left me feeling like shit.

I called Rogers Wireless that night and they assured me the phone was locked so no calls could be made and to just go to a store the next day and they would help me get a new phone and SIM card. When I arrived at the store they told me I had to purchase the new phone and renew (thus extend) my contact. ‘This was not the impression the agent on the phone gave me.’, I said and they responded, ‘Those guys are retards. We only their sell phones. We’re like a car dealership.’. I’m not kidding you. That is what a retailer, with the Rogers sign and exclusively Rogers products told me. Those guys are retards? They had the good nature to call customer service on my behalf and things degraded to, ‘Its your own fault your phone was stolen SIR, not ours’. I felt like I was being scolded for even thinking they were going to help. I bought a new SIM card deciding I’d find a phone on my own and the agent hesitantly informed me, ‘uuuhhh, your phone was never locked’. I called customer service again and the agent sneered ‘those retailer people don’t know what they’re talking about.’ No long distance calls on my phone, at least.

I walked out tired, angry and disappointed. Negative and poisonous.

This incident represents an epic failure of a brand experience. The people in the store and on the phone represented a confidence destroying lack of professionalism and complete disregard for my misfortune. As a customer I, perhaps naively, expected to be treated better than that.

With complex pyramid scheme like plans, disparate messaging, disregard for the customer and belligerent employee hubris I doubt Rogers Wireless can continue to be a success as more companies enter into the wireless space. As a human being first and a consumer second I am now actively seeking better options.

Digg! | Del.icio.us

Posted in rant | 5 Comments »

Ajax and Scotch - TONIGHT!

May 22nd, 2008

At the Shebeen Room. Be there!
Be there or your hair is a bird!

Digg! | Del.icio.us

Posted in Uncategorized, air, ajax, brian.leroux, flash, flex, papervision3d, rant, software | No Comments »

Enumerate a range of dates with Ruby

May 5th, 2008

Quick snippet, having fun with dates.


require 'rubygems'
require 'activesupport'

date_range = (DateTime.now-10.days)..DateTime.now

date_range.each { |e| puts e }

Digg! | Del.icio.us

Posted in Uncategorized | 1 Comment »

Papervision3D Training w/ John Grden

May 5th, 2008

This past weekend James and I had the pleasure of taking in some Papervision3D training.

Papervision3D, for the uninitiated, is a full fledged 3D engine in ActionScript 3. Its blazing fast and totally sweet.

John Grden is a great teacher and, as a result, the course was very approachable for programmer and designer alike. He was careful to ensure everyone was working at the same pace and no one was left behind. His descriptions where clear and whenever in doubt he pointed out additional resources for our own study outside the class.

Day one was high level, API and capability overview. Quick demos of the overall Papervision architecture, history and direction.

Day two was deeper, looking into the more advanced capabilities and getting us to code for ourselves. Animation, interactivity, effects, colladas and performance tuning. I had a little trouble getting Flex Builder to play nice but after some gentle coaxing I was able to create an extremely rudimentary demo, by hand, with no trouble.

Papervision is an impressive platform. The potential for creating an innovative user experience is there from enhancing your existing RIA with some simple effects to full blown game development. Not to mention a 3D AIR application. I found the API to be very approachable once I understood the concepts behind the library.

I’m looking forward to building something a little more substantial with it … soon! Until then, here’s some resources:

Main site:
http://blog.papervision3d.org/

Documentation:
http://www.papervision3d.org/docs/as3/

Developers blog:
http://dev.papervision3d.org/

Mailing list:
http://osflash.org/mailman/listinfo/Papervision3D_osflash.org

Digg! | Del.icio.us

Posted in Uncategorized, air, flash, flex, papervision3d | No Comments »

Ruby case statements in ERB

March 14th, 2008

Fail spectacularly if you happen to indent incorrectly (but not intuitively). Thankfully, Jamis Buck points out a simple solution on the Ruby mailing list:


<% case number
when 1 %>
one
<% when 2 %>
two
<% else %>
something else
<% end %>

Thank you Jamis!

Digg! | Del.icio.us

Posted in Uncategorized | No Comments »

Ruby recognized

March 10th, 2008

Each year O’Reilly publishes on their blog a State of the Computer Book Market analysis. It is an excellent indicator of computer programming language trends. Geeks love their books and programming geeks adorn their desks with as many reference books as possible. Despite living in a hyper connected world we cannot risk even one moment without access to the more obscure and arcane intricacies of our chosen languages and toolsets.

And Ruby is cleaning up: officially recognized as a “Mid-Major Programming Language”. And in good company too with Visual Basic and ActionScript.

Perhaps its the growing body of knowledge or perhaps its just the beauty and simplicity of the language itself. Probably a little bit of both. Its nice to see such a fun and rewarding environment growing into the hearts of the mainstream. We love Ruby here at Nitobi and we have grown a good number of Ruby projects and expertise. With Java and, soon, .NET support we’re looking forward to bringing Ruby to even more places. And adding more books to our shelves!

Digg! | Del.icio.us

Posted in .NET, IronRuby, JRuby, java, nitobi, rails, ror, ruby, software | No Comments »

Tab sweeping

February 8th, 2008

Ever since Firefox introduced tabbed browsing and session saver kept things alive after crashing, surfers everywhere use the tabs to store the sites they’re interested in and want to take a closer look at — but aren’t going to bookmark — at least not yet.

In the “Getting Things Done” philosophy we should always Do, Delegate or Defer any action item immediately to stay on task, be productive and focused. Well, as much of a GTD guy I want to be I always end up with a swath of tabs by Friday. So be it. I’ll defer them to this blog.

More REST and Less Code with Merb

The RESTful way of development is old hat for many Rails guys at this point and the one common complaint is the repetitious boilerplate scaffold code with respond_to for each mime type. Merb is learning from Rails and, in particular, the Merb Responder and “provides” inteface abstracts these idioms from the controller cleaning things up. I love it.

Flash based PDF viewer

Viewing PDF documents isn’t too bad but if you can avoid the jarring effect of the loading dialogue and provide a slicker web based interface then why not. Check out Issuu for their inspired user experience that is web based and by far one of the best viewers for PDF I’ve come across.

RESTful Authentication: The Definitive Guide

Not only authentication but authorization with roles and permissions and, possibly the kitchen sink too. This is the most comprehensive guide I’ve seen to the common pattern of user accounts in a web based software system.

Digg! | Del.icio.us

Posted in Uncategorized | No Comments »

Ajax and Beer 2.0

February 6th, 2008

Tonight its on, like Megatron, another installment of the formidable meetup. Now with more beer!

If that isn’t enough, you find myself and other Nitobians out tomorrow night at DemoCamp Vancouver. Do we have something to demo? Come and find out.

If demos and presentations aren’t your thing then do not despair, my hacker friends, this Sat we’re hosting Nitobi Hack Day 2.0. We have beer. We have shwag. We have giant sandwich. Join us in capturing the elusive Balmer peak and score some free stuff.

Digg! | Del.icio.us

Posted in Uncategorized | No Comments »

Super fast full text search on Rails with Sphinx and Ultrasphinx

January 30th, 2008

Full text search is difficult, I mean really hard to do right, with good relevance, filterable, fast querying and indexing. Searching is just not something that any business should be trying to solve as a core objective unless they are planning to taking on the Google… or they have reams of unstructured data in weird silos without any other way of accessing it. Search simply should not replace solid Information Architecture. Content should be inherently findable without an ambiguous search box. The use cases for a powerful full text search are those very rare instances where there is either just a tonne of content that is too difficult to classify or you are interacting with content that has little or no structure, metadata or taxonomy.

And, of course, my next big project, required full text search. Massive amounts of data. Very little structure. Disparate content sources.

In past projects I’ve had some limited success, and spectacular failure, with Ferret, a Ruby port of the Java based Lucene search. It was slow, leaked memory and generally caused more pain than it should.

The next full text search project I ran into our client decided that the Google Mini Search Appliance would be the cheapest and quickest the way to go. He was right. It provides an out of the box search interface experience with fantastic relevance. This is mighty Google in a box afterall. The downside? Google Mini has limited customization without cycling through reams of skanky XSL/T. Deep integration is nearly impossible. That’s an ok tradeoff depending on your goals. For our project it just wouldn’t work.

My next thought was a project called Solr which is essentially an abstraction layer on top of (again) Lucene. Solr has an accompanying Rails plugin called, appropriately, acts_as_solr. The only issue, I could immediately see with Solr, is having to maintain a second server instance, which is generally something you’ll nearly always have to do for full text search.

Then Sphinx happens to appear on my radar via the excellent Deploying Rails Google Group. To make a long story short here’s a couple of quotes from Ezra Zygmuntowicz, of Engine Yard fame, who literally wrote the book on deploying rails applications:

Ferret is unstable in production. Segfaults, corrupted indexes galore. We’ve switched around 40 clients form ferret to sphinx and solved their problems this way. I will never use ferret again after all the problems I have seen it cause peoples production apps. Plus sphinx can reindex many many times faster then ferret and uses
less cpu and memory as well.

Right about here you can hear me say in a western Canadian accent, “Sphinx eh..”. Ezra continues in a later post:

We have a bunch of clients using solr as well. In general it is more powerful then sphinx but a lot slower to reindex and querey. Also it uses 50 times the memory of sphinx. If you have a box or vm to put SOLR on by itself then it is a good option as well. but if sphinx can do everything you need from a a search indexer then it is a way better option cost wise.

Ok. I was fully intrigued in this crazy Sphinx. A little searching around I came across an excellent article from Ben Smith about using Rails with Sphinx. Following his instructions for compiling with support for MySQL 5 installed via Darwin Ports was pretty easy. I chose the Ultrasphinx plugin which makes working with Sphinx trivial. He mentions acts_as_sphinx and the predictably named Sphincter which I plan to revisit eventually.

So, how is Sphinx with Ultrasphinx? Awesome. I can’t quite reveal what exactly I’m working on, but I can say that I had recently downloaded all the page titles from Wikipedia and imported roughly 2.4 million of them into MySQL 5 into three columns. The first column is an integer index. The second is the raw page title. The final column is the page title with formatting removed and underscores replaced by spaces. You know, human readable and all that.

Running a hand rake task for indexing outputs:


collected 2409850 docs, 67.8 MB
sorted 8.9 Mhits, 100.0% done
total 2409850 docs, 67771103 bytes
total 34.220 sec, 1980424.75 bytes/sec, 70421.26 docs/sec

Roughly 34 seconds to index 2.4 million records. Not bad. I’ve had faster times so it might be time for me to reboot the old macbook. But what about actual searching? Consistently under a second. Relevance? Very good.

The verdict: Sphinx rocks.

Digg! | Del.icio.us

Posted in Uncategorized | No Comments »

A slightly better terminal experience for OS X

January 29th, 2008

Visor

A quake style terminal for OS X. Simply badass for the old school first person shooter gamer in you.

Tabs

Of course, just having a terminal instance available whenever to ‘drop in’ is sweet but most of us need more than one terminal at a time. No problem. Add tab support to your terminal. Awesome.

Syntax highlighting?

From the same blog there is an article about syntax highlighting with terminal but I cannot seem to get it working. Any suggestions from the lazy web are appreciated! I use textmate for the most part so I’m surviving but it would be nice to have. Seems like a major shortcoming on Apple’s part.

Digg! | Del.icio.us

Posted in Uncategorized | No Comments »


Search Posts

Pages

Archives

Categories

All contents are (c) Copyright 2006, Nitobi Software Inc. All rights Reserved
Brian@Nitobi Entries (RSS) and Comments (RSS).