@scalar/snippetz 0.2.20 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/httpsnippet-lite/esm/targets/c/libcurl/client.d.ts.map +1 -1
- package/dist/httpsnippet-lite/esm/targets/c/libcurl/client.js +37 -8
- package/dist/httpsnippet-lite/esm/targets/c/libcurl/client.js.map +2 -2
- package/dist/httpsnippet-lite/esm/targets/go/native/client.d.ts.map +1 -1
- package/dist/httpsnippet-lite/esm/targets/go/native/client.js +76 -30
- package/dist/httpsnippet-lite/esm/targets/go/native/client.js.map +2 -2
- package/dist/httpsnippet-lite/esm/targets/java/okhttp/client.d.ts.map +1 -1
- package/dist/httpsnippet-lite/esm/targets/java/okhttp/client.js +25 -9
- package/dist/httpsnippet-lite/esm/targets/java/okhttp/client.js.map +2 -2
- package/dist/httpsnippet-lite/esm/targets/kotlin/okhttp/client.d.ts.map +1 -1
- package/dist/httpsnippet-lite/esm/targets/kotlin/okhttp/client.js +25 -9
- package/dist/httpsnippet-lite/esm/targets/kotlin/okhttp/client.js.map +2 -2
- package/dist/httpsnippet-lite/esm/targets/shell/httpie/client.d.ts.map +1 -1
- package/dist/httpsnippet-lite/esm/targets/shell/httpie/client.js +11 -0
- package/dist/httpsnippet-lite/esm/targets/shell/httpie/client.js.map +2 -2
- package/dist/plugins/c/libcurl/libcurl.test.js +19 -11
- package/dist/plugins/c/libcurl/libcurl.test.js.map +2 -2
- package/dist/plugins/go/native/native.test.js +35 -36
- package/dist/plugins/go/native/native.test.js.map +2 -2
- package/dist/plugins/java/okhttp/okhttp.test.js +164 -0
- package/dist/plugins/java/okhttp/okhttp.test.js.map +7 -0
- package/dist/plugins/js/axios/index.d.ts +1 -1
- package/dist/plugins/js/axios/index.d.ts.map +1 -1
- package/dist/plugins/js/axios/index.js +4 -1
- package/dist/plugins/js/axios/index.js.map +2 -2
- package/dist/plugins/js/fetch/fetch.d.ts.map +1 -1
- package/dist/plugins/js/fetch/fetch.js +30 -9
- package/dist/plugins/js/fetch/fetch.js.map +2 -2
- package/dist/plugins/js/fetch/fetch.test.js +103 -0
- package/dist/plugins/js/fetch/fetch.test.js.map +2 -2
- package/dist/plugins/js/fetch/index.d.ts +1 -1
- package/dist/plugins/js/fetch/index.d.ts.map +1 -1
- package/dist/plugins/js/fetch/index.js +4 -1
- package/dist/plugins/js/fetch/index.js.map +2 -2
- package/dist/plugins/js/ofetch/ofetch.d.ts.map +1 -1
- package/dist/plugins/js/ofetch/ofetch.js +1 -10
- package/dist/plugins/js/ofetch/ofetch.js.map +2 -2
- package/dist/plugins/js/ofetch/ofetch.test.js +7 -4
- package/dist/plugins/js/ofetch/ofetch.test.js.map +2 -2
- package/dist/plugins/kotlin/okhttp/okhttp.test.js +164 -0
- package/dist/plugins/kotlin/okhttp/okhttp.test.js.map +7 -0
- package/dist/plugins/node/fetch/fetch.d.ts.map +1 -1
- package/dist/plugins/node/fetch/fetch.js +37 -9
- package/dist/plugins/node/fetch/fetch.js.map +2 -2
- package/dist/plugins/node/fetch/fetch.test.js +89 -0
- package/dist/plugins/node/fetch/fetch.test.js.map +2 -2
- package/dist/plugins/node/ofetch/ofetch.d.ts.map +1 -1
- package/dist/plugins/node/ofetch/ofetch.js +1 -10
- package/dist/plugins/node/ofetch/ofetch.js.map +2 -2
- package/dist/plugins/node/ofetch/ofetch.test.js +7 -4
- package/dist/plugins/node/ofetch/ofetch.test.js.map +2 -2
- package/dist/plugins/node/undici/undici.d.ts.map +1 -1
- package/dist/plugins/node/undici/undici.js +4 -6
- package/dist/plugins/node/undici/undici.js.map +2 -2
- package/dist/plugins/python/requests/requests.d.ts.map +1 -1
- package/dist/plugins/python/requests/requests.js +4 -3
- package/dist/plugins/python/requests/requests.js.map +3 -3
- package/dist/plugins/python/requests/requests.test.js +31 -2
- package/dist/plugins/python/requests/requests.test.js.map +2 -2
- package/dist/plugins/shell/httpie/httpie.test.js +3 -3
- package/dist/plugins/shell/httpie/httpie.test.js.map +2 -2
- package/dist/utils/create-search-params.d.ts +4 -0
- package/dist/utils/create-search-params.d.ts.map +1 -0
- package/dist/utils/create-search-params.js +11 -0
- package/dist/utils/create-search-params.js.map +7 -0
- package/dist/utils/create-search-params.test.js +49 -0
- package/dist/utils/create-search-params.test.js.map +7 -0
- package/dist/utils/index.d.ts +0 -1
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +0 -1
- package/dist/utils/index.js.map +2 -2
- package/dist/utils/objectToString.d.ts +8 -0
- package/dist/utils/objectToString.d.ts.map +1 -1
- package/dist/utils/objectToString.js +20 -15
- package/dist/utils/objectToString.js.map +2 -2
- package/package.json +5 -5
- package/dist/utils/arrayToObject.d.ts +0 -8
- package/dist/utils/arrayToObject.d.ts.map +0 -1
- package/dist/utils/arrayToObject.js +0 -10
- package/dist/utils/arrayToObject.js.map +0 -7
|
@@ -42,6 +42,7 @@ describe("nodeFetch", () => {
|
|
|
42
42
|
it("has JSON body", () => {
|
|
43
43
|
const result = nodeFetch.generate({
|
|
44
44
|
url: "https://example.com",
|
|
45
|
+
method: "POST",
|
|
45
46
|
headers: [
|
|
46
47
|
{
|
|
47
48
|
name: "Content-Type",
|
|
@@ -56,12 +57,36 @@ describe("nodeFetch", () => {
|
|
|
56
57
|
}
|
|
57
58
|
});
|
|
58
59
|
expect(result).toBe(`fetch('https://example.com', {
|
|
60
|
+
method: 'POST',
|
|
59
61
|
headers: {
|
|
60
62
|
'Content-Type': 'application/json'
|
|
61
63
|
},
|
|
62
64
|
body: JSON.stringify({
|
|
63
65
|
hello: 'world'
|
|
64
66
|
})
|
|
67
|
+
})`);
|
|
68
|
+
});
|
|
69
|
+
it("has raw body", () => {
|
|
70
|
+
const result = nodeFetch.generate({
|
|
71
|
+
url: "https://example.com",
|
|
72
|
+
method: "POST",
|
|
73
|
+
headers: [
|
|
74
|
+
{
|
|
75
|
+
name: "Content-Type",
|
|
76
|
+
value: "application/octet-stream"
|
|
77
|
+
}
|
|
78
|
+
],
|
|
79
|
+
postData: {
|
|
80
|
+
mimeType: "application/octet-stream",
|
|
81
|
+
text: "hello world"
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
expect(result).toBe(`fetch('https://example.com', {
|
|
85
|
+
method: 'POST',
|
|
86
|
+
headers: {
|
|
87
|
+
'Content-Type': 'application/octet-stream'
|
|
88
|
+
},
|
|
89
|
+
body: 'hello world'
|
|
65
90
|
})`);
|
|
66
91
|
});
|
|
67
92
|
it("has query string", () => {
|
|
@@ -107,5 +132,69 @@ describe("nodeFetch", () => {
|
|
|
107
132
|
});
|
|
108
133
|
expect(result).toBe(`fetch('https://example.com')`);
|
|
109
134
|
});
|
|
135
|
+
it("has urlencoded body", () => {
|
|
136
|
+
const result = nodeFetch.generate({
|
|
137
|
+
url: "https://example.com",
|
|
138
|
+
method: "POST",
|
|
139
|
+
headers: [
|
|
140
|
+
{
|
|
141
|
+
name: "Content-Type",
|
|
142
|
+
value: "application/x-www-form-urlencoded"
|
|
143
|
+
}
|
|
144
|
+
],
|
|
145
|
+
postData: {
|
|
146
|
+
mimeType: "application/x-www-form-urlencoded",
|
|
147
|
+
params: [
|
|
148
|
+
{
|
|
149
|
+
name: "foo",
|
|
150
|
+
value: "bar"
|
|
151
|
+
},
|
|
152
|
+
{
|
|
153
|
+
name: "baz",
|
|
154
|
+
value: "foo"
|
|
155
|
+
}
|
|
156
|
+
]
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
expect(result).toBe(`fetch('https://example.com', {
|
|
160
|
+
method: 'POST',
|
|
161
|
+
headers: {
|
|
162
|
+
'Content-Type': 'application/x-www-form-urlencoded'
|
|
163
|
+
},
|
|
164
|
+
body: new URLSearchParams({
|
|
165
|
+
foo: 'bar',
|
|
166
|
+
baz: 'foo'
|
|
167
|
+
})
|
|
168
|
+
})`);
|
|
169
|
+
});
|
|
170
|
+
it("has multipart body", () => {
|
|
171
|
+
const result = nodeFetch.generate({
|
|
172
|
+
url: "https://example.com",
|
|
173
|
+
method: "POST",
|
|
174
|
+
postData: {
|
|
175
|
+
mimeType: "multipart/form-data",
|
|
176
|
+
params: [
|
|
177
|
+
{
|
|
178
|
+
name: "foo",
|
|
179
|
+
value: "bar"
|
|
180
|
+
},
|
|
181
|
+
{
|
|
182
|
+
name: "file",
|
|
183
|
+
fileName: "baz.txt"
|
|
184
|
+
}
|
|
185
|
+
]
|
|
186
|
+
}
|
|
187
|
+
});
|
|
188
|
+
expect(result).toBe(`import fs from 'node:fs'
|
|
189
|
+
|
|
190
|
+
const formData = new FormData()
|
|
191
|
+
formData.append('foo', 'bar')
|
|
192
|
+
formData.append('file', new Blob([fs.readFileSync('baz.txt')]), 'baz.txt')
|
|
193
|
+
|
|
194
|
+
fetch('https://example.com', {
|
|
195
|
+
method: 'POST',
|
|
196
|
+
body: formData
|
|
197
|
+
})`);
|
|
198
|
+
});
|
|
110
199
|
});
|
|
111
200
|
//# sourceMappingURL=fetch.test.js.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/plugins/node/fetch/fetch.test.ts"],
|
|
4
|
-
"sourcesContent": ["import { describe, expect, it } from 'vitest'\n\nimport { nodeFetch } from './fetch'\n\ndescribe('nodeFetch', () => {\n it('returns a basic request', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n })\n\n expect(result).toBe(`fetch('https://example.com')`)\n })\n\n it('returns a POST request', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n method: 'post',\n })\n\n expect(result).toBe(`fetch('https://example.com', {\n method: 'POST'\n})`)\n })\n\n it('has headers', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n })\n\n expect(result).toBe(`fetch('https://example.com', {\n headers: {\n 'Content-Type': 'application/json'\n }\n})`)\n })\n\n it('doesn\u2019t add empty headers', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n headers: [],\n })\n\n expect(result).toBe(`fetch('https://example.com')`)\n })\n\n it('has JSON body', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n postData: {\n mimeType: 'application/json',\n text: JSON.stringify({\n hello: 'world',\n }),\n },\n })\n\n expect(result).toBe(`fetch('https://example.com', {\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n hello: 'world'\n })\n})`)\n })\n\n it('has query string', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n queryString: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`fetch('https://example.com?foo=bar&bar=foo')`)\n })\n\n it('has cookies', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n cookies: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`fetch('https://example.com', {\n headers: {\n 'Set-Cookie': 'foo=bar; bar=foo'\n }\n})`)\n })\n\n it('doesn\u2019t add empty cookies', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n cookies: [],\n })\n\n expect(result).toBe(`fetch('https://example.com')`)\n })\n})\n"],
|
|
5
|
-
"mappings": "AAAA,SAAS,UAAU,QAAQ,UAAU;AAErC,SAAS,iBAAiB;AAE1B,SAAS,aAAa,MAAM;AAC1B,KAAG,2BAA2B,MAAM;AAClC,UAAM,SAAS,UAAU,SAAS;AAAA,MAChC,KAAK;AAAA,IACP,CAAC;AAED,WAAO,MAAM,EAAE,KAAK,8BAA8B;AAAA,EACpD,CAAC;AAED,KAAG,0BAA0B,MAAM;AACjC,UAAM,SAAS,UAAU,SAAS;AAAA,MAChC,KAAK;AAAA,MACL,QAAQ;AAAA,IACV,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA,GAErB;AAAA,EACD,CAAC;AAED,KAAG,eAAe,MAAM;AACtB,UAAM,SAAS,UAAU,SAAS;AAAA,MAChC,KAAK;AAAA,MACL,SAAS;AAAA,QACP;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA,GAIrB;AAAA,EACD,CAAC;AAED,KAAG,kCAA6B,MAAM;AACpC,UAAM,SAAS,UAAU,SAAS;AAAA,MAChC,KAAK;AAAA,MACL,SAAS,CAAC;AAAA,IACZ,CAAC;AAED,WAAO,MAAM,EAAE,KAAK,8BAA8B;AAAA,EACpD,CAAC;AAED,KAAG,iBAAiB,MAAM;AACxB,UAAM,SAAS,UAAU,SAAS;AAAA,MAChC,KAAK;AAAA,MACL,SAAS;AAAA,QACP;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,MACF;AAAA,MACA,UAAU;AAAA,QACR,UAAU;AAAA,QACV,MAAM,KAAK,UAAU;AAAA,UACnB,OAAO;AAAA,QACT,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,
|
|
4
|
+
"sourcesContent": ["import { describe, expect, it } from 'vitest'\n\nimport { nodeFetch } from './fetch'\n\ndescribe('nodeFetch', () => {\n it('returns a basic request', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n })\n\n expect(result).toBe(`fetch('https://example.com')`)\n })\n\n it('returns a POST request', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n method: 'post',\n })\n\n expect(result).toBe(`fetch('https://example.com', {\n method: 'POST'\n})`)\n })\n\n it('has headers', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n })\n\n expect(result).toBe(`fetch('https://example.com', {\n headers: {\n 'Content-Type': 'application/json'\n }\n})`)\n })\n\n it('doesn\u2019t add empty headers', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n headers: [],\n })\n\n expect(result).toBe(`fetch('https://example.com')`)\n })\n\n it('has JSON body', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n method: 'POST',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n postData: {\n mimeType: 'application/json',\n text: JSON.stringify({\n hello: 'world',\n }),\n },\n })\n\n expect(result).toBe(`fetch('https://example.com', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n hello: 'world'\n })\n})`)\n })\n\n it('has raw body', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n method: 'POST',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/octet-stream',\n },\n ],\n postData: {\n mimeType: 'application/octet-stream',\n text: 'hello world',\n },\n })\n\n expect(result).toBe(`fetch('https://example.com', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/octet-stream'\n },\n body: 'hello world'\n})`)\n })\n\n it('has query string', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n queryString: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`fetch('https://example.com?foo=bar&bar=foo')`)\n })\n\n it('has cookies', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n cookies: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`fetch('https://example.com', {\n headers: {\n 'Set-Cookie': 'foo=bar; bar=foo'\n }\n})`)\n })\n\n it('doesn\u2019t add empty cookies', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n cookies: [],\n })\n\n expect(result).toBe(`fetch('https://example.com')`)\n })\n\n it('has urlencoded body', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n method: 'POST',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/x-www-form-urlencoded',\n },\n ],\n postData: {\n mimeType: 'application/x-www-form-urlencoded',\n params: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'baz',\n value: 'foo',\n },\n ],\n },\n })\n\n expect(result).toBe(`fetch('https://example.com', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/x-www-form-urlencoded'\n },\n body: new URLSearchParams({\n foo: 'bar',\n baz: 'foo'\n })\n})`)\n })\n\n it('has multipart body', () => {\n const result = nodeFetch.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'multipart/form-data',\n params: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'file',\n fileName: 'baz.txt',\n },\n ],\n },\n })\n\n expect(result).toBe(`import fs from 'node:fs'\n\nconst formData = new FormData()\nformData.append('foo', 'bar')\nformData.append('file', new Blob([fs.readFileSync('baz.txt')]), 'baz.txt')\n\nfetch('https://example.com', {\n method: 'POST',\n body: formData\n})`)\n })\n})\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ofetch.d.ts","sourceRoot":"","sources":["../../../../src/plugins/node/ofetch/ofetch.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ofetch.d.ts","sourceRoot":"","sources":["../../../../src/plugins/node/ofetch/ofetch.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AAEpD;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,MAoExB,CAAA"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { arrayToObject } from "../../../utils/arrayToObject.js";
|
|
2
1
|
import { objectToString } from "../../../utils/objectToString.js";
|
|
3
2
|
const nodeOfetch = {
|
|
4
3
|
target: "node",
|
|
@@ -13,15 +12,7 @@ const nodeOfetch = {
|
|
|
13
12
|
const options = {
|
|
14
13
|
method: normalizedRequest.method === "GET" ? void 0 : normalizedRequest.method
|
|
15
14
|
};
|
|
16
|
-
|
|
17
|
-
normalizedRequest.queryString ? arrayToObject(normalizedRequest.queryString) : void 0
|
|
18
|
-
);
|
|
19
|
-
if (searchParams.size) {
|
|
20
|
-
options.query = {};
|
|
21
|
-
searchParams.forEach((value, key) => {
|
|
22
|
-
options.query[key] = value;
|
|
23
|
-
});
|
|
24
|
-
}
|
|
15
|
+
options.query = normalizedRequest.queryString;
|
|
25
16
|
if (normalizedRequest.headers?.length) {
|
|
26
17
|
options.headers = {};
|
|
27
18
|
normalizedRequest.headers.forEach((header) => {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/plugins/node/ofetch/ofetch.ts"],
|
|
4
|
-
"sourcesContent": ["import {
|
|
5
|
-
"mappings": "AAAA,SAAS,
|
|
4
|
+
"sourcesContent": ["import { objectToString } from '@/utils/objectToString'\nimport type { Plugin } from '@scalar/types/snippetz'\n\n/**\n * node/ofetch\n */\nexport const nodeOfetch: Plugin = {\n target: 'node',\n client: 'ofetch',\n title: 'ofetch',\n generate(request) {\n // Defaults\n const normalizedRequest = {\n method: 'GET',\n ...request,\n }\n\n // Normalization\n normalizedRequest.method = normalizedRequest.method.toUpperCase()\n\n // Reset fetch defaults\n const options: Record<string, any> = {\n method: normalizedRequest.method === 'GET' ? undefined : normalizedRequest.method,\n }\n\n // Query\n options.query = normalizedRequest.queryString\n\n // Headers\n if (normalizedRequest.headers?.length) {\n options.headers = {}\n\n normalizedRequest.headers.forEach((header) => {\n options.headers![header.name] = header.value\n })\n }\n\n // Cookies\n if (normalizedRequest.cookies?.length) {\n options.headers = options.headers || {}\n\n normalizedRequest.cookies.forEach((cookie) => {\n options.headers!['Set-Cookie'] = options.headers!['Set-Cookie']\n ? `${options.headers!['Set-Cookie']}; ${cookie.name}=${cookie.value}`\n : `${cookie.name}=${cookie.value}`\n })\n }\n\n // Remove undefined keys\n Object.keys(options).forEach((key) => {\n if (options[key] === undefined) {\n delete options[key]\n }\n })\n\n // Add body\n if (normalizedRequest.postData) {\n // Plain text\n options.body = normalizedRequest.postData.text\n\n // JSON\n if (normalizedRequest.postData.mimeType === 'application/json') {\n options.body = JSON.parse(options.body)\n }\n }\n\n // Transform to JSON\n const jsonOptions = Object.keys(options).length ? `, ${objectToString(options)}` : ''\n\n // Code Template\n return `import { ofetch } from 'ofetch'\n\nofetch('${normalizedRequest.url}'${jsonOptions})`\n },\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,sBAAsB;AAMxB,MAAM,aAAqB;AAAA,EAChC,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,SAAS,SAAS;AAEhB,UAAM,oBAAoB;AAAA,MACxB,QAAQ;AAAA,MACR,GAAG;AAAA,IACL;AAGA,sBAAkB,SAAS,kBAAkB,OAAO,YAAY;AAGhE,UAAM,UAA+B;AAAA,MACnC,QAAQ,kBAAkB,WAAW,QAAQ,SAAY,kBAAkB;AAAA,IAC7E;AAGA,YAAQ,QAAQ,kBAAkB;AAGlC,QAAI,kBAAkB,SAAS,QAAQ;AACrC,cAAQ,UAAU,CAAC;AAEnB,wBAAkB,QAAQ,QAAQ,CAAC,WAAW;AAC5C,gBAAQ,QAAS,OAAO,IAAI,IAAI,OAAO;AAAA,MACzC,CAAC;AAAA,IACH;AAGA,QAAI,kBAAkB,SAAS,QAAQ;AACrC,cAAQ,UAAU,QAAQ,WAAW,CAAC;AAEtC,wBAAkB,QAAQ,QAAQ,CAAC,WAAW;AAC5C,gBAAQ,QAAS,YAAY,IAAI,QAAQ,QAAS,YAAY,IAC1D,GAAG,QAAQ,QAAS,YAAY,CAAC,KAAK,OAAO,IAAI,IAAI,OAAO,KAAK,KACjE,GAAG,OAAO,IAAI,IAAI,OAAO,KAAK;AAAA,MACpC,CAAC;AAAA,IACH;AAGA,WAAO,KAAK,OAAO,EAAE,QAAQ,CAAC,QAAQ;AACpC,UAAI,QAAQ,GAAG,MAAM,QAAW;AAC9B,eAAO,QAAQ,GAAG;AAAA,MACpB;AAAA,IACF,CAAC;AAGD,QAAI,kBAAkB,UAAU;AAE9B,cAAQ,OAAO,kBAAkB,SAAS;AAG1C,UAAI,kBAAkB,SAAS,aAAa,oBAAoB;AAC9D,gBAAQ,OAAO,KAAK,MAAM,QAAQ,IAAI;AAAA,MACxC;AAAA,IACF;AAGA,UAAM,cAAc,OAAO,KAAK,OAAO,EAAE,SAAS,KAAK,eAAe,OAAO,CAAC,KAAK;AAGnF,WAAO;AAAA;AAAA,UAED,kBAAkB,GAAG,IAAI,WAAW;AAAA,EAC5C;AACF;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -82,10 +82,13 @@ ofetch('https://example.com', {
|
|
|
82
82
|
expect(result).toBe(`import { ofetch } from 'ofetch'
|
|
83
83
|
|
|
84
84
|
ofetch('https://example.com', {
|
|
85
|
-
query: {
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
}
|
|
85
|
+
query: [{
|
|
86
|
+
name: 'foo',
|
|
87
|
+
value: 'bar'
|
|
88
|
+
}, {
|
|
89
|
+
name: 'bar',
|
|
90
|
+
value: 'foo'
|
|
91
|
+
}]
|
|
89
92
|
})`);
|
|
90
93
|
});
|
|
91
94
|
it("has cookies", () => {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/plugins/node/ofetch/ofetch.test.ts"],
|
|
4
|
-
"sourcesContent": ["import { describe, expect, it } from 'vitest'\n\nimport { nodeOfetch } from './ofetch'\n\ndescribe('nodeOfetch', () => {\n it('returns a basic request', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com')`)\n })\n\n it('returns a POST request', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n method: 'post',\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com', {\n method: 'POST'\n})`)\n })\n\n it('has headers', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com', {\n headers: {\n 'Content-Type': 'application/json'\n }\n})`)\n })\n\n it('doesn\u2019t add empty headers', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n headers: [],\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com')`)\n })\n\n it('has JSON body', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n postData: {\n mimeType: 'application/json',\n text: JSON.stringify({\n hello: 'world',\n }),\n },\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com', {\n body: {\n hello: 'world'\n }\n})`)\n })\n\n it('has query string', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n queryString: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com', {\n query: {\n foo: 'bar',\n
|
|
5
|
-
"mappings": "AAAA,SAAS,UAAU,QAAQ,UAAU;AAErC,SAAS,kBAAkB;AAE3B,SAAS,cAAc,MAAM;AAC3B,KAAG,2BAA2B,MAAM;AAClC,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,IACP,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA,8BAEM;AAAA,EAC5B,CAAC;AAED,KAAG,0BAA0B,MAAM;AACjC,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,QAAQ;AAAA,IACV,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA,GAIrB;AAAA,EACD,CAAC;AAED,KAAG,eAAe,MAAM;AACtB,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,SAAS;AAAA,QACP;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAMrB;AAAA,EACD,CAAC;AAED,KAAG,kCAA6B,MAAM;AACpC,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,SAAS,CAAC;AAAA,IACZ,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA,8BAEM;AAAA,EAC5B,CAAC;AAED,KAAG,iBAAiB,MAAM;AACxB,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,UAAU;AAAA,QACR,UAAU;AAAA,QACV,MAAM,KAAK,UAAU;AAAA,UACnB,OAAO;AAAA,QACT,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAMrB;AAAA,EACD,CAAC;AAED,KAAG,oBAAoB,MAAM;AAC3B,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,aAAa;AAAA,QACX;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,QACA;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,
|
|
4
|
+
"sourcesContent": ["import { describe, expect, it } from 'vitest'\n\nimport { nodeOfetch } from './ofetch'\n\ndescribe('nodeOfetch', () => {\n it('returns a basic request', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com')`)\n })\n\n it('returns a POST request', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n method: 'post',\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com', {\n method: 'POST'\n})`)\n })\n\n it('has headers', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com', {\n headers: {\n 'Content-Type': 'application/json'\n }\n})`)\n })\n\n it('doesn\u2019t add empty headers', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n headers: [],\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com')`)\n })\n\n it('has JSON body', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n postData: {\n mimeType: 'application/json',\n text: JSON.stringify({\n hello: 'world',\n }),\n },\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com', {\n body: {\n hello: 'world'\n }\n})`)\n })\n\n it('has query string', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n queryString: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com', {\n query: [{\n name: 'foo',\n value: 'bar'\n }, {\n name: 'bar',\n value: 'foo'\n }]\n})`)\n })\n\n it('has cookies', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n cookies: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com', {\n headers: {\n 'Set-Cookie': 'foo=bar; bar=foo'\n }\n})`)\n })\n\n it('doesn\u2019t add empty cookies', () => {\n const result = nodeOfetch.generate({\n url: 'https://example.com',\n cookies: [],\n })\n\n expect(result).toBe(`import { ofetch } from 'ofetch'\n\nofetch('https://example.com')`)\n })\n})\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,UAAU,QAAQ,UAAU;AAErC,SAAS,kBAAkB;AAE3B,SAAS,cAAc,MAAM;AAC3B,KAAG,2BAA2B,MAAM;AAClC,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,IACP,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA,8BAEM;AAAA,EAC5B,CAAC;AAED,KAAG,0BAA0B,MAAM;AACjC,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,QAAQ;AAAA,IACV,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA,GAIrB;AAAA,EACD,CAAC;AAED,KAAG,eAAe,MAAM;AACtB,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,SAAS;AAAA,QACP;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAMrB;AAAA,EACD,CAAC;AAED,KAAG,kCAA6B,MAAM;AACpC,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,SAAS,CAAC;AAAA,IACZ,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA,8BAEM;AAAA,EAC5B,CAAC;AAED,KAAG,iBAAiB,MAAM;AACxB,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,UAAU;AAAA,QACR,UAAU;AAAA,QACV,MAAM,KAAK,UAAU;AAAA,UACnB,OAAO;AAAA,QACT,CAAC;AAAA,MACH;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAMrB;AAAA,EACD,CAAC;AAED,KAAG,oBAAoB,MAAM;AAC3B,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,aAAa;AAAA,QACX;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,QACA;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAUrB;AAAA,EACD,CAAC;AAED,KAAG,eAAe,MAAM;AACtB,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,SAAS;AAAA,QACP;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,QACA;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAMrB;AAAA,EACD,CAAC;AAED,KAAG,kCAA6B,MAAM;AACpC,UAAM,SAAS,WAAW,SAAS;AAAA,MACjC,KAAK;AAAA,MACL,SAAS,CAAC;AAAA,IACZ,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA,8BAEM;AAAA,EAC5B,CAAC;AACH,CAAC;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"undici.d.ts","sourceRoot":"","sources":["../../../../src/plugins/node/undici/undici.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AAEpD;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,
|
|
1
|
+
{"version":3,"file":"undici.d.ts","sourceRoot":"","sources":["../../../../src/plugins/node/undici/undici.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AAEpD;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,MAqExB,CAAA"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { objectToString } from "../../../utils/objectToString.js";
|
|
1
|
+
import { createSearchParams } from "../../../utils/create-search-params.js";
|
|
2
|
+
import { objectToString, Unquoted } from "../../../utils/objectToString.js";
|
|
3
3
|
const nodeUndici = {
|
|
4
4
|
target: "node",
|
|
5
5
|
client: "undici",
|
|
@@ -13,9 +13,7 @@ const nodeUndici = {
|
|
|
13
13
|
const options = {
|
|
14
14
|
method: normalizedRequest.method === "GET" ? void 0 : normalizedRequest.method
|
|
15
15
|
};
|
|
16
|
-
const searchParams =
|
|
17
|
-
normalizedRequest.queryString ? arrayToObject(normalizedRequest.queryString) : void 0
|
|
18
|
-
);
|
|
16
|
+
const searchParams = createSearchParams(normalizedRequest.queryString);
|
|
19
17
|
const queryString = searchParams.size ? `?${searchParams.toString()}` : "";
|
|
20
18
|
if (normalizedRequest.headers?.length) {
|
|
21
19
|
options.headers = {};
|
|
@@ -37,7 +35,7 @@ const nodeUndici = {
|
|
|
37
35
|
if (normalizedRequest.postData) {
|
|
38
36
|
options.body = normalizedRequest.postData.text;
|
|
39
37
|
if (normalizedRequest.postData.mimeType === "application/json") {
|
|
40
|
-
options.body = `JSON.stringify(${objectToString(JSON.parse(options.body))})
|
|
38
|
+
options.body = new Unquoted(`JSON.stringify(${objectToString(JSON.parse(options.body))})`);
|
|
41
39
|
}
|
|
42
40
|
}
|
|
43
41
|
const jsonOptions = Object.keys(options).length ? `, ${objectToString(options)}` : "";
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/plugins/node/undici/undici.ts"],
|
|
4
|
-
"sourcesContent": ["import {
|
|
5
|
-
"mappings": "AAAA,SAAS,
|
|
4
|
+
"sourcesContent": ["import { createSearchParams } from '@/utils/create-search-params'\nimport { objectToString, Unquoted } from '@/utils/objectToString'\nimport type { Plugin } from '@scalar/types/snippetz'\n\n/**\n * node/undici\n */\nexport const nodeUndici: Plugin = {\n target: 'node',\n client: 'undici',\n title: 'undici',\n generate(request) {\n // Defaults\n const normalizedRequest = {\n method: 'GET',\n ...request,\n }\n\n // Normalization\n normalizedRequest.method = normalizedRequest.method.toUpperCase()\n\n // Reset undici defaults\n const options: Record<string, any> = {\n method: normalizedRequest.method === 'GET' ? undefined : normalizedRequest.method,\n }\n\n // Query\n const searchParams = createSearchParams(normalizedRequest.queryString)\n const queryString = searchParams.size ? `?${searchParams.toString()}` : ''\n\n // Headers\n if (normalizedRequest.headers?.length) {\n options.headers = {}\n\n normalizedRequest.headers.forEach((header) => {\n options.headers![header.name] = header.value\n })\n }\n\n // Cookies\n if (normalizedRequest.cookies?.length) {\n options.headers = options.headers || {}\n\n normalizedRequest.cookies.forEach((cookie) => {\n options.headers!['Set-Cookie'] = options.headers!['Set-Cookie']\n ? `${options.headers!['Set-Cookie']}; ${cookie.name}=${cookie.value}`\n : `${cookie.name}=${cookie.value}`\n })\n }\n\n // Remove undefined keys\n Object.keys(options).forEach((key) => {\n if (options[key] === undefined) {\n delete options[key]\n }\n })\n\n // Add body\n if (normalizedRequest.postData) {\n // Plain text\n options.body = normalizedRequest.postData.text\n\n // JSON\n if (normalizedRequest.postData.mimeType === 'application/json') {\n options.body = new Unquoted(`JSON.stringify(${objectToString(JSON.parse(options.body))})`)\n }\n }\n\n // Transform to JSON\n const jsonOptions = Object.keys(options).length ? `, ${objectToString(options)}` : ''\n\n // Code Template\n return `import { request } from 'undici'\n\nconst { statusCode, body } = await request('${normalizedRequest.url}${queryString}'${jsonOptions})`\n },\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,0BAA0B;AACnC,SAAS,gBAAgB,gBAAgB;AAMlC,MAAM,aAAqB;AAAA,EAChC,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,SAAS,SAAS;AAEhB,UAAM,oBAAoB;AAAA,MACxB,QAAQ;AAAA,MACR,GAAG;AAAA,IACL;AAGA,sBAAkB,SAAS,kBAAkB,OAAO,YAAY;AAGhE,UAAM,UAA+B;AAAA,MACnC,QAAQ,kBAAkB,WAAW,QAAQ,SAAY,kBAAkB;AAAA,IAC7E;AAGA,UAAM,eAAe,mBAAmB,kBAAkB,WAAW;AACrE,UAAM,cAAc,aAAa,OAAO,IAAI,aAAa,SAAS,CAAC,KAAK;AAGxE,QAAI,kBAAkB,SAAS,QAAQ;AACrC,cAAQ,UAAU,CAAC;AAEnB,wBAAkB,QAAQ,QAAQ,CAAC,WAAW;AAC5C,gBAAQ,QAAS,OAAO,IAAI,IAAI,OAAO;AAAA,MACzC,CAAC;AAAA,IACH;AAGA,QAAI,kBAAkB,SAAS,QAAQ;AACrC,cAAQ,UAAU,QAAQ,WAAW,CAAC;AAEtC,wBAAkB,QAAQ,QAAQ,CAAC,WAAW;AAC5C,gBAAQ,QAAS,YAAY,IAAI,QAAQ,QAAS,YAAY,IAC1D,GAAG,QAAQ,QAAS,YAAY,CAAC,KAAK,OAAO,IAAI,IAAI,OAAO,KAAK,KACjE,GAAG,OAAO,IAAI,IAAI,OAAO,KAAK;AAAA,MACpC,CAAC;AAAA,IACH;AAGA,WAAO,KAAK,OAAO,EAAE,QAAQ,CAAC,QAAQ;AACpC,UAAI,QAAQ,GAAG,MAAM,QAAW;AAC9B,eAAO,QAAQ,GAAG;AAAA,MACpB;AAAA,IACF,CAAC;AAGD,QAAI,kBAAkB,UAAU;AAE9B,cAAQ,OAAO,kBAAkB,SAAS;AAG1C,UAAI,kBAAkB,SAAS,aAAa,oBAAoB;AAC9D,gBAAQ,OAAO,IAAI,SAAS,kBAAkB,eAAe,KAAK,MAAM,QAAQ,IAAI,CAAC,CAAC,GAAG;AAAA,MAC3F;AAAA,IACF;AAGA,UAAM,cAAc,OAAO,KAAK,OAAO,EAAE,SAAS,KAAK,eAAe,OAAO,CAAC,KAAK;AAGnF,WAAO;AAAA;AAAA,8CAEmC,kBAAkB,GAAG,GAAG,WAAW,IAAI,WAAW;AAAA,EAC9F;AACF;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"requests.d.ts","sourceRoot":"","sources":["../../../../src/plugins/python/requests/requests.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AAIpD;;GAEG;AACH,eAAO,MAAM,cAAc,EAAE,
|
|
1
|
+
{"version":3,"file":"requests.d.ts","sourceRoot":"","sources":["../../../../src/plugins/python/requests/requests.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AAIpD;;GAEG;AACH,eAAO,MAAM,cAAc,EAAE,MAoI5B,CAAA"}
|
|
@@ -42,11 +42,11 @@ const pythonRequests = {
|
|
|
42
42
|
} else if (mimeType === "application/octet-stream" && text) {
|
|
43
43
|
options.data = text;
|
|
44
44
|
} else if (mimeType === "multipart/form-data" && params) {
|
|
45
|
-
const files =
|
|
45
|
+
const files = [];
|
|
46
46
|
const formData = {};
|
|
47
47
|
params.forEach((param) => {
|
|
48
48
|
if (param.fileName !== void 0) {
|
|
49
|
-
files
|
|
49
|
+
files.push({ key: param.name, file: `open("${param.fileName}", "rb")` });
|
|
50
50
|
} else if (param.value !== void 0) {
|
|
51
51
|
formData[param.name] = param.value;
|
|
52
52
|
}
|
|
@@ -72,7 +72,8 @@ const pythonRequests = {
|
|
|
72
72
|
if (key === "auth") {
|
|
73
73
|
formattedParams.push(`${key}=(${JSON.stringify(value[0])}, ${JSON.stringify(value[1])})`);
|
|
74
74
|
} else if (key === "files") {
|
|
75
|
-
const
|
|
75
|
+
const filesTuples = value.map(({ key: key2, file }) => ` ("${key2}", ${file})`);
|
|
76
|
+
const filesStr = "[\n" + filesTuples.join(",\n") + "\n ]";
|
|
76
77
|
formattedParams.push(`${key}=${filesStr}`);
|
|
77
78
|
} else if (key === "json") {
|
|
78
79
|
const jsonString = JSON.stringify(value, null, 2).split("\n").map((line, i) => i === 0 ? line : " " + line).join("\n");
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/plugins/python/requests/requests.ts"],
|
|
4
|
-
"sourcesContent": ["import type { Plugin } from '@scalar/types/snippetz'\n\nconst LENGTH_CONSIDERED_AS_SHORT = 40\n\n/**\n * python/requests\n */\nexport const pythonRequests: Plugin = {\n target: 'python',\n client: 'requests',\n title: 'Requests',\n generate(request, configuration) {\n // Normalize request with defaults\n const normalizedRequest = {\n url: 'https://example.com',\n method: 'get',\n ...request,\n }\n\n // Normalize method to lowercase for requests library\n const method = normalizedRequest.method.toLowerCase()\n\n // Build options object\n const options: Record<string, any> = {}\n\n // Add headers if present\n if (normalizedRequest.headers?.length) {\n options.headers = normalizedRequest.headers.reduce(\n (acc, header) => {\n if (!(header.name in acc)) {\n acc[header.name] = header.value\n }\n return acc\n },\n {} as Record<string, string>,\n )\n }\n\n // Add query parameters if present\n if (normalizedRequest.queryString?.length) {\n options.params = Object.fromEntries(normalizedRequest.queryString.map((q) => [q.name, q.value]))\n }\n\n // Add cookies if present\n if (normalizedRequest.cookies?.length) {\n options.cookies = Object.fromEntries(normalizedRequest.cookies.map((c) => [c.name, c.value]))\n }\n\n // Add auth if present\n if (configuration?.auth?.username && configuration?.auth?.password) {\n options.auth = [configuration.auth.username, configuration.auth.password]\n }\n\n // Handle request body\n if (normalizedRequest.postData) {\n const { mimeType, text, params } = normalizedRequest.postData\n\n if (mimeType === 'application/json' && text) {\n try {\n options.json = JSON.parse(text)\n } catch {\n options.data = text\n }\n } else if (mimeType === 'application/octet-stream' && text) {\n options.data = text // Store raw text, we'll handle the b\"...\" formatting later\n } else if (mimeType === 'multipart/form-data' && params) {\n const files:
|
|
5
|
-
"mappings": "AAEA,MAAM,6BAA6B;AAK5B,MAAM,iBAAyB;AAAA,EACpC,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,SAAS,SAAS,eAAe;AAE/B,UAAM,oBAAoB;AAAA,MACxB,KAAK;AAAA,MACL,QAAQ;AAAA,MACR,GAAG;AAAA,IACL;AAGA,UAAM,SAAS,kBAAkB,OAAO,YAAY;AAGpD,UAAM,UAA+B,CAAC;AAGtC,QAAI,kBAAkB,SAAS,QAAQ;AACrC,cAAQ,UAAU,kBAAkB,QAAQ;AAAA,QAC1C,CAAC,KAAK,WAAW;AACf,cAAI,EAAE,OAAO,QAAQ,MAAM;AACzB,gBAAI,OAAO,IAAI,IAAI,OAAO;AAAA,UAC5B;AACA,iBAAO;AAAA,QACT;AAAA,QACA,CAAC;AAAA,MACH;AAAA,IACF;AAGA,QAAI,kBAAkB,aAAa,QAAQ;AACzC,cAAQ,SAAS,OAAO,YAAY,kBAAkB,YAAY,IAAI,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;AAAA,IACjG;AAGA,QAAI,kBAAkB,SAAS,QAAQ;AACrC,cAAQ,UAAU,OAAO,YAAY,kBAAkB,QAAQ,IAAI,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;AAAA,IAC9F;AAGA,QAAI,eAAe,MAAM,YAAY,eAAe,MAAM,UAAU;AAClE,cAAQ,OAAO,CAAC,cAAc,KAAK,UAAU,cAAc,KAAK,QAAQ;AAAA,IAC1E;AAGA,QAAI,kBAAkB,UAAU;AAC9B,YAAM,EAAE,UAAU,MAAM,OAAO,IAAI,kBAAkB;AAErD,UAAI,aAAa,sBAAsB,MAAM;AAC3C,YAAI;AACF,kBAAQ,OAAO,KAAK,MAAM,IAAI;AAAA,QAChC,QAAQ;AACN,kBAAQ,OAAO;AAAA,QACjB;AAAA,MACF,WAAW,aAAa,8BAA8B,MAAM;AAC1D,gBAAQ,OAAO;AAAA,MACjB,WAAW,aAAa,yBAAyB,QAAQ;AACvD,cAAM,
|
|
6
|
-
"names": []
|
|
4
|
+
"sourcesContent": ["import type { Plugin } from '@scalar/types/snippetz'\n\nconst LENGTH_CONSIDERED_AS_SHORT = 40\n\n/**\n * python/requests\n */\nexport const pythonRequests: Plugin = {\n target: 'python',\n client: 'requests',\n title: 'Requests',\n generate(request, configuration) {\n // Normalize request with defaults\n const normalizedRequest = {\n url: 'https://example.com',\n method: 'get',\n ...request,\n }\n\n // Normalize method to lowercase for requests library\n const method = normalizedRequest.method.toLowerCase()\n\n // Build options object\n const options: Record<string, any> = {}\n\n // Add headers if present\n if (normalizedRequest.headers?.length) {\n options.headers = normalizedRequest.headers.reduce(\n (acc, header) => {\n if (!(header.name in acc)) {\n acc[header.name] = header.value\n }\n return acc\n },\n {} as Record<string, string>,\n )\n }\n\n // Add query parameters if present\n if (normalizedRequest.queryString?.length) {\n options.params = Object.fromEntries(normalizedRequest.queryString.map((q) => [q.name, q.value]))\n }\n\n // Add cookies if present\n if (normalizedRequest.cookies?.length) {\n options.cookies = Object.fromEntries(normalizedRequest.cookies.map((c) => [c.name, c.value]))\n }\n\n // Add auth if present\n if (configuration?.auth?.username && configuration?.auth?.password) {\n options.auth = [configuration.auth.username, configuration.auth.password]\n }\n\n // Handle request body\n if (normalizedRequest.postData) {\n const { mimeType, text, params } = normalizedRequest.postData\n\n if (mimeType === 'application/json' && text) {\n try {\n options.json = JSON.parse(text)\n } catch {\n options.data = text\n }\n } else if (mimeType === 'application/octet-stream' && text) {\n options.data = text // Store raw text, we'll handle the b\"...\" formatting later\n } else if (mimeType === 'multipart/form-data' && params) {\n const files: { key: string; file: string }[] = []\n const formData: Record<string, string> = {}\n\n params.forEach((param) => {\n if (param.fileName !== undefined) {\n files.push({ key: param.name, file: `open(\"${param.fileName}\", \"rb\")` })\n } else if (param.value !== undefined) {\n formData[param.name] = param.value\n }\n })\n\n if (Object.keys(files).length) {\n options.files = files\n }\n if (Object.keys(formData).length) {\n options.data = formData\n }\n } else if (mimeType === 'application/x-www-form-urlencoded' && params) {\n options.data = Object.fromEntries(params.map((p) => [p.name, p.value]))\n }\n }\n\n // Format all parameters\n const formattedParams: string[] = []\n\n // Format URL based on length\n const urlParam = `\"${normalizedRequest.url}\"`\n if (normalizedRequest.url.length > LENGTH_CONSIDERED_AS_SHORT) {\n formattedParams.push(urlParam)\n } else {\n // Will be handled in the return statement for short URLs\n formattedParams.push('')\n }\n\n // Format options\n for (const [key, value] of Object.entries(options)) {\n if (key === 'auth') {\n formattedParams.push(`${key}=(${JSON.stringify(value[0])}, ${JSON.stringify(value[1])})`)\n } else if (key === 'files') {\n const filesTuples = value.map(({ key, file }: { key: string; file: string }) => ` (\"${key}\", ${file})`)\n const filesStr = '[\\n' + filesTuples.join(',\\n') + '\\n ]'\n formattedParams.push(`${key}=${filesStr}`)\n } else if (key === 'json') {\n const jsonString = JSON.stringify(value, null, 2)\n .split('\\n')\n .map((line, i) => (i === 0 ? line : ' ' + line))\n .join('\\n')\n formattedParams.push(`${key}=${jsonString}`)\n } else if (key === 'data' && normalizedRequest.postData?.mimeType === 'application/octet-stream') {\n // Special handling for binary data\n formattedParams.push(`${key}=b\"${value}\"`)\n } else {\n const str = JSON.stringify(value, null, 2)\n .split('\\n')\n .map((line, i) => (i === 0 ? line : ' ' + line))\n .join('\\n')\n formattedParams.push(`${key}=${str}`)\n }\n }\n\n // Build the final request string with conditional URL formatting\n if (normalizedRequest.url.length > LENGTH_CONSIDERED_AS_SHORT) {\n return `requests.${method}(\\n ${formattedParams.join(',\\n ')}\\n)`\n }\n\n // For short URLs with no additional parameters, return a single-line format\n if (formattedParams.length <= 1) {\n return `requests.${method}(${urlParam})`\n }\n\n // For short URLs with parameters, maintain the multi-line format\n return `requests.${method}(${urlParam}${formattedParams.length > 1 ? ',' : ''}\\n ${formattedParams.slice(1).join(',\\n ')}\\n)`\n },\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["key"]
|
|
7
7
|
}
|
|
@@ -147,10 +147,37 @@ describe("pythonRequests", () => {
|
|
|
147
147
|
}
|
|
148
148
|
});
|
|
149
149
|
expect(result).toBe(`requests.post("https://example.com",
|
|
150
|
-
files=
|
|
150
|
+
files=[
|
|
151
|
+
("file", open("test.txt", "rb"))
|
|
152
|
+
],
|
|
151
153
|
data={
|
|
152
154
|
"field": "value"
|
|
153
155
|
}
|
|
156
|
+
)`);
|
|
157
|
+
});
|
|
158
|
+
it("handles multipart form data with multiple files", () => {
|
|
159
|
+
const result = pythonRequests.generate({
|
|
160
|
+
url: "https://example.com",
|
|
161
|
+
method: "POST",
|
|
162
|
+
postData: {
|
|
163
|
+
mimeType: "multipart/form-data",
|
|
164
|
+
params: [
|
|
165
|
+
{
|
|
166
|
+
name: "file",
|
|
167
|
+
fileName: "test.txt"
|
|
168
|
+
},
|
|
169
|
+
{
|
|
170
|
+
name: "file",
|
|
171
|
+
fileName: "another.txt"
|
|
172
|
+
}
|
|
173
|
+
]
|
|
174
|
+
}
|
|
175
|
+
});
|
|
176
|
+
expect(result).toBe(`requests.post("https://example.com",
|
|
177
|
+
files=[
|
|
178
|
+
("file", open("test.txt", "rb")),
|
|
179
|
+
("file", open("another.txt", "rb"))
|
|
180
|
+
]
|
|
154
181
|
)`);
|
|
155
182
|
});
|
|
156
183
|
it("handles url-encoded form data", () => {
|
|
@@ -291,7 +318,9 @@ describe("pythonRequests", () => {
|
|
|
291
318
|
}
|
|
292
319
|
});
|
|
293
320
|
expect(result).toBe(`requests.post("https://example.com",
|
|
294
|
-
files=
|
|
321
|
+
files=[
|
|
322
|
+
("file", open("", "rb"))
|
|
323
|
+
]
|
|
295
324
|
)`);
|
|
296
325
|
});
|
|
297
326
|
it("handles JSON body with special characters", () => {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/plugins/python/requests/requests.test.ts"],
|
|
4
|
-
"sourcesContent": ["import { describe, expect, it } from 'vitest'\nimport { pythonRequests } from './requests'\n\ndescribe('pythonRequests', () => {\n it('returns a basic request', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n })\n\n expect(result).toBe('requests.get(\"https://example.com\")')\n })\n\n it('returns a POST request', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'post',\n })\n\n expect(result).toBe('requests.post(\"https://example.com\")')\n })\n\n it('has headers', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n headers={\n \"Content-Type\": \"application/json\"\n }\n)`)\n })\n\n it('doesn\u2019t add empty headers', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n headers: [],\n })\n\n expect(result).toBe('requests.get(\"https://example.com\")')\n })\n\n it('has JSON body', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n postData: {\n mimeType: 'application/json',\n text: JSON.stringify({\n hello: 'world',\n }),\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n headers={\n \"Content-Type\": \"application/json\"\n },\n json={\n \"hello\": \"world\"\n }\n)`)\n })\n\n it('has query string', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n queryString: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n params={\n \"foo\": \"bar\",\n \"bar\": \"foo\"\n }\n)`)\n })\n\n it('has cookies', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n cookies: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n cookies={\n \"foo\": \"bar\",\n \"bar\": \"foo\"\n }\n)`)\n })\n\n it('doesn\u2019t add empty cookies', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n cookies: [],\n })\n\n expect(result).toBe('requests.get(\"https://example.com\")')\n })\n\n it('adds basic auth credentials', () => {\n const result = pythonRequests.generate(\n {\n url: 'https://example.com',\n },\n {\n auth: {\n username: 'user',\n password: 'pass',\n },\n },\n )\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n auth=(\"user\", \"pass\")\n)`)\n })\n\n it('handles multipart form data with files', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'multipart/form-data',\n params: [\n {\n name: 'file',\n fileName: 'test.txt',\n },\n {\n name: 'field',\n value: 'value',\n },\n ],\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n files={\"file\": open(\"test.txt\", \"rb\")},\n data={\n \"field\": \"value\"\n }\n)`)\n })\n\n it('handles url-encoded form data', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'application/x-www-form-urlencoded',\n params: [\n {\n name: 'special chars!@#',\n value: 'value',\n },\n ],\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n data={\n \"special chars!@#\": \"value\"\n }\n)`)\n })\n\n it('handles binary data flag', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'application/octet-stream',\n text: 'binary content',\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n data=b\"binary content\"\n)`)\n })\n\n it('handles compressed response', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Accept-Encoding',\n value: 'gzip, deflate',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n headers={\n \"Accept-Encoding\": \"gzip, deflate\"\n }\n)`)\n })\n\n it('handles special characters in URL', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com/path with spaces/[brackets]',\n })\n\n expect(result).toBe(`requests.get(\n \"https://example.com/path with spaces/[brackets]\"\n)`)\n })\n\n it('handles special characters in query parameters', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n queryString: [\n {\n name: 'q',\n value: 'hello world & more',\n },\n {\n name: 'special',\n value: '!@#$%^&*()',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n params={\n \"q\": \"hello world & more\",\n \"special\": \"!@#$%^&*()\"\n }\n)`)\n })\n\n it('handles empty URL', () => {\n const result = pythonRequests.generate({\n url: '',\n })\n\n expect(result).toBe('requests.get(\"\")')\n })\n\n it('doesn\u2019t add a line break for a short URL', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n })\n\n expect(result).toBe('requests.get(\"https://example.com\")')\n })\n\n it('handles extremely long URLs', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com/' + 'a'.repeat(2000),\n })\n\n expect(result).toBe(`requests.get(\n \"https://example.com/${'a'.repeat(2000)}\"\n)`)\n })\n\n it('handles multiple headers with same name', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n headers: [\n { name: 'X-Custom', value: 'value1' },\n { name: 'X-Custom', value: 'value2' },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n headers={\n \"X-Custom\": \"value1\"\n }\n)`)\n })\n\n it('handles headers with empty values', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n headers: [{ name: 'X-Empty', value: '' }],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n headers={\n \"X-Empty\": \"\"\n }\n)`)\n })\n\n it('handles multipart form data with empty file names', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'multipart/form-data',\n params: [\n {\n name: 'file',\n fileName: '',\n },\n ],\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n files={\"file\": open(\"\", \"rb\")}\n)`)\n })\n\n it('handles JSON body with special characters', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n postData: {\n mimeType: 'application/json',\n text: JSON.stringify({\n key: '\"quotes\" and \\\\backslashes\\\\',\n nested: {\n array: ['item1', null, undefined],\n },\n }),\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n headers={\n \"Content-Type\": \"application/json\"\n },\n json={\n \"key\": \"\\\\\"quotes\\\\\" and \\\\\\\\backslashes\\\\\\\\\",\n \"nested\": {\n \"array\": [\n \"item1\",\n null,\n null\n ]\n }\n }\n)`)\n })\n\n it('handles cookies with special characters', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n cookies: [\n {\n name: 'special;cookie',\n value: 'value with spaces',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n cookies={\n \"special;cookie\": \"value with spaces\"\n }\n)`)\n })\n\n it('prettifies JSON body', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n postData: {\n mimeType: 'application/json',\n text: JSON.stringify({\n nested: {\n array: [1, 2, 3],\n object: { foo: 'bar' },\n },\n simple: 'value',\n }),\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n headers={\n \"Content-Type\": \"application/json\"\n },\n json={\n \"nested\": {\n \"array\": [\n 1,\n 2,\n 3\n ],\n \"object\": {\n \"foo\": \"bar\"\n }\n },\n \"simple\": \"value\"\n }\n)`)\n })\n})\n"],
|
|
5
|
-
"mappings": "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
|
|
4
|
+
"sourcesContent": ["import { describe, expect, it } from 'vitest'\nimport { pythonRequests } from './requests'\n\ndescribe('pythonRequests', () => {\n it('returns a basic request', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n })\n\n expect(result).toBe('requests.get(\"https://example.com\")')\n })\n\n it('returns a POST request', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'post',\n })\n\n expect(result).toBe('requests.post(\"https://example.com\")')\n })\n\n it('has headers', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n headers={\n \"Content-Type\": \"application/json\"\n }\n)`)\n })\n\n it('doesn\u2019t add empty headers', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n headers: [],\n })\n\n expect(result).toBe('requests.get(\"https://example.com\")')\n })\n\n it('has JSON body', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n postData: {\n mimeType: 'application/json',\n text: JSON.stringify({\n hello: 'world',\n }),\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n headers={\n \"Content-Type\": \"application/json\"\n },\n json={\n \"hello\": \"world\"\n }\n)`)\n })\n\n it('has query string', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n queryString: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n params={\n \"foo\": \"bar\",\n \"bar\": \"foo\"\n }\n)`)\n })\n\n it('has cookies', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n cookies: [\n {\n name: 'foo',\n value: 'bar',\n },\n {\n name: 'bar',\n value: 'foo',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n cookies={\n \"foo\": \"bar\",\n \"bar\": \"foo\"\n }\n)`)\n })\n\n it('doesn\u2019t add empty cookies', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n cookies: [],\n })\n\n expect(result).toBe('requests.get(\"https://example.com\")')\n })\n\n it('adds basic auth credentials', () => {\n const result = pythonRequests.generate(\n {\n url: 'https://example.com',\n },\n {\n auth: {\n username: 'user',\n password: 'pass',\n },\n },\n )\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n auth=(\"user\", \"pass\")\n)`)\n })\n\n it('handles multipart form data with files', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'multipart/form-data',\n params: [\n {\n name: 'file',\n fileName: 'test.txt',\n },\n {\n name: 'field',\n value: 'value',\n },\n ],\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n files=[\n (\"file\", open(\"test.txt\", \"rb\"))\n ],\n data={\n \"field\": \"value\"\n }\n)`)\n })\n\n it('handles multipart form data with multiple files', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'multipart/form-data',\n params: [\n {\n name: 'file',\n fileName: 'test.txt',\n },\n {\n name: 'file',\n fileName: 'another.txt',\n },\n ],\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n files=[\n (\"file\", open(\"test.txt\", \"rb\")),\n (\"file\", open(\"another.txt\", \"rb\"))\n ]\n)`)\n })\n\n it('handles url-encoded form data', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'application/x-www-form-urlencoded',\n params: [\n {\n name: 'special chars!@#',\n value: 'value',\n },\n ],\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n data={\n \"special chars!@#\": \"value\"\n }\n)`)\n })\n\n it('handles binary data flag', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'application/octet-stream',\n text: 'binary content',\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n data=b\"binary content\"\n)`)\n })\n\n it('handles compressed response', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Accept-Encoding',\n value: 'gzip, deflate',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n headers={\n \"Accept-Encoding\": \"gzip, deflate\"\n }\n)`)\n })\n\n it('handles special characters in URL', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com/path with spaces/[brackets]',\n })\n\n expect(result).toBe(`requests.get(\n \"https://example.com/path with spaces/[brackets]\"\n)`)\n })\n\n it('handles special characters in query parameters', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n queryString: [\n {\n name: 'q',\n value: 'hello world & more',\n },\n {\n name: 'special',\n value: '!@#$%^&*()',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n params={\n \"q\": \"hello world & more\",\n \"special\": \"!@#$%^&*()\"\n }\n)`)\n })\n\n it('handles empty URL', () => {\n const result = pythonRequests.generate({\n url: '',\n })\n\n expect(result).toBe('requests.get(\"\")')\n })\n\n it('doesn\u2019t add a line break for a short URL', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n })\n\n expect(result).toBe('requests.get(\"https://example.com\")')\n })\n\n it('handles extremely long URLs', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com/' + 'a'.repeat(2000),\n })\n\n expect(result).toBe(`requests.get(\n \"https://example.com/${'a'.repeat(2000)}\"\n)`)\n })\n\n it('handles multiple headers with same name', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n headers: [\n { name: 'X-Custom', value: 'value1' },\n { name: 'X-Custom', value: 'value2' },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n headers={\n \"X-Custom\": \"value1\"\n }\n)`)\n })\n\n it('handles headers with empty values', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n headers: [{ name: 'X-Empty', value: '' }],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n headers={\n \"X-Empty\": \"\"\n }\n)`)\n })\n\n it('handles multipart form data with empty file names', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'multipart/form-data',\n params: [\n {\n name: 'file',\n fileName: '',\n },\n ],\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n files=[\n (\"file\", open(\"\", \"rb\"))\n ]\n)`)\n })\n\n it('handles JSON body with special characters', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n postData: {\n mimeType: 'application/json',\n text: JSON.stringify({\n key: '\"quotes\" and \\\\backslashes\\\\',\n nested: {\n array: ['item1', null, undefined],\n },\n }),\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n headers={\n \"Content-Type\": \"application/json\"\n },\n json={\n \"key\": \"\\\\\"quotes\\\\\" and \\\\\\\\backslashes\\\\\\\\\",\n \"nested\": {\n \"array\": [\n \"item1\",\n null,\n null\n ]\n }\n }\n)`)\n })\n\n it('handles cookies with special characters', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n cookies: [\n {\n name: 'special;cookie',\n value: 'value with spaces',\n },\n ],\n })\n\n expect(result).toBe(`requests.get(\"https://example.com\",\n cookies={\n \"special;cookie\": \"value with spaces\"\n }\n)`)\n })\n\n it('prettifies JSON body', () => {\n const result = pythonRequests.generate({\n url: 'https://example.com',\n method: 'POST',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n postData: {\n mimeType: 'application/json',\n text: JSON.stringify({\n nested: {\n array: [1, 2, 3],\n object: { foo: 'bar' },\n },\n simple: 'value',\n }),\n },\n })\n\n expect(result).toBe(`requests.post(\"https://example.com\",\n headers={\n \"Content-Type\": \"application/json\"\n },\n json={\n \"nested\": {\n \"array\": [\n 1,\n 2,\n 3\n ],\n \"object\": {\n \"foo\": \"bar\"\n }\n },\n \"simple\": \"value\"\n }\n)`)\n })\n})\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -27,7 +27,7 @@ describe("shellHttpie", () => {
|
|
|
27
27
|
expect(result).toBe(`http GET https://example.com \\
|
|
28
28
|
Content-Type:application/json`);
|
|
29
29
|
});
|
|
30
|
-
it
|
|
30
|
+
it("handles multipart form data with files", () => {
|
|
31
31
|
const result = shellHttpie.generate({
|
|
32
32
|
url: "https://example.com",
|
|
33
33
|
method: "POST",
|
|
@@ -45,9 +45,9 @@ describe("shellHttpie", () => {
|
|
|
45
45
|
]
|
|
46
46
|
}
|
|
47
47
|
});
|
|
48
|
-
expect(result).toBe(`http POST https://example.com \\
|
|
48
|
+
expect(result).toBe(`http --multipart POST https://example.com \\
|
|
49
49
|
file@test.txt \\
|
|
50
|
-
field=value`);
|
|
50
|
+
field='value'`);
|
|
51
51
|
});
|
|
52
52
|
it.skip("handles url-encoded form data with special characters", () => {
|
|
53
53
|
const result = shellHttpie.generate({
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../../src/plugins/shell/httpie/httpie.test.ts"],
|
|
4
|
-
"sourcesContent": ["import { describe, expect, it } from 'vitest'\n\nimport { shellHttpie } from './httpie'\n\ndescribe('shellHttpie', () => {\n it('returns a basic request', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n })\n\n expect(result).toBe('http GET https://example.com')\n })\n\n it('returns a POST request', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n method: 'post',\n })\n\n expect(result).toBe('http POST https://example.com')\n })\n\n it('has headers', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n })\n expect(result).toBe(`http GET https://example.com \\\\\n Content-Type:application/json`)\n })\n\n it
|
|
5
|
-
"mappings": "AAAA,SAAS,UAAU,QAAQ,UAAU;AAErC,SAAS,mBAAmB;AAE5B,SAAS,eAAe,MAAM;AAC5B,KAAG,2BAA2B,MAAM;AAClC,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,IACP,CAAC;AAED,WAAO,MAAM,EAAE,KAAK,8BAA8B;AAAA,EACpD,CAAC;AAED,KAAG,0BAA0B,MAAM;AACjC,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,MACL,QAAQ;AAAA,IACV,CAAC;AAED,WAAO,MAAM,EAAE,KAAK,+BAA+B;AAAA,EACrD,CAAC;AAED,KAAG,eAAe,MAAM;AACtB,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,MACL,SAAS;AAAA,QACP;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF,CAAC;AACD,WAAO,MAAM,EAAE,KAAK;AAAA,gCACQ;AAAA,EAC9B,CAAC;AAED,KAAG,
|
|
4
|
+
"sourcesContent": ["import { describe, expect, it } from 'vitest'\n\nimport { shellHttpie } from './httpie'\n\ndescribe('shellHttpie', () => {\n it('returns a basic request', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n })\n\n expect(result).toBe('http GET https://example.com')\n })\n\n it('returns a POST request', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n method: 'post',\n })\n\n expect(result).toBe('http POST https://example.com')\n })\n\n it('has headers', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n headers: [\n {\n name: 'Content-Type',\n value: 'application/json',\n },\n ],\n })\n expect(result).toBe(`http GET https://example.com \\\\\n Content-Type:application/json`)\n })\n\n it('handles multipart form data with files', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'multipart/form-data',\n params: [\n {\n name: 'file',\n fileName: 'test.txt',\n },\n {\n name: 'field',\n value: 'value',\n },\n ],\n },\n })\n\n expect(result).toBe(`http --multipart POST https://example.com \\\\\n file@test.txt \\\\\n field='value'`)\n })\n\n it.skip('handles url-encoded form data with special characters', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'application/x-www-form-urlencoded',\n params: [\n {\n name: 'special chars!@#',\n value: 'value',\n },\n ],\n },\n })\n\n expect(result).toBe(`http --form POST https://example.com/ \\\\\n 'special chars!@#=value'`)\n })\n\n it('handles binary data', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n method: 'POST',\n postData: {\n mimeType: 'application/octet-stream',\n text: 'binary content',\n },\n })\n\n expect(result).toBe(`echo 'binary content' | \\\\\n http POST https://example.com`)\n })\n\n it('handles special characters in URL', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com/path with spaces/[brackets]',\n })\n\n expect(result).toBe(`http GET 'https://example.com/path%20with%20spaces/[brackets]'`)\n })\n\n it('handles multiple headers with same name', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n headers: [\n { name: 'X-Custom', value: 'value1' },\n { name: 'X-Custom', value: 'value2' },\n ],\n })\n\n expect(result).toBe(`http GET https://example.com \\\\\n X-Custom:value2`)\n })\n\n it('handles headers with empty values', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com',\n headers: [{ name: 'X-Empty', value: '' }],\n })\n\n expect(result).toBe(`http GET https://example.com \\\\\n X-Empty:''`)\n })\n\n it('handles query string parameters', () => {\n const result = shellHttpie.generate({\n url: 'https://example.com/api?param1=value1¶m2=special value¶m3=123',\n })\n\n expect(result).toBe(`http GET 'https://example.com/api?param1=value1¶m2=special%20value¶m3=123'`)\n })\n})\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,UAAU,QAAQ,UAAU;AAErC,SAAS,mBAAmB;AAE5B,SAAS,eAAe,MAAM;AAC5B,KAAG,2BAA2B,MAAM;AAClC,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,IACP,CAAC;AAED,WAAO,MAAM,EAAE,KAAK,8BAA8B;AAAA,EACpD,CAAC;AAED,KAAG,0BAA0B,MAAM;AACjC,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,MACL,QAAQ;AAAA,IACV,CAAC;AAED,WAAO,MAAM,EAAE,KAAK,+BAA+B;AAAA,EACrD,CAAC;AAED,KAAG,eAAe,MAAM;AACtB,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,MACL,SAAS;AAAA,QACP;AAAA,UACE,MAAM;AAAA,UACN,OAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF,CAAC;AACD,WAAO,MAAM,EAAE,KAAK;AAAA,gCACQ;AAAA,EAC9B,CAAC;AAED,KAAG,0CAA0C,MAAM;AACjD,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,MACL,QAAQ;AAAA,MACR,UAAU;AAAA,QACR,UAAU;AAAA,QACV,QAAQ;AAAA,UACN;AAAA,YACE,MAAM;AAAA,YACN,UAAU;AAAA,UACZ;AAAA,UACA;AAAA,YACE,MAAM;AAAA,YACN,OAAO;AAAA,UACT;AAAA,QACF;AAAA,MACF;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA;AAAA,gBAER;AAAA,EACd,CAAC;AAED,KAAG,KAAK,yDAAyD,MAAM;AACrE,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,MACL,QAAQ;AAAA,MACR,UAAU;AAAA,QACR,UAAU;AAAA,QACV,QAAQ;AAAA,UACN;AAAA,YACE,MAAM;AAAA,YACN,OAAO;AAAA,UACT;AAAA,QACF;AAAA,MACF;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA,2BACG;AAAA,EACzB,CAAC;AAED,KAAG,uBAAuB,MAAM;AAC9B,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,MACL,QAAQ;AAAA,MACR,UAAU;AAAA,QACR,UAAU;AAAA,QACV,MAAM;AAAA,MACR;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA,gCACQ;AAAA,EAC9B,CAAC;AAED,KAAG,qCAAqC,MAAM;AAC5C,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,IACP,CAAC;AAED,WAAO,MAAM,EAAE,KAAK,gEAAgE;AAAA,EACtF,CAAC;AAED,KAAG,2CAA2C,MAAM;AAClD,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,MACL,SAAS;AAAA,QACP,EAAE,MAAM,YAAY,OAAO,SAAS;AAAA,QACpC,EAAE,MAAM,YAAY,OAAO,SAAS;AAAA,MACtC;AAAA,IACF,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA,kBACN;AAAA,EAChB,CAAC;AAED,KAAG,qCAAqC,MAAM;AAC5C,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,MACL,SAAS,CAAC,EAAE,MAAM,WAAW,OAAO,GAAG,CAAC;AAAA,IAC1C,CAAC;AAED,WAAO,MAAM,EAAE,KAAK;AAAA,aACX;AAAA,EACX,CAAC;AAED,KAAG,mCAAmC,MAAM;AAC1C,UAAM,SAAS,YAAY,SAAS;AAAA,MAClC,KAAK;AAAA,IACP,CAAC;AAED,WAAO,MAAM,EAAE,KAAK,oFAAoF;AAAA,EAC1G,CAAC;AACH,CAAC;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { HarRequest } from '@scalar/types/snippetz';
|
|
2
|
+
/** Creates a new URL search params object and sets query params so we can handle arrays */
|
|
3
|
+
export declare const createSearchParams: (query?: HarRequest["queryString"]) => URLSearchParams;
|
|
4
|
+
//# sourceMappingURL=create-search-params.d.ts.map
|