@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.
Files changed (80) hide show
  1. package/dist/httpsnippet-lite/esm/targets/c/libcurl/client.d.ts.map +1 -1
  2. package/dist/httpsnippet-lite/esm/targets/c/libcurl/client.js +37 -8
  3. package/dist/httpsnippet-lite/esm/targets/c/libcurl/client.js.map +2 -2
  4. package/dist/httpsnippet-lite/esm/targets/go/native/client.d.ts.map +1 -1
  5. package/dist/httpsnippet-lite/esm/targets/go/native/client.js +76 -30
  6. package/dist/httpsnippet-lite/esm/targets/go/native/client.js.map +2 -2
  7. package/dist/httpsnippet-lite/esm/targets/java/okhttp/client.d.ts.map +1 -1
  8. package/dist/httpsnippet-lite/esm/targets/java/okhttp/client.js +25 -9
  9. package/dist/httpsnippet-lite/esm/targets/java/okhttp/client.js.map +2 -2
  10. package/dist/httpsnippet-lite/esm/targets/kotlin/okhttp/client.d.ts.map +1 -1
  11. package/dist/httpsnippet-lite/esm/targets/kotlin/okhttp/client.js +25 -9
  12. package/dist/httpsnippet-lite/esm/targets/kotlin/okhttp/client.js.map +2 -2
  13. package/dist/httpsnippet-lite/esm/targets/shell/httpie/client.d.ts.map +1 -1
  14. package/dist/httpsnippet-lite/esm/targets/shell/httpie/client.js +11 -0
  15. package/dist/httpsnippet-lite/esm/targets/shell/httpie/client.js.map +2 -2
  16. package/dist/plugins/c/libcurl/libcurl.test.js +19 -11
  17. package/dist/plugins/c/libcurl/libcurl.test.js.map +2 -2
  18. package/dist/plugins/go/native/native.test.js +35 -36
  19. package/dist/plugins/go/native/native.test.js.map +2 -2
  20. package/dist/plugins/java/okhttp/okhttp.test.js +164 -0
  21. package/dist/plugins/java/okhttp/okhttp.test.js.map +7 -0
  22. package/dist/plugins/js/axios/index.d.ts +1 -1
  23. package/dist/plugins/js/axios/index.d.ts.map +1 -1
  24. package/dist/plugins/js/axios/index.js +4 -1
  25. package/dist/plugins/js/axios/index.js.map +2 -2
  26. package/dist/plugins/js/fetch/fetch.d.ts.map +1 -1
  27. package/dist/plugins/js/fetch/fetch.js +30 -9
  28. package/dist/plugins/js/fetch/fetch.js.map +2 -2
  29. package/dist/plugins/js/fetch/fetch.test.js +103 -0
  30. package/dist/plugins/js/fetch/fetch.test.js.map +2 -2
  31. package/dist/plugins/js/fetch/index.d.ts +1 -1
  32. package/dist/plugins/js/fetch/index.d.ts.map +1 -1
  33. package/dist/plugins/js/fetch/index.js +4 -1
  34. package/dist/plugins/js/fetch/index.js.map +2 -2
  35. package/dist/plugins/js/ofetch/ofetch.d.ts.map +1 -1
  36. package/dist/plugins/js/ofetch/ofetch.js +1 -10
  37. package/dist/plugins/js/ofetch/ofetch.js.map +2 -2
  38. package/dist/plugins/js/ofetch/ofetch.test.js +7 -4
  39. package/dist/plugins/js/ofetch/ofetch.test.js.map +2 -2
  40. package/dist/plugins/kotlin/okhttp/okhttp.test.js +164 -0
  41. package/dist/plugins/kotlin/okhttp/okhttp.test.js.map +7 -0
  42. package/dist/plugins/node/fetch/fetch.d.ts.map +1 -1
  43. package/dist/plugins/node/fetch/fetch.js +37 -9
  44. package/dist/plugins/node/fetch/fetch.js.map +2 -2
  45. package/dist/plugins/node/fetch/fetch.test.js +89 -0
  46. package/dist/plugins/node/fetch/fetch.test.js.map +2 -2
  47. package/dist/plugins/node/ofetch/ofetch.d.ts.map +1 -1
  48. package/dist/plugins/node/ofetch/ofetch.js +1 -10
  49. package/dist/plugins/node/ofetch/ofetch.js.map +2 -2
  50. package/dist/plugins/node/ofetch/ofetch.test.js +7 -4
  51. package/dist/plugins/node/ofetch/ofetch.test.js.map +2 -2
  52. package/dist/plugins/node/undici/undici.d.ts.map +1 -1
  53. package/dist/plugins/node/undici/undici.js +4 -6
  54. package/dist/plugins/node/undici/undici.js.map +2 -2
  55. package/dist/plugins/python/requests/requests.d.ts.map +1 -1
  56. package/dist/plugins/python/requests/requests.js +4 -3
  57. package/dist/plugins/python/requests/requests.js.map +3 -3
  58. package/dist/plugins/python/requests/requests.test.js +31 -2
  59. package/dist/plugins/python/requests/requests.test.js.map +2 -2
  60. package/dist/plugins/shell/httpie/httpie.test.js +3 -3
  61. package/dist/plugins/shell/httpie/httpie.test.js.map +2 -2
  62. package/dist/utils/create-search-params.d.ts +4 -0
  63. package/dist/utils/create-search-params.d.ts.map +1 -0
  64. package/dist/utils/create-search-params.js +11 -0
  65. package/dist/utils/create-search-params.js.map +7 -0
  66. package/dist/utils/create-search-params.test.js +49 -0
  67. package/dist/utils/create-search-params.test.js.map +7 -0
  68. package/dist/utils/index.d.ts +0 -1
  69. package/dist/utils/index.d.ts.map +1 -1
  70. package/dist/utils/index.js +0 -1
  71. package/dist/utils/index.js.map +2 -2
  72. package/dist/utils/objectToString.d.ts +8 -0
  73. package/dist/utils/objectToString.d.ts.map +1 -1
  74. package/dist/utils/objectToString.js +20 -15
  75. package/dist/utils/objectToString.js.map +2 -2
  76. package/package.json +5 -5
  77. package/dist/utils/arrayToObject.d.ts +0 -8
  78. package/dist/utils/arrayToObject.d.ts.map +0 -1
  79. package/dist/utils/arrayToObject.js +0 -10
  80. 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,GAOrB;AAAA,EACD,CAAC;AAED,KAAG,oBAAoB,MAAM;AAC3B,UAAM,SAAS,UAAU,SAAS;AAAA,MAChC,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,8CAA8C;AAAA,EACpE,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,QACA;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;AACH,CAAC;",
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":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAA;AAEpD;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,MA6ExB,CAAA"}
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
- const searchParams = new URLSearchParams(
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 { arrayToObject } from '@/utils/arrayToObject'\nimport { 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 const searchParams = new URLSearchParams(\n normalizedRequest.queryString ? arrayToObject(normalizedRequest.queryString) : undefined,\n )\n\n if (searchParams.size) {\n options.query = {}\n searchParams.forEach((value, key) => {\n options.query[key] = value\n })\n }\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,qBAAqB;AAC9B,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,UAAM,eAAe,IAAI;AAAA,MACvB,kBAAkB,cAAc,cAAc,kBAAkB,WAAW,IAAI;AAAA,IACjF;AAEA,QAAI,aAAa,MAAM;AACrB,cAAQ,QAAQ,CAAC;AACjB,mBAAa,QAAQ,CAAC,OAAO,QAAQ;AACnC,gBAAQ,MAAM,GAAG,IAAI;AAAA,MACvB,CAAC;AAAA,IACH;AAGA,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;",
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
- foo: 'bar',
87
- bar: 'foo'
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 bar: '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,GAOrB;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;",
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,MAuExB,CAAA"}
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 { arrayToObject } from "../../../utils/arrayToObject.js";
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 = new URLSearchParams(
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 { arrayToObject } from '@/utils/arrayToObject'\nimport { objectToString } 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 = new URLSearchParams(\n normalizedRequest.queryString ? arrayToObject(normalizedRequest.queryString) : undefined,\n )\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 = `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,qBAAqB;AAC9B,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,UAAM,eAAe,IAAI;AAAA,MACvB,kBAAkB,cAAc,cAAc,kBAAkB,WAAW,IAAI;AAAA,IACjF;AACA,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,kBAAkB,eAAe,KAAK,MAAM,QAAQ,IAAI,CAAC,CAAC;AAAA,MAC3E;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;",
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,MAsI5B,CAAA"}
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[param.name] = `open("${param.fileName}", "rb")`;
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 filesStr = JSON.stringify(value).replace(/"open\((.*?)\)"/g, "open($1)").replace(/":open/g, '": open').replace(/\\"/g, '"');
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: Record<string, string> = {}\n const formData: Record<string, string> = {}\n\n params.forEach((param) => {\n if (param.fileName !== undefined) {\n files[param.name] = `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 filesStr = JSON.stringify(value)\n .replace(/\"open\\((.*?)\\)\"/g, 'open($1)')\n .replace(/\":open/g, '\": open')\n .replace(/\\\\\"/g, '\"')\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": []
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={"file": open("test.txt", "rb")},
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={"file": open("", "rb")}
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.skip("handles multipart form data with files", () => {
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.skip('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 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&param2=special value&param3=123',\n })\n\n expect(result).toBe(`http GET 'https://example.com/api?param1=value1&param2=special%20value&param3=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,KAAK,0CAA0C,MAAM;AACtD,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,cAEV;AAAA,EACZ,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;",
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&param2=special value&param3=123',\n })\n\n expect(result).toBe(`http GET 'https://example.com/api?param1=value1&param2=special%20value&param3=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