mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-27 07:34:20 +00:00
Bug 974990 - hawk request to access lang prefs as infrequently as possible. r=rnewman
--HG-- rename : services/common/hawk.js => services/common/hawkclient.js rename : services/common/tests/unit/test_hawk.js => services/common/tests/unit/test_hawkclient.js
This commit is contained in:
parent
56129edf1c
commit
ceb73476f1
@ -3,7 +3,8 @@
|
||||
# You can obtain one at http://mozilla.org/MPL/2.0/.
|
||||
|
||||
modules := \
|
||||
hawk.js \
|
||||
hawkclient.js \
|
||||
hawkrequest.js \
|
||||
storageservice.js \
|
||||
stringbundle.js \
|
||||
tokenserverclient.js \
|
||||
|
@ -31,7 +31,7 @@ const {interfaces: Ci, utils: Cu} = Components;
|
||||
Cu.import("resource://gre/modules/FxAccountsCommon.js");
|
||||
Cu.import("resource://services-common/utils.js");
|
||||
Cu.import("resource://services-crypto/utils.js");
|
||||
Cu.import("resource://services-common/rest.js");
|
||||
Cu.import("resource://services-common/hawkrequest.js");
|
||||
Cu.import("resource://gre/modules/Promise.jsm");
|
||||
|
||||
/*
|
145
services/common/hawkrequest.js
Normal file
145
services/common/hawkrequest.js
Normal file
@ -0,0 +1,145 @@
|
||||
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
||||
* You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
"use strict";
|
||||
|
||||
const {classes: Cc, interfaces: Ci, utils: Cu, results: Cr} = Components;
|
||||
|
||||
this.EXPORTED_SYMBOLS = [
|
||||
"HAWKAuthenticatedRESTRequest",
|
||||
];
|
||||
|
||||
Cu.import("resource://gre/modules/Preferences.jsm");
|
||||
Cu.import("resource://gre/modules/Services.jsm");
|
||||
Cu.import("resource://gre/modules/XPCOMUtils.jsm");
|
||||
Cu.import("resource://gre/modules/Log.jsm");
|
||||
Cu.import("resource://services-common/rest.js");
|
||||
|
||||
XPCOMUtils.defineLazyModuleGetter(this, "CryptoUtils",
|
||||
"resource://services-crypto/utils.js");
|
||||
|
||||
const Prefs = new Preferences("services.common.rest.");
|
||||
|
||||
/**
|
||||
* Single-use HAWK-authenticated HTTP requests to RESTish resources.
|
||||
*
|
||||
* @param uri
|
||||
* (String) URI for the RESTRequest constructor
|
||||
*
|
||||
* @param credentials
|
||||
* (Object) Optional credentials for computing HAWK authentication
|
||||
* header.
|
||||
*
|
||||
* @param payloadObj
|
||||
* (Object) Optional object to be converted to JSON payload
|
||||
*
|
||||
* @param extra
|
||||
* (Object) Optional extra params for HAWK header computation.
|
||||
* Valid properties are:
|
||||
*
|
||||
* now: <current time in milliseconds>,
|
||||
* localtimeOffsetMsec: <local clock offset vs server>
|
||||
*
|
||||
* extra.localtimeOffsetMsec is the value in milliseconds that must be added to
|
||||
* the local clock to make it agree with the server's clock. For instance, if
|
||||
* the local clock is two minutes ahead of the server, the time offset in
|
||||
* milliseconds will be -120000.
|
||||
*/
|
||||
|
||||
this.HAWKAuthenticatedRESTRequest =
|
||||
function HawkAuthenticatedRESTRequest(uri, credentials, extra={}) {
|
||||
RESTRequest.call(this, uri);
|
||||
|
||||
this.credentials = credentials;
|
||||
this.now = extra.now || Date.now();
|
||||
this.localtimeOffsetMsec = extra.localtimeOffsetMsec || 0;
|
||||
this._log.trace("local time, offset: " + this.now + ", " + (this.localtimeOffsetMsec));
|
||||
|
||||
// Expose for testing
|
||||
this._intl = getIntl();
|
||||
};
|
||||
HAWKAuthenticatedRESTRequest.prototype = {
|
||||
__proto__: RESTRequest.prototype,
|
||||
|
||||
dispatch: function dispatch(method, data, onComplete, onProgress) {
|
||||
let contentType = "text/plain";
|
||||
if (method == "POST" || method == "PUT") {
|
||||
contentType = "application/json";
|
||||
}
|
||||
if (this.credentials) {
|
||||
let options = {
|
||||
now: this.now,
|
||||
localtimeOffsetMsec: this.localtimeOffsetMsec,
|
||||
credentials: this.credentials,
|
||||
payload: data && JSON.stringify(data) || "",
|
||||
contentType: contentType,
|
||||
};
|
||||
let header = CryptoUtils.computeHAWK(this.uri, method, options);
|
||||
this.setHeader("Authorization", header.field);
|
||||
this._log.trace("hawk auth header: " + header.field);
|
||||
}
|
||||
|
||||
this.setHeader("Content-Type", contentType);
|
||||
|
||||
this.setHeader("Accept-Language", this._intl.accept_languages);
|
||||
|
||||
return RESTRequest.prototype.dispatch.call(
|
||||
this, method, data, onComplete, onProgress
|
||||
);
|
||||
}
|
||||
};
|
||||
|
||||
// With hawk request, we send the user's accepted-languages with each request.
|
||||
// To keep the number of times we read this pref at a minimum, maintain the
|
||||
// preference in a stateful object that notices and updates itself when the
|
||||
// pref is changed.
|
||||
this.Intl = function Intl() {
|
||||
// We won't actually query the pref until the first time we need it
|
||||
this._accepted = "";
|
||||
this._everRead = false;
|
||||
this._log = Log.repository.getLogger("Services.common.RESTRequest");
|
||||
this._log.level = Log.Level[Prefs.get("log.logger.rest.request")];
|
||||
this.init();
|
||||
};
|
||||
|
||||
this.Intl.prototype = {
|
||||
init: function() {
|
||||
Services.prefs.addObserver("intl.accept_languages", this, false);
|
||||
},
|
||||
|
||||
uninit: function() {
|
||||
Services.prefs.removeObserver("intl.accept_languages", this);
|
||||
},
|
||||
|
||||
observe: function(subject, topic, data) {
|
||||
this.readPref();
|
||||
},
|
||||
|
||||
readPref: function() {
|
||||
this._everRead = true;
|
||||
try {
|
||||
this._accepted = Services.prefs.getComplexValue(
|
||||
"intl.accept_languages", Ci.nsIPrefLocalizedString).data;
|
||||
} catch (err) {
|
||||
this._log.error("Error reading intl.accept_languages pref: " + CommonUtils.exceptionStr(err));
|
||||
}
|
||||
},
|
||||
|
||||
get accept_languages() {
|
||||
if (!this._everRead) {
|
||||
this.readPref();
|
||||
}
|
||||
return this._accepted;
|
||||
},
|
||||
};
|
||||
|
||||
// Singleton getter for Intl, creating an instance only when we first need it.
|
||||
let intl = null;
|
||||
function getIntl() {
|
||||
if (!intl) {
|
||||
intl = new Intl();
|
||||
}
|
||||
return intl;
|
||||
}
|
||||
|
@ -10,7 +10,6 @@ this.EXPORTED_SYMBOLS = [
|
||||
"RESTRequest",
|
||||
"RESTResponse",
|
||||
"TokenAuthenticatedRESTRequest",
|
||||
"HAWKAuthenticatedRESTRequest",
|
||||
];
|
||||
|
||||
#endif
|
||||
@ -725,75 +724,3 @@ TokenAuthenticatedRESTRequest.prototype = {
|
||||
},
|
||||
};
|
||||
|
||||
/**
|
||||
* Single-use HAWK-authenticated HTTP requests to RESTish resources.
|
||||
*
|
||||
* @param uri
|
||||
* (String) URI for the RESTRequest constructor
|
||||
*
|
||||
* @param credentials
|
||||
* (Object) Optional credentials for computing HAWK authentication
|
||||
* header.
|
||||
*
|
||||
* @param payloadObj
|
||||
* (Object) Optional object to be converted to JSON payload
|
||||
*
|
||||
* @param extra
|
||||
* (Object) Optional extra params for HAWK header computation.
|
||||
* Valid properties are:
|
||||
*
|
||||
* now: <current time in milliseconds>,
|
||||
* localtimeOffsetMsec: <local clock offset vs server>
|
||||
*
|
||||
* extra.localtimeOffsetMsec is the value in milliseconds that must be added to
|
||||
* the local clock to make it agree with the server's clock. For instance, if
|
||||
* the local clock is two minutes ahead of the server, the time offset in
|
||||
* milliseconds will be -120000.
|
||||
*/
|
||||
this.HAWKAuthenticatedRESTRequest =
|
||||
function HawkAuthenticatedRESTRequest(uri, credentials, extra={}) {
|
||||
RESTRequest.call(this, uri);
|
||||
|
||||
this.credentials = credentials;
|
||||
this.now = extra.now || Date.now();
|
||||
this.localtimeOffsetMsec = extra.localtimeOffsetMsec || 0;
|
||||
this._log.trace("local time, offset: " + this.now + ", " + (this.localtimeOffsetMsec));
|
||||
};
|
||||
HAWKAuthenticatedRESTRequest.prototype = {
|
||||
__proto__: RESTRequest.prototype,
|
||||
|
||||
dispatch: function dispatch(method, data, onComplete, onProgress) {
|
||||
let contentType = "text/plain";
|
||||
if (method == "POST" || method == "PUT") {
|
||||
contentType = "application/json";
|
||||
}
|
||||
if (this.credentials) {
|
||||
let options = {
|
||||
now: this.now,
|
||||
localtimeOffsetMsec: this.localtimeOffsetMsec,
|
||||
credentials: this.credentials,
|
||||
payload: data && JSON.stringify(data) || "",
|
||||
contentType: contentType,
|
||||
};
|
||||
let header = CryptoUtils.computeHAWK(this.uri, method, options);
|
||||
this.setHeader("Authorization", header.field);
|
||||
this._log.trace("hawk auth header: " + header.field);
|
||||
}
|
||||
|
||||
this.setHeader("Content-Type", contentType);
|
||||
|
||||
try {
|
||||
let acceptLanguage = Services.prefs.getComplexValue(
|
||||
"intl.accept_languages", Ci.nsIPrefLocalizedString).data;
|
||||
if (acceptLanguage) {
|
||||
this.setHeader("Accept-Language", acceptLanguage);
|
||||
}
|
||||
} catch (err) {
|
||||
this._log.error("Error reading intl.accept_languages pref: " + CommonUtils.exceptionStr(err));
|
||||
}
|
||||
|
||||
return RESTRequest.prototype.dispatch.call(
|
||||
this, method, data, onComplete, onProgress
|
||||
);
|
||||
}
|
||||
};
|
||||
|
@ -4,7 +4,7 @@
|
||||
"use strict";
|
||||
|
||||
Cu.import("resource://gre/modules/Promise.jsm");
|
||||
Cu.import("resource://services-common/hawk.js");
|
||||
Cu.import("resource://services-common/hawkclient.js");
|
||||
|
||||
const SECOND_MS = 1000;
|
||||
const MINUTE_MS = SECOND_MS * 60;
|
203
services/common/tests/unit/test_hawkrequest.js
Normal file
203
services/common/tests/unit/test_hawkrequest.js
Normal file
@ -0,0 +1,203 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
"use strict";
|
||||
|
||||
Cu.import("resource://gre/modules/Log.jsm");
|
||||
Cu.import("resource://services-common/utils.js");
|
||||
Cu.import("resource://services-common/hawkrequest.js");
|
||||
|
||||
function do_register_cleanup() {
|
||||
Services.prefs.resetUserPrefs();
|
||||
|
||||
// remove the pref change listener
|
||||
let hawk = new HAWKAuthenticatedRESTRequest("https://example.com");
|
||||
hawk._intl.uninit();
|
||||
}
|
||||
|
||||
function run_test() {
|
||||
Log.repository.getLogger("Services.Common.RESTRequest").level =
|
||||
Log.Level.Trace;
|
||||
initTestLogging("Trace");
|
||||
|
||||
run_next_test();
|
||||
}
|
||||
|
||||
|
||||
add_test(function test_intl_accept_language() {
|
||||
let testCount = 0;
|
||||
let languages = [
|
||||
"zu-NP;vo", // Nepalese dialect of Zulu, defaulting to Volapük
|
||||
"fa-CG;ik", // Congolese dialect of Farsei, defaulting to Inupiaq
|
||||
];
|
||||
|
||||
function setLanguage(lang) {
|
||||
let acceptLanguage = Cc["@mozilla.org/supports-string;1"]
|
||||
.createInstance(Ci.nsISupportsString);
|
||||
acceptLanguage.data = lang;
|
||||
Services.prefs.setComplexValue(
|
||||
"intl.accept_languages", Ci.nsISupportsString, acceptLanguage);
|
||||
}
|
||||
|
||||
let hawk = new HAWKAuthenticatedRESTRequest("https://example.com");
|
||||
|
||||
Services.prefs.addObserver("intl.accept_languages", nextTest, false);
|
||||
setLanguage(languages[testCount]);
|
||||
|
||||
function nextTest() {
|
||||
CommonUtils.nextTick(function() {
|
||||
if (testCount < 2) {
|
||||
do_check_eq(hawk._intl.accept_languages, languages[testCount]);
|
||||
|
||||
testCount += 1;
|
||||
setLanguage(languages[testCount]);
|
||||
nextTest();
|
||||
return;
|
||||
}
|
||||
Services.prefs.removeObserver("intl.accept_languages", nextTest);
|
||||
run_next_test();
|
||||
return;
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
add_test(function test_hawk_authenticated_request() {
|
||||
let onProgressCalled = false;
|
||||
let postData = {your: "data"};
|
||||
|
||||
// An arbitrary date - Feb 2, 1971. It ends in a bunch of zeroes to make our
|
||||
// computation with the hawk timestamp easier, since hawk throws away the
|
||||
// millisecond values.
|
||||
let then = 34329600000;
|
||||
|
||||
let clockSkew = 120000;
|
||||
let timeOffset = -1 * clockSkew;
|
||||
let localTime = then + clockSkew;
|
||||
|
||||
// Set the accept-languages pref to the Nepalese dialect of Zulu.
|
||||
let acceptLanguage = Cc['@mozilla.org/supports-string;1'].createInstance(Ci.nsISupportsString);
|
||||
acceptLanguage.data = 'zu-NP'; // omit trailing ';', which our HTTP libs snip
|
||||
Services.prefs.setComplexValue('intl.accept_languages', Ci.nsISupportsString, acceptLanguage);
|
||||
|
||||
let credentials = {
|
||||
id: "eyJleHBpcmVzIjogMTM2NTAxMDg5OC4x",
|
||||
key: "qTZf4ZFpAMpMoeSsX3zVRjiqmNs=",
|
||||
algorithm: "sha256"
|
||||
};
|
||||
|
||||
let server = httpd_setup({
|
||||
"/elysium": function(request, response) {
|
||||
do_check_true(request.hasHeader("Authorization"));
|
||||
|
||||
// check that the header timestamp is our arbitrary system date, not
|
||||
// today's date. Note that hawk header timestamps are in seconds, not
|
||||
// milliseconds.
|
||||
let authorization = request.getHeader("Authorization");
|
||||
let tsMS = parseInt(/ts="(\d+)"/.exec(authorization)[1], 10) * 1000;
|
||||
do_check_eq(tsMS, then);
|
||||
|
||||
// This testing can be a little wonky. In an environment where
|
||||
// pref("intl.accept_languages") === 'en-US, en'
|
||||
// the header is sent as:
|
||||
// 'en-US,en;q=0.5'
|
||||
// hence our fake value for acceptLanguage.
|
||||
let lang = request.getHeader("Accept-Language");
|
||||
do_check_eq(lang, acceptLanguage);
|
||||
|
||||
let message = "yay";
|
||||
response.setStatusLine(request.httpVersion, 200, "OK");
|
||||
response.bodyOutputStream.write(message, message.length);
|
||||
}
|
||||
});
|
||||
|
||||
function onProgress() {
|
||||
onProgressCalled = true;
|
||||
}
|
||||
|
||||
function onComplete(error) {
|
||||
do_check_eq(200, this.response.status);
|
||||
do_check_eq(this.response.body, "yay");
|
||||
do_check_true(onProgressCalled);
|
||||
|
||||
Services.prefs.resetUserPrefs();
|
||||
let pref = Services.prefs.getComplexValue(
|
||||
"intl.accept_languages", Ci.nsIPrefLocalizedString);
|
||||
do_check_neq(acceptLanguage.data, pref.data);
|
||||
|
||||
server.stop(run_next_test);
|
||||
}
|
||||
|
||||
let url = server.baseURI + "/elysium";
|
||||
let extra = {
|
||||
now: localTime,
|
||||
localtimeOffsetMsec: timeOffset
|
||||
};
|
||||
|
||||
let request = new HAWKAuthenticatedRESTRequest(url, credentials, extra);
|
||||
|
||||
// Allow hawk._intl to respond to the language pref change
|
||||
CommonUtils.nextTick(function() {
|
||||
request.post(postData, onComplete, onProgress);
|
||||
});
|
||||
});
|
||||
|
||||
add_test(function test_hawk_language_pref_changed() {
|
||||
let languages = [
|
||||
"zu-NP", // Nepalese dialect of Zulu
|
||||
"fa-CG", // Congolese dialect of Farsi
|
||||
];
|
||||
|
||||
let credentials = {
|
||||
id: "eyJleHBpcmVzIjogMTM2NTAxMDg5OC4x",
|
||||
key: "qTZf4ZFpAMpMoeSsX3zVRjiqmNs=",
|
||||
algorithm: "sha256",
|
||||
};
|
||||
|
||||
function setLanguage(lang) {
|
||||
let acceptLanguage = Cc["@mozilla.org/supports-string;1"].createInstance(Ci.nsISupportsString);
|
||||
acceptLanguage.data = lang;
|
||||
Services.prefs.setComplexValue("intl.accept_languages", Ci.nsISupportsString, acceptLanguage);
|
||||
}
|
||||
|
||||
let server = httpd_setup({
|
||||
"/foo": function(request, response) {
|
||||
do_check_eq(languages[1], request.getHeader("Accept-Language"));
|
||||
|
||||
response.setStatusLine(request.httpVersion, 200, "OK");
|
||||
},
|
||||
});
|
||||
|
||||
let url = server.baseURI + "/foo";
|
||||
let postData = {};
|
||||
let request;
|
||||
|
||||
setLanguage(languages[0]);
|
||||
|
||||
// A new request should create the stateful object for tracking the current
|
||||
// language.
|
||||
request = new HAWKAuthenticatedRESTRequest(url, credentials);
|
||||
CommonUtils.nextTick(testFirstLanguage);
|
||||
|
||||
function testFirstLanguage() {
|
||||
do_check_eq(languages[0], request._intl.accept_languages);
|
||||
|
||||
// Change the language pref ...
|
||||
setLanguage(languages[1]);
|
||||
CommonUtils.nextTick(testRequest);
|
||||
}
|
||||
|
||||
function testRequest() {
|
||||
// Change of language pref should be picked up, which we can see on the
|
||||
// server by inspecting the request headers.
|
||||
request = new HAWKAuthenticatedRESTRequest(url, credentials);
|
||||
request.post({}, function(error) {
|
||||
do_check_null(error);
|
||||
do_check_eq(200, this.response.status);
|
||||
|
||||
Services.prefs.resetUserPrefs();
|
||||
|
||||
server.stop(run_next_test);
|
||||
});
|
||||
}
|
||||
});
|
||||
|
@ -1,13 +1,13 @@
|
||||
/* Any copyright is dedicated to the Public Domain.
|
||||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||||
|
||||
"use strict";
|
||||
|
||||
Cu.import("resource://gre/modules/NetUtil.jsm");
|
||||
Cu.import("resource://gre/modules/Log.jsm");
|
||||
Cu.import("resource://services-common/rest.js");
|
||||
Cu.import("resource://services-common/utils.js");
|
||||
|
||||
//DEBUG = true;
|
||||
|
||||
function run_test() {
|
||||
Log.repository.getLogger("Services.Common.RESTRequest").level =
|
||||
Log.Level.Trace;
|
||||
@ -838,79 +838,3 @@ add_test(function test_not_sending_cookie() {
|
||||
});
|
||||
});
|
||||
|
||||
add_test(function test_hawk_authenticated_request() {
|
||||
do_test_pending();
|
||||
|
||||
let onProgressCalled = false;
|
||||
let postData = {your: "data"};
|
||||
|
||||
// An arbitrary date - Feb 2, 1971. It ends in a bunch of zeroes to make our
|
||||
// computation with the hawk timestamp easier, since hawk throws away the
|
||||
// millisecond values.
|
||||
let then = 34329600000;
|
||||
|
||||
let clockSkew = 120000;
|
||||
let timeOffset = -1 * clockSkew;
|
||||
let localTime = then + clockSkew;
|
||||
|
||||
// Set the accept-languages pref to the Nepalese dialect of Zulu.
|
||||
let acceptLanguage = Cc['@mozilla.org/supports-string;1'].createInstance(Ci.nsISupportsString);
|
||||
acceptLanguage.data = 'zu-NP'; // omit trailing ';', which our HTTP libs snip
|
||||
Services.prefs.setComplexValue('intl.accept_languages', Ci.nsISupportsString, acceptLanguage);
|
||||
|
||||
let credentials = {
|
||||
id: "eyJleHBpcmVzIjogMTM2NTAxMDg5OC4x",
|
||||
key: "qTZf4ZFpAMpMoeSsX3zVRjiqmNs=",
|
||||
algorithm: "sha256"
|
||||
};
|
||||
|
||||
let server = httpd_setup({
|
||||
"/elysium": function(request, response) {
|
||||
do_check_true(request.hasHeader("Authorization"));
|
||||
|
||||
// check that the header timestamp is our arbitrary system date, not
|
||||
// today's date. Note that hawk header timestamps are in seconds, not
|
||||
// milliseconds.
|
||||
let authorization = request.getHeader("Authorization");
|
||||
let tsMS = parseInt(/ts="(\d+)"/.exec(authorization)[1], 10) * 1000;
|
||||
do_check_eq(tsMS, then);
|
||||
|
||||
// This testing can be a little wonky. In an environment where
|
||||
// pref("intl.accept_languages") === 'en-US, en'
|
||||
// the header is sent as:
|
||||
// 'en-US,en;q=0.5'
|
||||
// hence our fake value for acceptLanguage.
|
||||
let lang = request.getHeader('Accept-Language');
|
||||
do_check_eq(lang, acceptLanguage);
|
||||
|
||||
let message = "yay";
|
||||
response.setStatusLine(request.httpVersion, 200, "OK");
|
||||
response.bodyOutputStream.write(message, message.length);
|
||||
}
|
||||
});
|
||||
|
||||
function onProgress() {
|
||||
onProgressCalled = true;
|
||||
}
|
||||
|
||||
function onComplete(error) {
|
||||
do_check_eq(200, this.response.status);
|
||||
do_check_eq(this.response.body, "yay");
|
||||
do_check_true(onProgressCalled);
|
||||
do_test_finished();
|
||||
server.stop(run_next_test);
|
||||
}
|
||||
|
||||
let url = server.baseURI + "/elysium";
|
||||
let extra = {
|
||||
now: localTime,
|
||||
localtimeOffsetMsec: timeOffset
|
||||
};
|
||||
let request = new HAWKAuthenticatedRESTRequest(url, credentials, extra);
|
||||
request.post(postData, onComplete, onProgress);
|
||||
|
||||
Services.prefs.resetUserPrefs();
|
||||
let pref = Services.prefs.getComplexValue('intl.accept_languages',
|
||||
Ci.nsIPrefLocalizedString);
|
||||
do_check_neq(acceptLanguage.data, pref.data);
|
||||
});
|
||||
|
@ -25,7 +25,8 @@ firefox-appdir = browser
|
||||
[test_async_querySpinningly.js]
|
||||
[test_bagheera_server.js]
|
||||
[test_bagheera_client.js]
|
||||
[test_hawk.js]
|
||||
[test_hawkclient.js]
|
||||
[test_hawkrequest.js]
|
||||
[test_observers.js]
|
||||
[test_restrequest.js]
|
||||
[test_tokenauthenticatedrequest.js]
|
||||
|
@ -10,7 +10,7 @@ Cu.import("resource://gre/modules/Log.jsm");
|
||||
Cu.import("resource://gre/modules/Promise.jsm");
|
||||
Cu.import("resource://gre/modules/Services.jsm");
|
||||
Cu.import("resource://services-common/utils.js");
|
||||
Cu.import("resource://services-common/hawk.js");
|
||||
Cu.import("resource://services-common/hawkclient.js");
|
||||
Cu.import("resource://services-crypto/utils.js");
|
||||
Cu.import("resource://gre/modules/FxAccountsCommon.js");
|
||||
Cu.import("resource://gre/modules/Credentials.jsm");
|
||||
|
@ -29,7 +29,7 @@ Components.utils.import("resource://gre/modules/Promise.jsm");
|
||||
Components.utils.import("resource://gre/modules/Services.jsm");
|
||||
Components.utils.import("resource://gre/modules/FxAccounts.jsm");
|
||||
Components.utils.import("resource://gre/modules/FxAccountsClient.jsm");
|
||||
Components.utils.import("resource://services-common/hawk.js");
|
||||
Components.utils.import("resource://services-common/hawkclient.js");
|
||||
|
||||
const TEST_SERVER =
|
||||
"http://mochi.test:8888/chrome/services/fxaccounts/tests/mochitest/file_invalidEmailCase.sjs?path=";
|
||||
|
@ -8,7 +8,7 @@ Cu.import("resource://services-sync/util.js");
|
||||
Cu.import("resource://services-common/utils.js");
|
||||
Cu.import("resource://services-crypto/utils.js");
|
||||
Cu.import("resource://testing-common/services/sync/utils.js");
|
||||
Cu.import("resource://services-common/hawk.js");
|
||||
Cu.import("resource://services-common/hawkclient.js");
|
||||
Cu.import("resource://gre/modules/FxAccounts.jsm");
|
||||
Cu.import("resource://gre/modules/FxAccountsClient.jsm");
|
||||
Cu.import("resource://gre/modules/FxAccountsCommon.js");
|
||||
|
Loading…
x
Reference in New Issue
Block a user