I’m starting up a new personal project involving Ember-Data and Rails
(more to come). The gist of it is that it’s a pure frontend app engine
built in Yeoman and Grunt, and designed to talk to a remote API service
built on Rails.
So since it’s a remote API, I’ve got to enable CORS, right?
Install CORS via rack-cors
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
A very naive implementation with zero security whatsoever. Anyways.
Get Ember-Data DS.RESTAdapter talkin’ CORS
I saw conflicting documentation on Ember-Data and CORS – it seemed like
it should support CORS out of the box. Apparently this is not so.
In my ember app’s
store.js (or anywhere your app loads before the
application adapter is defined, do this:
1 2 3 4 5 6 7 8 9 10 11 12
$.ajaxSetup, though its
usage is not recommended, is designed to set global options on the
ajax object. It provides some information on the options you can modify.
Why doesn’t Ember support this out of the box? I think it’s because they
cannot support IE, where one must use an XDR object to support CORS.
I’ve posted an Ember follow-up question in the
forums for discussion.
Get Rails talking JSON out of its mimetype confusion.
Did you know that if you rely on the
Accepts: header in HTTP that
Rails does not obey its ordering
*? I was trying to figure out why my
Rails controllers were trying to render HTML instead of JSON when the
A very long winded
discussion on the Rails
project reveals that, well, nobody has it figured out yet. Most modern
browsers do obey
Accepts: specificity, but for the sake of older
browser compatibility, the best practice for browsers is still to return
*/* is specified.
What does this mean for Rails developers who want to use
mimetype lists? Well, we either wait for the Rails projects to support
mimetype specificity (and for older browsers to die out), or we are
encouraged to include the format explicitly in the URI.
I chose to have Ember append the
.json suffix to the URL, thanks to
1 2 3 4 5 6 7 8
More to come how how this app works.