1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
/* 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/. */
// This file is a chrome-API-free version of the module
// devtools/client/netmonitor/src/utils/firefox/open-request-in-tab.js, so that
// it can be used in Chrome-API-free applications, such as the Launchpad. But
// because of this, it cannot take advantage of utilizing chrome APIs and should
// implement the similar functionalities on its own.
//
// Please keep in mind that if the feature in this file has changed, don't
// forget to also change that accordingly in
// devtools/client/netmonitor/src/utils/firefox/open-request-in-tab.js.
"use strict";
loader.lazyRequireGetter(
this,
"openContentLink",
"resource://devtools/client/shared/link.js",
true
);
/**
* Opens given request in a new tab.
*
* For POST request supports application/x-www-form-urlencoded content-type only.
*/
function openRequestInTab(url, requestHeaders, requestPostData) {
if (!requestPostData) {
openContentLink(url, { relatedToCurrent: true });
} else {
openPostRequestInTabHelper({
url,
data: requestPostData.postData,
});
}
}
function openPostRequestInTabHelper({ url, data }) {
const form = document.createElement("form");
form.target = "_blank";
form.action = url;
form.method = "post";
if (data) {
for (const key in data) {
const input = document.createElement("input");
input.name = key;
input.value = data[key];
form.appendChild(input);
}
}
form.hidden = true;
document.body.appendChild(form);
form.submit();
form.remove();
}
module.exports = {
openRequestInTab,
};
|