X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/84f7d322d01639a9a4617ff2f3f635e2e1e2cfc6..93b8c47c8fa1aac86d2d9c730c327c076b578a84:/app/assets/javascripts/oauth.js?ds=inline diff --git a/app/assets/javascripts/oauth.js b/app/assets/javascripts/oauth.js index 40f685cc7..d688590b0 100644 --- a/app/assets/javascripts/oauth.js +++ b/app/assets/javascripts/oauth.js @@ -1,25 +1,27 @@ -//= require sha -//= require ohauth +//= require ohauth/ohauth -$.ajaxPrefilter(function(options, jqxhr) { - if (options.oauth && OSM.oauth_token) { - var ohauth = window.ohauth; - var url = options.url.replace(/\?$/, ""); - var params = { - oauth_consumer_key: OSM.oauth_consumer_key, - oauth_token: OSM.oauth_token, - oauth_signature_method: "HMAC-SHA1", - oauth_timestamp: ohauth.timestamp(), - oauth_nonce: ohauth.nonce() - }; +$(document).ready(function () { + var application_data = $("head").data(); - params.oauth_signature = ohauth.signature( - OSM.oauth_consumer_secret, - OSM.oauth_token_secret, - ohauth.baseString(options.type, url, $.extend({}, params, jqxhr.data)) - ); + function makeAbsolute(url) { + var a = document.createElement("a"); + a.href = url; + return a.href; + } + + if (application_data.token) { + var headerGenerator = window.ohauth.headerGenerator({ + consumer_key: application_data.consumerKey, + consumer_secret: application_data.consumerSecret, + token: application_data.token, + token_secret: application_data.tokenSecret + }); - options.headers = options.headers || {}; - options.headers.Authorization = "OAuth " + ohauth.authHeader(params); + $.ajaxPrefilter(function (options, jqxhr) { + if (options.oauth) { + options.headers = options.headers || {}; + options.headers.Authorization = headerGenerator(options.type, makeAbsolute(options.url), jqxhr.data); + } + }); } });