X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/0c8ad2f86edefed72052b402742cadedb0d674d9..526ff061727cd1142350b08eae031294908d0b27:/app/assets/javascripts/oauth.js diff --git a/app/assets/javascripts/oauth.js b/app/assets/javascripts/oauth.js index 40f685cc7..98ce302e1 100644 --- a/app/assets/javascripts/oauth.js +++ b/app/assets/javascripts/oauth.js @@ -1,25 +1,25 @@ -//= require sha //= require 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 () { + function makeAbsolute(url) { + var a = document.createElement('a'); + a.href = url; + return a.href; + } - params.oauth_signature = ohauth.signature( - OSM.oauth_consumer_secret, - OSM.oauth_token_secret, - ohauth.baseString(options.type, url, $.extend({}, params, jqxhr.data)) - ); + if (OSM.oauth_token) { + var headerGenerator = window.ohauth.headerGenerator({ + consumer_key: OSM.oauth_consumer_key, + consumer_secret: OSM.oauth_consumer_secret, + token: OSM.oauth_token, + token_secret: OSM.oauth_token_secret + }); - 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); + } + }); } });