@corellium/corellium-cli 1.4.0 → 1.5.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 (614) hide show
  1. package/.eslintrc.js +12 -16
  2. package/.gitlab-ci.yml +13 -13
  3. package/.nvmrc +1 -1
  4. package/.nycrc +14 -14
  5. package/.prettierrc.js +8 -7
  6. package/README.md +13 -6
  7. package/docs/OVERVIEW.md +57 -27
  8. package/index.js +8 -8
  9. package/lint-staged.config.js +3 -6
  10. package/node_modules/@babel/cli/README.md +1 -1
  11. package/node_modules/@babel/cli/bin/babel-external-helpers.mjs +3 -0
  12. package/node_modules/@babel/cli/bin/babel.mjs +3 -0
  13. package/node_modules/@babel/cli/lib/babel/dir.js +23 -73
  14. package/node_modules/@babel/cli/lib/babel/dir.js.map +1 -0
  15. package/node_modules/@babel/cli/lib/babel/file.js +27 -72
  16. package/node_modules/@babel/cli/lib/babel/file.js.map +1 -0
  17. package/node_modules/@babel/cli/lib/babel/index.js +6 -8
  18. package/node_modules/@babel/cli/lib/babel/index.js.map +1 -0
  19. package/node_modules/@babel/cli/lib/babel/options.js +70 -143
  20. package/node_modules/@babel/cli/lib/babel/options.js.map +1 -0
  21. package/node_modules/@babel/cli/lib/babel/util.js +39 -59
  22. package/node_modules/@babel/cli/lib/babel/util.js.map +1 -0
  23. package/node_modules/@babel/cli/lib/babel/watcher.js +19 -52
  24. package/node_modules/@babel/cli/lib/babel/watcher.js.map +1 -0
  25. package/node_modules/@babel/cli/lib/babel-external-helpers.js +14 -21
  26. package/node_modules/@babel/cli/lib/babel-external-helpers.js.map +1 -0
  27. package/node_modules/@babel/cli/package.json +11 -9
  28. package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.mjs +19 -29
  29. package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.mjs.map +1 -1
  30. package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.umd.js +19 -29
  31. package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.umd.js.map +1 -1
  32. package/node_modules/@jridgewell/resolve-uri/package.json +2 -2
  33. package/node_modules/@jridgewell/sourcemap-codec/README.md +147 -83
  34. package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.mjs +351 -91
  35. package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.mjs.map +1 -1
  36. package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.umd.js +354 -90
  37. package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.umd.js.map +1 -1
  38. package/node_modules/@jridgewell/sourcemap-codec/dist/types/scopes.d.ts +49 -0
  39. package/node_modules/@jridgewell/sourcemap-codec/dist/types/sourcemap-codec.d.ts +2 -0
  40. package/node_modules/@jridgewell/sourcemap-codec/dist/types/strings.d.ts +15 -0
  41. package/node_modules/@jridgewell/sourcemap-codec/dist/types/vlq.d.ts +6 -0
  42. package/node_modules/@jridgewell/sourcemap-codec/package.json +7 -7
  43. package/node_modules/@jridgewell/trace-mapping/README.md +5 -0
  44. package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.mjs +202 -174
  45. package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.mjs.map +1 -1
  46. package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.umd.js +216 -182
  47. package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.umd.js.map +1 -1
  48. package/node_modules/@jridgewell/trace-mapping/dist/types/any-map.d.ts +1 -1
  49. package/node_modules/@jridgewell/trace-mapping/dist/types/binary-search.d.ts +1 -1
  50. package/node_modules/@jridgewell/trace-mapping/dist/types/by-source.d.ts +1 -1
  51. package/node_modules/@jridgewell/trace-mapping/dist/types/sourcemap-segment.d.ts +8 -8
  52. package/node_modules/@jridgewell/trace-mapping/dist/types/trace-mapping.d.ts +33 -28
  53. package/node_modules/@jridgewell/trace-mapping/dist/types/types.d.ts +23 -16
  54. package/node_modules/@jridgewell/trace-mapping/package.json +20 -18
  55. package/node_modules/anymatch/index.d.ts +1 -0
  56. package/node_modules/anymatch/index.js +1 -1
  57. package/node_modules/anymatch/package.json +1 -1
  58. package/node_modules/{form-data/README.md.bak → axios/node_modules/form-data/Readme.md} +4 -4
  59. package/node_modules/{superagent → axios}/node_modules/form-data/lib/form_data.js +8 -5
  60. package/node_modules/{superagent → axios}/node_modules/form-data/package.json +9 -6
  61. package/node_modules/binary-extensions/binary-extensions.json +3 -0
  62. package/node_modules/binary-extensions/license +2 -1
  63. package/node_modules/binary-extensions/package.json +4 -2
  64. package/node_modules/binary-extensions/readme.md +2 -18
  65. package/node_modules/braces/LICENSE +1 -1
  66. package/node_modules/braces/README.md +91 -98
  67. package/node_modules/braces/index.js +3 -3
  68. package/node_modules/braces/lib/compile.js +14 -11
  69. package/node_modules/braces/lib/constants.js +1 -1
  70. package/node_modules/braces/lib/expand.js +9 -9
  71. package/node_modules/braces/lib/parse.js +14 -16
  72. package/node_modules/braces/lib/stringify.js +4 -4
  73. package/node_modules/braces/lib/utils.js +13 -3
  74. package/node_modules/braces/package.json +2 -2
  75. package/node_modules/{call-bind → call-bind-apply-helpers}/.eslintrc +0 -1
  76. package/node_modules/call-bind-apply-helpers/.github/FUNDING.yml +12 -0
  77. package/node_modules/call-bind-apply-helpers/.nycrc +9 -0
  78. package/node_modules/call-bind-apply-helpers/CHANGELOG.md +23 -0
  79. package/node_modules/{call-bind → call-bind-apply-helpers}/LICENSE +1 -1
  80. package/node_modules/call-bind-apply-helpers/README.md +62 -0
  81. package/node_modules/call-bind-apply-helpers/actualApply.d.ts +1 -0
  82. package/node_modules/call-bind-apply-helpers/actualApply.js +10 -0
  83. package/node_modules/call-bind-apply-helpers/applyBind.d.ts +19 -0
  84. package/node_modules/call-bind-apply-helpers/applyBind.js +10 -0
  85. package/node_modules/call-bind-apply-helpers/functionApply.d.ts +1 -0
  86. package/node_modules/call-bind-apply-helpers/functionApply.js +4 -0
  87. package/node_modules/call-bind-apply-helpers/functionCall.d.ts +1 -0
  88. package/node_modules/call-bind-apply-helpers/functionCall.js +4 -0
  89. package/node_modules/call-bind-apply-helpers/index.d.ts +46 -0
  90. package/node_modules/call-bind-apply-helpers/index.js +15 -0
  91. package/node_modules/call-bind-apply-helpers/package.json +85 -0
  92. package/node_modules/call-bind-apply-helpers/reflectApply.d.ts +3 -0
  93. package/node_modules/call-bind-apply-helpers/reflectApply.js +4 -0
  94. package/node_modules/call-bind-apply-helpers/test/index.js +63 -0
  95. package/node_modules/call-bind-apply-helpers/tsconfig.json +9 -0
  96. package/node_modules/call-bound/.eslintrc +13 -0
  97. package/node_modules/call-bound/.github/FUNDING.yml +12 -0
  98. package/node_modules/call-bound/.nycrc +9 -0
  99. package/node_modules/call-bound/CHANGELOG.md +34 -0
  100. package/node_modules/call-bound/LICENSE +21 -0
  101. package/node_modules/call-bound/README.md +53 -0
  102. package/node_modules/call-bound/index.d.ts +13 -0
  103. package/node_modules/call-bound/index.js +18 -0
  104. package/node_modules/call-bound/package.json +99 -0
  105. package/node_modules/{call-bind/test/callBound.js → call-bound/test/index.js} +1 -2
  106. package/node_modules/call-bound/tsconfig.json +9 -0
  107. package/node_modules/chokidar/README.md +1 -1
  108. package/node_modules/chokidar/index.js +1 -1
  109. package/node_modules/chokidar/lib/constants.js +1 -0
  110. package/node_modules/chokidar/lib/fsevents-handler.js +2 -0
  111. package/node_modules/chokidar/package.json +5 -20
  112. package/node_modules/chokidar/types/index.d.ts +4 -0
  113. package/node_modules/cliui/CHANGELOG.md +18 -0
  114. package/node_modules/cliui/build/index.d.cts +43 -0
  115. package/node_modules/cliui/package.json +6 -6
  116. package/node_modules/commander/CHANGELOG.md +361 -0
  117. package/node_modules/{@babel/cli/node_modules/commander → commander}/Readme.md +243 -165
  118. package/node_modules/commander/index.js +1881 -0
  119. package/node_modules/{@babel/cli/node_modules/commander → commander}/package.json +19 -9
  120. package/node_modules/commander/typings/index.d.ts +410 -0
  121. package/node_modules/component-emitter/LICENSE +24 -24
  122. package/node_modules/component-emitter/Readme.md +74 -74
  123. package/node_modules/component-emitter/index.js +175 -175
  124. package/node_modules/component-emitter/package.json +3 -2
  125. package/node_modules/convert-source-map/README.md +97 -11
  126. package/node_modules/convert-source-map/index.js +127 -30
  127. package/node_modules/convert-source-map/package.json +3 -9
  128. package/node_modules/cookiejar/cookiejar.js +5 -0
  129. package/node_modules/cookiejar/package.json +1 -1
  130. package/node_modules/debug/README.md +1 -1
  131. package/node_modules/debug/package.json +10 -4
  132. package/node_modules/debug/src/browser.js +4 -1
  133. package/node_modules/debug/src/common.js +57 -39
  134. package/node_modules/debug/src/node.js +2 -2
  135. package/node_modules/dotenv/CHANGELOG.md +133 -1
  136. package/node_modules/dotenv/README-es.md +448 -0
  137. package/node_modules/dotenv/README.md +309 -66
  138. package/node_modules/dotenv/lib/cli-options.js +1 -1
  139. package/node_modules/dotenv/lib/env-options.js +4 -0
  140. package/node_modules/dotenv/lib/main.d.ts +85 -5
  141. package/node_modules/dotenv/lib/main.js +287 -35
  142. package/node_modules/dotenv/package.json +19 -14
  143. package/node_modules/dunder-proto/.eslintrc +5 -0
  144. package/node_modules/dunder-proto/.github/FUNDING.yml +12 -0
  145. package/node_modules/dunder-proto/CHANGELOG.md +24 -0
  146. package/node_modules/dunder-proto/LICENSE +21 -0
  147. package/node_modules/dunder-proto/README.md +54 -0
  148. package/node_modules/dunder-proto/get.d.ts +5 -0
  149. package/node_modules/dunder-proto/get.js +30 -0
  150. package/node_modules/dunder-proto/package.json +76 -0
  151. package/node_modules/dunder-proto/set.d.ts +5 -0
  152. package/node_modules/dunder-proto/set.js +35 -0
  153. package/node_modules/dunder-proto/test/get.js +34 -0
  154. package/node_modules/dunder-proto/test/index.js +4 -0
  155. package/node_modules/dunder-proto/test/set.js +50 -0
  156. package/node_modules/dunder-proto/tsconfig.json +9 -0
  157. package/node_modules/es-define-property/.eslintrc +13 -0
  158. package/node_modules/es-define-property/.github/FUNDING.yml +12 -0
  159. package/node_modules/es-define-property/.nycrc +9 -0
  160. package/node_modules/es-define-property/CHANGELOG.md +29 -0
  161. package/node_modules/es-define-property/LICENSE +21 -0
  162. package/node_modules/es-define-property/README.md +49 -0
  163. package/node_modules/es-define-property/index.d.ts +3 -0
  164. package/node_modules/es-define-property/index.js +14 -0
  165. package/node_modules/es-define-property/package.json +81 -0
  166. package/node_modules/es-define-property/test/index.js +56 -0
  167. package/node_modules/es-define-property/tsconfig.json +10 -0
  168. package/node_modules/es-errors/.eslintrc +5 -0
  169. package/node_modules/es-errors/.github/FUNDING.yml +12 -0
  170. package/node_modules/es-errors/CHANGELOG.md +40 -0
  171. package/node_modules/es-errors/LICENSE +21 -0
  172. package/node_modules/es-errors/README.md +55 -0
  173. package/node_modules/es-errors/eval.d.ts +3 -0
  174. package/node_modules/es-errors/eval.js +4 -0
  175. package/node_modules/es-errors/index.d.ts +3 -0
  176. package/node_modules/es-errors/index.js +4 -0
  177. package/node_modules/es-errors/package.json +80 -0
  178. package/node_modules/es-errors/range.d.ts +3 -0
  179. package/node_modules/es-errors/range.js +4 -0
  180. package/node_modules/es-errors/ref.d.ts +3 -0
  181. package/node_modules/es-errors/ref.js +4 -0
  182. package/node_modules/es-errors/syntax.d.ts +3 -0
  183. package/node_modules/es-errors/syntax.js +4 -0
  184. package/node_modules/es-errors/test/index.js +19 -0
  185. package/node_modules/es-errors/tsconfig.json +49 -0
  186. package/node_modules/es-errors/type.d.ts +3 -0
  187. package/node_modules/es-errors/type.js +4 -0
  188. package/node_modules/es-errors/uri.d.ts +3 -0
  189. package/node_modules/es-errors/uri.js +4 -0
  190. package/node_modules/es-object-atoms/.eslintrc +16 -0
  191. package/node_modules/es-object-atoms/.github/FUNDING.yml +12 -0
  192. package/node_modules/es-object-atoms/CHANGELOG.md +37 -0
  193. package/node_modules/es-object-atoms/LICENSE +21 -0
  194. package/node_modules/es-object-atoms/README.md +63 -0
  195. package/node_modules/es-object-atoms/RequireObjectCoercible.d.ts +3 -0
  196. package/node_modules/es-object-atoms/RequireObjectCoercible.js +11 -0
  197. package/node_modules/es-object-atoms/ToObject.d.ts +7 -0
  198. package/node_modules/es-object-atoms/ToObject.js +10 -0
  199. package/node_modules/es-object-atoms/index.d.ts +3 -0
  200. package/node_modules/es-object-atoms/index.js +4 -0
  201. package/node_modules/es-object-atoms/isObject.d.ts +3 -0
  202. package/node_modules/es-object-atoms/isObject.js +6 -0
  203. package/node_modules/es-object-atoms/package.json +80 -0
  204. package/node_modules/es-object-atoms/test/index.js +38 -0
  205. package/node_modules/es-object-atoms/tsconfig.json +6 -0
  206. package/node_modules/escalade/index.d.mts +11 -0
  207. package/node_modules/escalade/index.d.ts +14 -2
  208. package/node_modules/escalade/package.json +18 -5
  209. package/node_modules/escalade/readme.md +1 -1
  210. package/node_modules/escalade/sync/index.d.mts +9 -0
  211. package/node_modules/escalade/sync/index.d.ts +13 -2
  212. package/node_modules/fill-range/index.js +4 -5
  213. package/node_modules/fill-range/package.json +8 -3
  214. package/node_modules/follow-redirects/index.js +186 -98
  215. package/node_modules/follow-redirects/package.json +3 -4
  216. package/node_modules/form-data/Readme.md +5 -7
  217. package/node_modules/form-data/lib/form_data.js +5 -8
  218. package/node_modules/form-data/package.json +9 -6
  219. package/node_modules/function-bind/.eslintrc +11 -5
  220. package/node_modules/function-bind/.github/FUNDING.yml +12 -0
  221. package/node_modules/function-bind/.github/SECURITY.md +3 -0
  222. package/node_modules/function-bind/.nycrc +13 -0
  223. package/node_modules/function-bind/CHANGELOG.md +136 -0
  224. package/node_modules/function-bind/README.md +25 -27
  225. package/node_modules/function-bind/implementation.js +44 -12
  226. package/node_modules/function-bind/package.json +38 -14
  227. package/node_modules/get-intrinsic/.eslintrc +1 -0
  228. package/node_modules/get-intrinsic/CHANGELOG.md +87 -0
  229. package/node_modules/get-intrinsic/index.js +75 -32
  230. package/node_modules/get-intrinsic/package.json +31 -22
  231. package/node_modules/get-intrinsic/test/GetIntrinsic.js +3 -3
  232. package/node_modules/get-proto/.eslintrc +10 -0
  233. package/node_modules/{call-bind → get-proto}/.github/FUNDING.yml +1 -1
  234. package/node_modules/get-proto/.nycrc +9 -0
  235. package/node_modules/get-proto/CHANGELOG.md +21 -0
  236. package/node_modules/get-proto/LICENSE +21 -0
  237. package/node_modules/get-proto/Object.getPrototypeOf.d.ts +5 -0
  238. package/node_modules/get-proto/Object.getPrototypeOf.js +6 -0
  239. package/node_modules/get-proto/README.md +50 -0
  240. package/node_modules/get-proto/Reflect.getPrototypeOf.d.ts +3 -0
  241. package/node_modules/get-proto/Reflect.getPrototypeOf.js +4 -0
  242. package/node_modules/get-proto/index.d.ts +5 -0
  243. package/node_modules/get-proto/index.js +27 -0
  244. package/node_modules/get-proto/package.json +81 -0
  245. package/node_modules/get-proto/test/index.js +68 -0
  246. package/node_modules/get-proto/tsconfig.json +9 -0
  247. package/node_modules/gopd/.eslintrc +16 -0
  248. package/node_modules/gopd/.github/FUNDING.yml +12 -0
  249. package/node_modules/gopd/CHANGELOG.md +45 -0
  250. package/node_modules/gopd/LICENSE +21 -0
  251. package/node_modules/gopd/README.md +40 -0
  252. package/node_modules/gopd/gOPD.d.ts +1 -0
  253. package/node_modules/gopd/gOPD.js +4 -0
  254. package/node_modules/gopd/index.d.ts +5 -0
  255. package/node_modules/gopd/index.js +15 -0
  256. package/node_modules/gopd/package.json +77 -0
  257. package/node_modules/gopd/test/index.js +36 -0
  258. package/node_modules/gopd/tsconfig.json +9 -0
  259. package/node_modules/has-symbols/CHANGELOG.md +16 -0
  260. package/node_modules/has-symbols/index.d.ts +3 -0
  261. package/node_modules/has-symbols/index.js +1 -0
  262. package/node_modules/has-symbols/package.json +19 -9
  263. package/node_modules/has-symbols/shams.d.ts +3 -0
  264. package/node_modules/has-symbols/shams.js +5 -2
  265. package/node_modules/has-symbols/test/shams/core-js.js +1 -0
  266. package/node_modules/has-symbols/test/shams/get-own-property-symbols.js +1 -0
  267. package/node_modules/has-symbols/test/tests.js +4 -2
  268. package/node_modules/has-symbols/tsconfig.json +10 -0
  269. package/node_modules/hasown/.eslintrc +5 -0
  270. package/node_modules/hasown/.github/FUNDING.yml +12 -0
  271. package/node_modules/hasown/.nycrc +13 -0
  272. package/node_modules/hasown/CHANGELOG.md +40 -0
  273. package/node_modules/hasown/LICENSE +21 -0
  274. package/node_modules/hasown/README.md +40 -0
  275. package/node_modules/hasown/index.d.ts +3 -0
  276. package/node_modules/hasown/index.js +8 -0
  277. package/node_modules/hasown/package.json +92 -0
  278. package/node_modules/hasown/tsconfig.json +6 -0
  279. package/node_modules/make-dir/node_modules/semver/package.json +38 -0
  280. package/node_modules/{@babel/cli → make-dir}/node_modules/semver/semver.js +68 -26
  281. package/node_modules/math-intrinsics/.eslintrc +16 -0
  282. package/node_modules/math-intrinsics/.github/FUNDING.yml +12 -0
  283. package/node_modules/math-intrinsics/CHANGELOG.md +24 -0
  284. package/node_modules/math-intrinsics/LICENSE +21 -0
  285. package/node_modules/math-intrinsics/README.md +50 -0
  286. package/node_modules/math-intrinsics/abs.d.ts +1 -0
  287. package/node_modules/math-intrinsics/abs.js +4 -0
  288. package/node_modules/math-intrinsics/constants/maxArrayLength.d.ts +3 -0
  289. package/node_modules/math-intrinsics/constants/maxArrayLength.js +4 -0
  290. package/node_modules/math-intrinsics/constants/maxSafeInteger.d.ts +3 -0
  291. package/node_modules/math-intrinsics/constants/maxSafeInteger.js +5 -0
  292. package/node_modules/math-intrinsics/constants/maxValue.d.ts +3 -0
  293. package/node_modules/math-intrinsics/constants/maxValue.js +5 -0
  294. package/node_modules/math-intrinsics/floor.d.ts +1 -0
  295. package/node_modules/math-intrinsics/floor.js +4 -0
  296. package/node_modules/math-intrinsics/isFinite.d.ts +3 -0
  297. package/node_modules/math-intrinsics/isFinite.js +12 -0
  298. package/node_modules/math-intrinsics/isInteger.d.ts +3 -0
  299. package/node_modules/math-intrinsics/isInteger.js +16 -0
  300. package/node_modules/math-intrinsics/isNaN.d.ts +1 -0
  301. package/node_modules/math-intrinsics/isNaN.js +6 -0
  302. package/node_modules/math-intrinsics/isNegativeZero.d.ts +3 -0
  303. package/node_modules/math-intrinsics/isNegativeZero.js +6 -0
  304. package/node_modules/math-intrinsics/max.d.ts +1 -0
  305. package/node_modules/math-intrinsics/max.js +4 -0
  306. package/node_modules/math-intrinsics/min.d.ts +1 -0
  307. package/node_modules/math-intrinsics/min.js +4 -0
  308. package/node_modules/math-intrinsics/mod.d.ts +3 -0
  309. package/node_modules/math-intrinsics/mod.js +9 -0
  310. package/node_modules/math-intrinsics/package.json +86 -0
  311. package/node_modules/math-intrinsics/pow.d.ts +1 -0
  312. package/node_modules/math-intrinsics/pow.js +4 -0
  313. package/node_modules/math-intrinsics/round.d.ts +1 -0
  314. package/node_modules/math-intrinsics/round.js +4 -0
  315. package/node_modules/math-intrinsics/sign.d.ts +3 -0
  316. package/node_modules/math-intrinsics/sign.js +11 -0
  317. package/node_modules/math-intrinsics/test/index.js +192 -0
  318. package/node_modules/math-intrinsics/tsconfig.json +3 -0
  319. package/node_modules/ms/index.js +1 -1
  320. package/node_modules/ms/license.md +1 -1
  321. package/node_modules/ms/package.json +5 -4
  322. package/node_modules/ms/readme.md +1 -2
  323. package/node_modules/object-inspect/CHANGELOG.md +56 -0
  324. package/node_modules/object-inspect/index.js +38 -9
  325. package/node_modules/object-inspect/package.json +23 -13
  326. package/node_modules/object-inspect/readme.markdown +9 -11
  327. package/node_modules/object-inspect/test/global.js +17 -0
  328. package/node_modules/object-inspect/test/quoteStyle.js +9 -0
  329. package/node_modules/qs/.editorconfig +3 -0
  330. package/node_modules/qs/.eslintrc +3 -2
  331. package/node_modules/qs/CHANGELOG.md +81 -5
  332. package/node_modules/qs/README.md +158 -50
  333. package/node_modules/qs/dist/qs.js +90 -2003
  334. package/node_modules/qs/lib/parse.js +89 -24
  335. package/node_modules/qs/lib/stringify.js +61 -31
  336. package/node_modules/qs/lib/utils.js +54 -38
  337. package/node_modules/qs/package.json +29 -13
  338. package/node_modules/qs/test/empty-keys-cases.js +267 -0
  339. package/node_modules/qs/test/parse.js +468 -47
  340. package/node_modules/qs/test/stringify.js +454 -57
  341. package/node_modules/qs/test/utils.js +126 -0
  342. package/node_modules/side-channel/.editorconfig +9 -0
  343. package/node_modules/side-channel/.eslintrc +2 -1
  344. package/node_modules/side-channel/CHANGELOG.md +45 -0
  345. package/node_modules/side-channel/README.md +60 -1
  346. package/node_modules/side-channel/index.d.ts +14 -0
  347. package/node_modules/side-channel/index.js +21 -102
  348. package/node_modules/side-channel/package.json +40 -22
  349. package/node_modules/side-channel/test/index.js +78 -52
  350. package/node_modules/side-channel/tsconfig.json +9 -0
  351. package/node_modules/{function-bind → side-channel-list}/.editorconfig +3 -14
  352. package/node_modules/side-channel-list/.eslintrc +11 -0
  353. package/node_modules/side-channel-list/.github/FUNDING.yml +12 -0
  354. package/node_modules/side-channel-list/.nycrc +13 -0
  355. package/node_modules/side-channel-list/CHANGELOG.md +15 -0
  356. package/node_modules/side-channel-list/LICENSE +21 -0
  357. package/node_modules/side-channel-list/README.md +62 -0
  358. package/node_modules/side-channel-list/index.d.ts +13 -0
  359. package/node_modules/side-channel-list/index.js +113 -0
  360. package/node_modules/side-channel-list/list.d.ts +14 -0
  361. package/node_modules/side-channel-list/package.json +77 -0
  362. package/node_modules/side-channel-list/test/index.js +104 -0
  363. package/node_modules/side-channel-list/tsconfig.json +9 -0
  364. package/node_modules/side-channel-map/.editorconfig +9 -0
  365. package/node_modules/side-channel-map/.eslintrc +11 -0
  366. package/node_modules/side-channel-map/.github/FUNDING.yml +12 -0
  367. package/node_modules/side-channel-map/.nycrc +13 -0
  368. package/node_modules/side-channel-map/CHANGELOG.md +22 -0
  369. package/node_modules/side-channel-map/LICENSE +21 -0
  370. package/node_modules/side-channel-map/README.md +62 -0
  371. package/node_modules/side-channel-map/index.d.ts +15 -0
  372. package/node_modules/side-channel-map/index.js +68 -0
  373. package/node_modules/side-channel-map/package.json +80 -0
  374. package/node_modules/side-channel-map/test/index.js +114 -0
  375. package/node_modules/side-channel-map/tsconfig.json +9 -0
  376. package/node_modules/side-channel-weakmap/.editorconfig +9 -0
  377. package/node_modules/side-channel-weakmap/.eslintrc +12 -0
  378. package/node_modules/side-channel-weakmap/.github/FUNDING.yml +12 -0
  379. package/node_modules/side-channel-weakmap/.nycrc +13 -0
  380. package/node_modules/side-channel-weakmap/CHANGELOG.md +28 -0
  381. package/node_modules/side-channel-weakmap/LICENSE +21 -0
  382. package/node_modules/side-channel-weakmap/README.md +62 -0
  383. package/node_modules/side-channel-weakmap/index.d.ts +15 -0
  384. package/node_modules/side-channel-weakmap/index.js +84 -0
  385. package/node_modules/side-channel-weakmap/package.json +87 -0
  386. package/node_modules/side-channel-weakmap/test/index.js +114 -0
  387. package/node_modules/side-channel-weakmap/tsconfig.json +9 -0
  388. package/node_modules/superagent/node_modules/readable-stream/README.md +1 -1
  389. package/node_modules/superagent/node_modules/readable-stream/lib/_stream_duplex.js +12 -25
  390. package/node_modules/superagent/node_modules/readable-stream/lib/_stream_passthrough.js +2 -4
  391. package/node_modules/superagent/node_modules/readable-stream/lib/_stream_readable.js +176 -273
  392. package/node_modules/superagent/node_modules/readable-stream/lib/_stream_transform.js +26 -37
  393. package/node_modules/superagent/node_modules/readable-stream/lib/_stream_writable.js +118 -174
  394. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/async_iterator.js +10 -37
  395. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/buffer_list.js +20 -47
  396. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/destroy.js +8 -17
  397. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +1 -19
  398. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/from.js +12 -24
  399. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/pipeline.js +5 -16
  400. package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/state.js +2 -7
  401. package/node_modules/superagent/node_modules/readable-stream/package.json +1 -1
  402. package/node_modules/{semver → superagent/node_modules/semver}/README.md +132 -36
  403. package/node_modules/{semver → superagent/node_modules/semver}/bin/semver.js +22 -16
  404. package/node_modules/{semver → superagent/node_modules/semver}/classes/comparator.js +39 -34
  405. package/node_modules/{semver → superagent/node_modules/semver}/classes/range.js +72 -37
  406. package/node_modules/{semver → superagent/node_modules/semver}/classes/semver.js +49 -19
  407. package/node_modules/{semver → superagent/node_modules/semver}/functions/coerce.js +14 -6
  408. package/node_modules/superagent/node_modules/semver/functions/diff.js +58 -0
  409. package/node_modules/{semver → superagent/node_modules/semver}/functions/inc.js +3 -2
  410. package/node_modules/superagent/node_modules/semver/functions/parse.js +16 -0
  411. package/node_modules/superagent/node_modules/semver/index.js +89 -0
  412. package/node_modules/{semver → superagent/node_modules/semver}/internal/constants.js +20 -2
  413. package/node_modules/superagent/node_modules/semver/internal/lrucache.js +40 -0
  414. package/node_modules/superagent/node_modules/semver/internal/parse-options.js +15 -0
  415. package/node_modules/{semver → superagent/node_modules/semver}/internal/re.js +41 -6
  416. package/node_modules/{semver → superagent/node_modules/semver}/package.json +29 -26
  417. package/node_modules/{semver → superagent/node_modules/semver}/ranges/intersects.js +1 -1
  418. package/node_modules/{semver → superagent/node_modules/semver}/ranges/subset.js +6 -3
  419. package/node_modules/yargs/browser.d.ts +5 -0
  420. package/node_modules/yargs/build/index.cjs +1 -1
  421. package/node_modules/yargs/build/lib/command.js +2 -0
  422. package/node_modules/yargs/build/lib/completion.js +19 -12
  423. package/node_modules/yargs/build/lib/usage.js +9 -4
  424. package/node_modules/yargs/build/lib/yargs-factory.js +18 -3
  425. package/node_modules/yargs/locales/cs.json +51 -0
  426. package/node_modules/yargs/locales/en.json +4 -0
  427. package/node_modules/yargs/locales/fi.json +1 -1
  428. package/node_modules/yargs/package.json +4 -4
  429. package/node_modules/yargs-parser/CHANGELOG.md +21 -0
  430. package/node_modules/yargs-parser/build/index.cjs +6 -4
  431. package/node_modules/yargs-parser/build/lib/index.js +4 -2
  432. package/node_modules/yargs-parser/build/lib/yargs-parser.js +2 -2
  433. package/node_modules/yargs-parser/package.json +10 -6
  434. package/output/e3e8277b426d4bc636a8ed30e66dd056e6cc9691-corellium-cli-build.tar.gz +0 -0
  435. package/package.json +1 -1
  436. package/renovate.json +11 -58
  437. package/src/clients/Agent.js +40 -37
  438. package/src/clients/Client.js +42 -40
  439. package/src/clients/Instance.js +24 -24
  440. package/src/clients/Webplayer.js +23 -24
  441. package/src/commands/extensions/delete.js +26 -26
  442. package/src/commands/extensions/index.js +6 -11
  443. package/src/commands/extensions/list.js +25 -25
  444. package/src/commands/extensions/load.js +51 -50
  445. package/src/commands/extensions/validate.js +33 -38
  446. package/src/commands/firmware/index.js +6 -9
  447. package/src/commands/firmware/list.js +49 -38
  448. package/src/commands/firmware/load.js +45 -42
  449. package/src/commands/images/create.js +30 -29
  450. package/src/commands/images/delete.js +21 -21
  451. package/src/commands/images/index.js +6 -10
  452. package/src/commands/images/list.js +21 -20
  453. package/src/commands/index.js +2 -2
  454. package/src/commands/instances/apps/index.js +26 -23
  455. package/src/commands/instances/apps/install.js +14 -14
  456. package/src/commands/instances/apps/open.js +17 -17
  457. package/src/commands/instances/create.js +35 -38
  458. package/src/commands/instances/delete.js +24 -25
  459. package/src/commands/instances/file.js +36 -32
  460. package/src/commands/instances/get.js +23 -16
  461. package/src/commands/instances/index.js +8 -8
  462. package/src/commands/instances/input.js +16 -17
  463. package/src/commands/instances/list.js +38 -28
  464. package/src/commands/instances/netmon/disable.js +17 -15
  465. package/src/commands/instances/netmon/download.js +18 -16
  466. package/src/commands/instances/netmon/enable.js +30 -23
  467. package/src/commands/instances/netmon/index.js +6 -11
  468. package/src/commands/instances/netmon/stream.js +18 -16
  469. package/src/commands/instances/ready.js +30 -27
  470. package/src/commands/instances/restoreBackup.js +39 -36
  471. package/src/commands/instances/rotate.js +20 -21
  472. package/src/commands/instances/start.js +23 -24
  473. package/src/commands/instances/stop.js +20 -21
  474. package/src/commands/instances/unlock.js +17 -19
  475. package/src/commands/instances/upgrade.js +38 -34
  476. package/src/commands/login.js +67 -67
  477. package/src/commands/logout.js +10 -12
  478. package/src/commands/mast/constants.js +2 -2
  479. package/src/commands/mast/create-assessment.js +16 -16
  480. package/src/commands/mast/delete-assessment.js +15 -15
  481. package/src/commands/mast/download-report.js +18 -15
  482. package/src/commands/mast/get-assessment.js +14 -14
  483. package/src/commands/mast/get-assessments.js +13 -13
  484. package/src/commands/mast/index.js +7 -7
  485. package/src/commands/mast/start-monitor.js +15 -15
  486. package/src/commands/mast/stop-monitor.js +15 -15
  487. package/src/commands/mast/test.js +19 -16
  488. package/src/commands/projects/create.js +33 -32
  489. package/src/commands/projects/delete.js +26 -26
  490. package/src/commands/projects/index.js +6 -11
  491. package/src/commands/projects/list.js +21 -19
  492. package/src/commands/projects/vpnConfig.js +29 -26
  493. package/src/commands/webplayer/create.js +57 -50
  494. package/src/commands/webplayer/destroy.js +31 -28
  495. package/src/commands/webplayer/index.js +6 -11
  496. package/src/commands/webplayer/list.js +41 -42
  497. package/src/commands/webplayer/login.js +31 -28
  498. package/src/corellium-api.js +11 -11
  499. package/src/error.js +20 -18
  500. package/src/logging.js +15 -15
  501. package/src/profile.js +22 -22
  502. package/src/progress.js +6 -6
  503. package/src/resumable.js +606 -664
  504. package/src/table.js +20 -22
  505. package/src/upload.js +38 -38
  506. package/src/utils.js +63 -64
  507. package/test/test.js +47 -48
  508. package/coverage/cobertura-coverage.xml +0 -9
  509. package/coverage/lcov-report/base.css +0 -224
  510. package/coverage/lcov-report/block-navigation.js +0 -87
  511. package/coverage/lcov-report/favicon.png +0 -0
  512. package/coverage/lcov-report/index.html +0 -101
  513. package/coverage/lcov-report/prettify.css +0 -1
  514. package/coverage/lcov-report/prettify.js +0 -2
  515. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  516. package/coverage/lcov-report/sorter.js +0 -196
  517. package/coverage/lcov.info +0 -0
  518. package/node_modules/@babel/cli/node_modules/commander/CHANGELOG.md +0 -436
  519. package/node_modules/@babel/cli/node_modules/commander/index.js +0 -1649
  520. package/node_modules/@babel/cli/node_modules/commander/typings/index.d.ts +0 -311
  521. package/node_modules/@babel/cli/node_modules/semver/CHANGELOG.md +0 -39
  522. package/node_modules/@babel/cli/node_modules/semver/package.json +0 -28
  523. package/node_modules/@jridgewell/sourcemap-codec/src/sourcemap-codec.ts +0 -198
  524. package/node_modules/braces/CHANGELOG.md +0 -184
  525. package/node_modules/call-bind/.eslintignore +0 -1
  526. package/node_modules/call-bind/CHANGELOG.md +0 -42
  527. package/node_modules/call-bind/README.md +0 -2
  528. package/node_modules/call-bind/callBound.js +0 -15
  529. package/node_modules/call-bind/index.js +0 -47
  530. package/node_modules/call-bind/package.json +0 -80
  531. package/node_modules/call-bind/test/index.js +0 -66
  532. package/node_modules/component-emitter/History.md +0 -75
  533. package/node_modules/function-bind/.jscs.json +0 -176
  534. package/node_modules/function-bind/.npmignore +0 -22
  535. package/node_modules/function-bind/.travis.yml +0 -168
  536. package/node_modules/has/LICENSE-MIT +0 -22
  537. package/node_modules/has/README.md +0 -18
  538. package/node_modules/has/package.json +0 -48
  539. package/node_modules/has/src/index.js +0 -5
  540. package/node_modules/has/test/index.js +0 -10
  541. package/node_modules/lru-cache/README.md +0 -166
  542. package/node_modules/lru-cache/index.js +0 -334
  543. package/node_modules/lru-cache/package.json +0 -34
  544. package/node_modules/semver/LICENSE +0 -15
  545. package/node_modules/semver/functions/diff.js +0 -23
  546. package/node_modules/semver/functions/parse.js +0 -33
  547. package/node_modules/semver/index.js +0 -48
  548. package/node_modules/semver/internal/parse-options.js +0 -11
  549. package/node_modules/side-channel/.eslintignore +0 -1
  550. package/node_modules/superagent/node_modules/form-data/README.md.bak +0 -356
  551. package/node_modules/superagent/node_modules/form-data/Readme.md +0 -356
  552. package/node_modules/yallist/LICENSE +0 -15
  553. package/node_modules/yallist/README.md +0 -204
  554. package/node_modules/yallist/iterator.js +0 -8
  555. package/node_modules/yallist/package.json +0 -29
  556. package/node_modules/yallist/yallist.js +0 -426
  557. /package/node_modules/{superagent → axios}/node_modules/form-data/License +0 -0
  558. /package/node_modules/{superagent → axios}/node_modules/form-data/index.d.ts +0 -0
  559. /package/node_modules/{superagent → axios}/node_modules/form-data/lib/browser.js +0 -0
  560. /package/node_modules/{superagent → axios}/node_modules/form-data/lib/populate.js +0 -0
  561. /package/node_modules/{@babel/cli/node_modules/commander → commander}/LICENSE +0 -0
  562. /package/node_modules/{call-bind → dunder-proto}/.nycrc +0 -0
  563. /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/index.d.ts +0 -0
  564. /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/index.js +0 -0
  565. /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/license +0 -0
  566. /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/LICENSE +0 -0
  567. /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/README.md +0 -0
  568. /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/bin/semver +0 -0
  569. /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/range.bnf +0 -0
  570. /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/package.json +0 -0
  571. /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/readme.md +0 -0
  572. /package/node_modules/{@babel/cli/node_modules/pify → pify}/index.js +0 -0
  573. /package/node_modules/{@babel/cli/node_modules/pify → pify}/license +0 -0
  574. /package/node_modules/{@babel/cli/node_modules/pify → pify}/package.json +0 -0
  575. /package/node_modules/{@babel/cli/node_modules/pify → pify}/readme.md +0 -0
  576. /package/node_modules/{@babel/cli/node_modules/slash → slash}/index.js +0 -0
  577. /package/node_modules/{@babel/cli/node_modules/slash → slash}/license +0 -0
  578. /package/node_modules/{@babel/cli/node_modules/slash → slash}/package.json +0 -0
  579. /package/node_modules/{@babel/cli/node_modules/slash → slash}/readme.md +0 -0
  580. /package/node_modules/{lru-cache → superagent/node_modules/semver}/LICENSE +0 -0
  581. /package/node_modules/{semver → superagent/node_modules/semver}/classes/index.js +0 -0
  582. /package/node_modules/{semver → superagent/node_modules/semver}/functions/clean.js +0 -0
  583. /package/node_modules/{semver → superagent/node_modules/semver}/functions/cmp.js +0 -0
  584. /package/node_modules/{semver → superagent/node_modules/semver}/functions/compare-build.js +0 -0
  585. /package/node_modules/{semver → superagent/node_modules/semver}/functions/compare-loose.js +0 -0
  586. /package/node_modules/{semver → superagent/node_modules/semver}/functions/compare.js +0 -0
  587. /package/node_modules/{semver → superagent/node_modules/semver}/functions/eq.js +0 -0
  588. /package/node_modules/{semver → superagent/node_modules/semver}/functions/gt.js +0 -0
  589. /package/node_modules/{semver → superagent/node_modules/semver}/functions/gte.js +0 -0
  590. /package/node_modules/{semver → superagent/node_modules/semver}/functions/lt.js +0 -0
  591. /package/node_modules/{semver → superagent/node_modules/semver}/functions/lte.js +0 -0
  592. /package/node_modules/{semver → superagent/node_modules/semver}/functions/major.js +0 -0
  593. /package/node_modules/{semver → superagent/node_modules/semver}/functions/minor.js +0 -0
  594. /package/node_modules/{semver → superagent/node_modules/semver}/functions/neq.js +0 -0
  595. /package/node_modules/{semver → superagent/node_modules/semver}/functions/patch.js +0 -0
  596. /package/node_modules/{semver → superagent/node_modules/semver}/functions/prerelease.js +0 -0
  597. /package/node_modules/{semver → superagent/node_modules/semver}/functions/rcompare.js +0 -0
  598. /package/node_modules/{semver → superagent/node_modules/semver}/functions/rsort.js +0 -0
  599. /package/node_modules/{semver → superagent/node_modules/semver}/functions/satisfies.js +0 -0
  600. /package/node_modules/{semver → superagent/node_modules/semver}/functions/sort.js +0 -0
  601. /package/node_modules/{semver → superagent/node_modules/semver}/functions/valid.js +0 -0
  602. /package/node_modules/{semver → superagent/node_modules/semver}/internal/debug.js +0 -0
  603. /package/node_modules/{semver → superagent/node_modules/semver}/internal/identifiers.js +0 -0
  604. /package/node_modules/{semver → superagent/node_modules/semver}/preload.js +0 -0
  605. /package/node_modules/{semver → superagent/node_modules/semver}/range.bnf +0 -0
  606. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/gtr.js +0 -0
  607. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/ltr.js +0 -0
  608. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/max-satisfying.js +0 -0
  609. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/min-satisfying.js +0 -0
  610. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/min-version.js +0 -0
  611. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/outside.js +0 -0
  612. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/simplify.js +0 -0
  613. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/to-comparators.js +0 -0
  614. /package/node_modules/{semver → superagent/node_modules/semver}/ranges/valid.js +0 -0
@@ -0,0 +1,17 @@
1
+ 'use strict';
2
+
3
+ var inspect = require('../');
4
+
5
+ var test = require('tape');
6
+ var globalThis = require('globalthis')();
7
+
8
+ test('global object', function (t) {
9
+ /* eslint-env browser */
10
+ var expected = typeof window === 'undefined' ? 'globalThis' : 'Window';
11
+ t.equal(
12
+ inspect([globalThis]),
13
+ '[ { [object ' + expected + '] } ]'
14
+ );
15
+
16
+ t.end();
17
+ });
@@ -13,5 +13,14 @@ test('quoteStyle option', function (t) {
13
13
  t['throws'](function () { inspect(null, { quoteStyle: NaN }); }, 'NaN is not a valid value');
14
14
  t['throws'](function () { inspect(null, { quoteStyle: function () {} }); }, 'a function is not a valid value');
15
15
 
16
+ t.equal(inspect('"', { quoteStyle: 'single' }), '\'"\'', 'double quote, quoteStyle: "single"');
17
+ t.equal(inspect('"', { quoteStyle: 'double' }), '"\\""', 'double quote, quoteStyle: "double"');
18
+
19
+ t.equal(inspect('\'', { quoteStyle: 'single' }), '\'\\\'\'', 'single quote, quoteStyle: "single"');
20
+ t.equal(inspect('\'', { quoteStyle: 'double' }), '"\'"', 'single quote, quoteStyle: "double"');
21
+
22
+ t.equal(inspect('`', { quoteStyle: 'single' }), '\'`\'', 'backtick, quoteStyle: "single"');
23
+ t.equal(inspect('`', { quoteStyle: 'double' }), '"`"', 'backtick, quoteStyle: "double"');
24
+
16
25
  t.end();
17
26
  });
@@ -41,3 +41,6 @@ max_line_length = off
41
41
 
42
42
  [.nycrc]
43
43
  indent_style = tab
44
+
45
+ [tea.yaml]
46
+ indent_size = 2
@@ -13,9 +13,10 @@
13
13
  "func-name-matching": 0,
14
14
  "id-length": [2, { "min": 1, "max": 25, "properties": "never" }],
15
15
  "indent": [2, 4],
16
+ "max-lines": 0,
16
17
  "max-lines-per-function": [2, { "max": 150 }],
17
- "max-params": [2, 16],
18
- "max-statements": [2, 53],
18
+ "max-params": [2, 18],
19
+ "max-statements": [2, 100],
19
20
  "multiline-comment-style": 0,
20
21
  "no-continue": 1,
21
22
  "no-magic-numbers": 0,
@@ -1,4 +1,80 @@
1
- ## **6.11.0
1
+ ## **6.14.0**
2
+ - [New] `parse`: add `throwOnParameterLimitExceeded` option (#517)
3
+ - [Refactor] `parse`: use `utils.combine` more
4
+ - [patch] `parse`: add explicit `throwOnLimitExceeded` default
5
+ - [actions] use shared action; re-add finishers
6
+ - [meta] Fix changelog formatting bug
7
+ - [Deps] update `side-channel`
8
+ - [Dev Deps] update `es-value-fixtures`, `has-bigints`, `has-proto`, `has-symbols`
9
+ - [Tests] increase coverage
10
+
11
+ ## **6.13.1**
12
+ - [Fix] `stringify`: avoid a crash when a `filter` key is `null`
13
+ - [Fix] `utils.merge`: functions should not be stringified into keys
14
+ - [Fix] `parse`: avoid a crash with interpretNumericEntities: true, comma: true, and iso charset
15
+ - [Fix] `stringify`: ensure a non-string `filter` does not crash
16
+ - [Refactor] use `__proto__` syntax instead of `Object.create` for null objects
17
+ - [Refactor] misc cleanup
18
+ - [Tests] `utils.merge`: add some coverage
19
+ - [Tests] fix a test case
20
+ - [actions] split out node 10-20, and 20+
21
+ - [Dev Deps] update `es-value-fixtures`, `mock-property`, `object-inspect`, `tape`
22
+
23
+ ## **6.13.0**
24
+ - [New] `parse`: add `strictDepth` option (#511)
25
+ - [Tests] use `npm audit` instead of `aud`
26
+
27
+ ## **6.12.3**
28
+ - [Fix] `parse`: properly account for `strictNullHandling` when `allowEmptyArrays`
29
+ - [meta] fix changelog indentation
30
+
31
+ ## **6.12.2**
32
+ - [Fix] `parse`: parse encoded square brackets (#506)
33
+ - [readme] add CII best practices badge
34
+
35
+ ## **6.12.1**
36
+ - [Fix] `parse`: Disable `decodeDotInKeys` by default to restore previous behavior (#501)
37
+ - [Performance] `utils`: Optimize performance under large data volumes, reduce memory usage, and speed up processing (#502)
38
+ - [Refactor] `utils`: use `+=`
39
+ - [Tests] increase coverage
40
+
41
+ ## **6.12.0**
42
+
43
+ - [New] `parse`/`stringify`: add `decodeDotInKeys`/`encodeDotKeys` options (#488)
44
+ - [New] `parse`: add `duplicates` option
45
+ - [New] `parse`/`stringify`: add `allowEmptyArrays` option to allow [] in object values (#487)
46
+ - [Refactor] `parse`/`stringify`: move allowDots config logic to its own variable
47
+ - [Refactor] `stringify`: move option-handling code into `normalizeStringifyOptions`
48
+ - [readme] update readme, add logos (#484)
49
+ - [readme] `stringify`: clarify default `arrayFormat` behavior
50
+ - [readme] fix line wrapping
51
+ - [readme] remove dead badges
52
+ - [Deps] update `side-channel`
53
+ - [meta] make the dist build 50% smaller
54
+ - [meta] add `sideEffects` flag
55
+ - [meta] run build in prepack, not prepublish
56
+ - [Tests] `parse`: remove useless tests; add coverage
57
+ - [Tests] `stringify`: increase coverage
58
+ - [Tests] use `mock-property`
59
+ - [Tests] `stringify`: improve coverage
60
+ - [Dev Deps] update `@ljharb/eslint-config `, `aud`, `has-override-mistake`, `has-property-descriptors`, `mock-property`, `npmignore`, `object-inspect`, `tape`
61
+ - [Dev Deps] pin `glob`, since v10.3.8+ requires a broken `jackspeak`
62
+ - [Dev Deps] pin `jackspeak` since 2.1.2+ depends on npm aliases, which kill the install process in npm < 6
63
+
64
+ ## **6.11.2**
65
+ - [Fix] `parse`: Fix parsing when the global Object prototype is frozen (#473)
66
+ - [Tests] add passing test cases with empty keys (#473)
67
+
68
+ ## **6.11.1**
69
+ - [Fix] `stringify`: encode comma values more consistently (#463)
70
+ - [readme] add usage of `filter` option for injecting custom serialization, i.e. of custom types (#447)
71
+ - [meta] remove extraneous code backticks (#457)
72
+ - [meta] fix changelog markdown
73
+ - [actions] update checkout action
74
+ - [actions] restrict action permissions
75
+ - [Dev Deps] update `@ljharb/eslint-config`, `aud`, `object-inspect`, `tape`
76
+
77
+ ## **6.11.0**
2
78
  - [New] [Fix] `stringify`: revert 0e903c0; add `commaRoundTrip` option (#442)
3
79
  - [readme] fix version badge
4
80
 
@@ -238,7 +314,7 @@
238
314
 
239
315
  ## **6.5.3**
240
316
  - [Fix] `parse`: ignore `__proto__` keys (#428)
241
- - [Fix]` `utils.merge`: avoid a crash with a null target and a truthy non-array source
317
+ - [Fix] `utils.merge`: avoid a crash with a null target and a truthy non-array source
242
318
  - [Fix] correctly parse nested arrays
243
319
  - [Fix] `stringify`: fix a crash with `strictNullHandling` and a custom `filter`/`serializeDate` (#279)
244
320
  - [Fix] `utils`: `merge`: fix crash when `source` is a truthy primitive & no options are provided
@@ -291,7 +367,7 @@
291
367
  - [Fix] fix for an impossible situation: when the formatter is called with a non-string value
292
368
  - [Fix] use `safer-buffer` instead of `Buffer` constructor
293
369
  - [Fix] `utils.merge`: avoid a crash with a null target and an array source
294
- - [Fix]` `utils.merge`: avoid a crash with a null target and a truthy non-array source
370
+ - [Fix] `utils.merge`: avoid a crash with a null target and a truthy non-array source
295
371
  - [Fix] `stringify`: fix a crash with `strictNullHandling` and a custom `filter`/`serializeDate` (#279)
296
372
  - [Fix] `utils`: `merge`: fix crash when `source` is a truthy primitive & no options are provided
297
373
  - [Fix] when `parseArrays` is false, properly handle keys ending in `[]`
@@ -320,7 +396,7 @@
320
396
  - [Fix] `parse`: ignore `__proto__` keys (#428)
321
397
  - [Fix] fix for an impossible situation: when the formatter is called with a non-string value
322
398
  - [Fix] `utils.merge`: avoid a crash with a null target and an array source
323
- - [Fix]` `utils.merge`: avoid a crash with a null target and a truthy non-array source
399
+ - [Fix] `utils.merge`: avoid a crash with a null target and a truthy non-array source
324
400
  - [Fix] `stringify`: fix a crash with `strictNullHandling` and a custom `filter`/`serializeDate` (#279)
325
401
  - [Fix] `utils`: `merge`: fix crash when `source` is a truthy primitive & no options are provided
326
402
  - [Fix] when `parseArrays` is false, properly handle keys ending in `[]`
@@ -407,7 +483,7 @@
407
483
  - [New] add "encoder" and "decoder" options, for custom param encoding/decoding (#160)
408
484
  - [Fix] fix compacting of nested sparse arrays (#150)
409
485
 
410
- ## **6.1.2
486
+ ## **6.1.2**
411
487
  - [Fix] follow `allowPrototypes` option during merge (#201, #200)
412
488
  - [Fix] chmod a-x
413
489
  - [Fix] support keys starting with brackets (#202, #200)
@@ -1,11 +1,14 @@
1
+ <p align="center">
2
+ <img alt="qs" src="./logos/banner_default.png" width="800" />
3
+ </p>
4
+
1
5
  # qs <sup>[![Version Badge][npm-version-svg]][package-url]</sup>
2
6
 
3
7
  [![github actions][actions-image]][actions-url]
4
8
  [![coverage][codecov-image]][codecov-url]
5
- [![dependency status][deps-svg]][deps-url]
6
- [![dev dependency status][dev-deps-svg]][dev-deps-url]
7
9
  [![License][license-image]][license-url]
8
10
  [![Downloads][downloads-image]][downloads-url]
11
+ [![CII Best Practices](https://bestpractices.coreinfrastructure.org/projects/9058/badge)](https://bestpractices.coreinfrastructure.org/projects/9058)
9
12
 
10
13
  [![npm badge][npm-badge-png]][package-url]
11
14
 
@@ -46,14 +49,16 @@ assert.deepEqual(qs.parse('foo[bar]=baz'), {
46
49
  });
47
50
  ```
48
51
 
49
- When using the `plainObjects` option the parsed value is returned as a null object, created via `Object.create(null)` and as such you should be aware that prototype methods will not exist on it and a user may set those names to whatever value they like:
52
+ When using the `plainObjects` option the parsed value is returned as a null object, created via `{ __proto__: null }` and as such you should be aware that prototype methods will not exist on it and a user may set those names to whatever value they like:
50
53
 
51
54
  ```javascript
52
55
  var nullObject = qs.parse('a[hasOwnProperty]=b', { plainObjects: true });
53
56
  assert.deepEqual(nullObject, { a: { hasOwnProperty: 'b' } });
54
57
  ```
55
58
 
56
- By default parameters that would overwrite properties on the object prototype are ignored, if you wish to keep the data from those fields either use `plainObjects` as mentioned above, or set `allowPrototypes` to `true` which will allow user input to overwrite those properties. *WARNING* It is generally a bad idea to enable this option as it can cause problems when attempting to use the properties that have been overwritten. Always be careful with this option.
59
+ By default parameters that would overwrite properties on the object prototype are ignored, if you wish to keep the data from those fields either use `plainObjects` as mentioned above, or set `allowPrototypes` to `true` which will allow user input to overwrite those properties.
60
+ *WARNING* It is generally a bad idea to enable this option as it can cause problems when attempting to use the properties that have been overwritten.
61
+ Always be careful with this option.
57
62
 
58
63
  ```javascript
59
64
  var protoObject = qs.parse('a[hasOwnProperty]=b', { allowPrototypes: true });
@@ -80,8 +85,8 @@ assert.deepEqual(qs.parse('foo[bar][baz]=foobarbaz'), {
80
85
  });
81
86
  ```
82
87
 
83
- By default, when nesting objects **qs** will only parse up to 5 children deep. This means if you attempt to parse a string like
84
- `'a[b][c][d][e][f][g][h][i]=j'` your resulting object will be:
88
+ By default, when nesting objects **qs** will only parse up to 5 children deep.
89
+ This means if you attempt to parse a string like `'a[b][c][d][e][f][g][h][i]=j'` your resulting object will be:
85
90
 
86
91
  ```javascript
87
92
  var expected = {
@@ -110,7 +115,18 @@ var deep = qs.parse('a[b][c][d][e][f][g][h][i]=j', { depth: 1 });
110
115
  assert.deepEqual(deep, { a: { b: { '[c][d][e][f][g][h][i]': 'j' } } });
111
116
  ```
112
117
 
113
- The depth limit helps mitigate abuse when **qs** is used to parse user input, and it is recommended to keep it a reasonably small number.
118
+ You can configure **qs** to throw an error when parsing nested input beyond this depth using the `strictDepth` option (defaulted to false):
119
+
120
+ ```javascript
121
+ try {
122
+ qs.parse('a[b][c][d][e][f][g][h][i]=j', { depth: 1, strictDepth: true });
123
+ } catch (err) {
124
+ assert(err instanceof RangeError);
125
+ assert.strictEqual(err.message, 'Input depth exceeded depth option of 1 and strictDepth is true');
126
+ }
127
+ ```
128
+
129
+ The depth limit helps mitigate abuse when **qs** is used to parse user input, and it is recommended to keep it a reasonably small number. The strictDepth option adds a layer of protection by throwing an error when the limit is exceeded, allowing you to catch and handle such cases.
114
130
 
115
131
  For similar reasons, by default **qs** will only parse up to 1000 parameters. This can be overridden by passing a `parameterLimit` option:
116
132
 
@@ -119,6 +135,18 @@ var limited = qs.parse('a=b&c=d', { parameterLimit: 1 });
119
135
  assert.deepEqual(limited, { a: 'b' });
120
136
  ```
121
137
 
138
+ If you want an error to be thrown whenever the a limit is exceeded (eg, `parameterLimit`, `arrayLimit`), set the `throwOnLimitExceeded` option to `true`. This option will generate a descriptive error if the query string exceeds a configured limit.
139
+ ```javascript
140
+ try {
141
+ qs.parse('a=1&b=2&c=3&d=4', { parameterLimit: 3, throwOnLimitExceeded: true });
142
+ } catch (err) {
143
+ assert(err instanceof Error);
144
+ assert.strictEqual(err.message, 'Parameter limit exceeded. Only 3 parameters allowed.');
145
+ }
146
+ ```
147
+
148
+ When `throwOnLimitExceeded` is set to `false` (default), **qs** will parse up to the specified `parameterLimit` and ignore the rest without throwing an error.
149
+
122
150
  To bypass the leading question mark, use `ignoreQueryPrefix`:
123
151
 
124
152
  ```javascript
@@ -147,32 +175,44 @@ var withDots = qs.parse('a.b=c', { allowDots: true });
147
175
  assert.deepEqual(withDots, { a: { b: 'c' } });
148
176
  ```
149
177
 
150
- If you have to deal with legacy browsers or services, there's
151
- also support for decoding percent-encoded octets as iso-8859-1:
178
+ Option `decodeDotInKeys` can be used to decode dots in keys
179
+ Note: it implies `allowDots`, so `parse` will error if you set `decodeDotInKeys` to `true`, and `allowDots` to `false`.
180
+
181
+ ```javascript
182
+ var withDots = qs.parse('name%252Eobj.first=John&name%252Eobj.last=Doe', { decodeDotInKeys: true });
183
+ assert.deepEqual(withDots, { 'name.obj': { first: 'John', last: 'Doe' }});
184
+ ```
185
+
186
+ Option `allowEmptyArrays` can be used to allowing empty array values in object
187
+ ```javascript
188
+ var withEmptyArrays = qs.parse('foo[]&bar=baz', { allowEmptyArrays: true });
189
+ assert.deepEqual(withEmptyArrays, { foo: [], bar: 'baz' });
190
+ ```
191
+
192
+ Option `duplicates` can be used to change the behavior when duplicate keys are encountered
193
+ ```javascript
194
+ assert.deepEqual(qs.parse('foo=bar&foo=baz'), { foo: ['bar', 'baz'] });
195
+ assert.deepEqual(qs.parse('foo=bar&foo=baz', { duplicates: 'combine' }), { foo: ['bar', 'baz'] });
196
+ assert.deepEqual(qs.parse('foo=bar&foo=baz', { duplicates: 'first' }), { foo: 'bar' });
197
+ assert.deepEqual(qs.parse('foo=bar&foo=baz', { duplicates: 'last' }), { foo: 'baz' });
198
+ ```
199
+
200
+ If you have to deal with legacy browsers or services, there's also support for decoding percent-encoded octets as iso-8859-1:
152
201
 
153
202
  ```javascript
154
203
  var oldCharset = qs.parse('a=%A7', { charset: 'iso-8859-1' });
155
204
  assert.deepEqual(oldCharset, { a: '§' });
156
205
  ```
157
206
 
158
- Some services add an initial `utf8=✓` value to forms so that old
159
- Internet Explorer versions are more likely to submit the form as
160
- utf-8. Additionally, the server can check the value against wrong
161
- encodings of the checkmark character and detect that a query string
162
- or `application/x-www-form-urlencoded` body was *not* sent as
163
- utf-8, eg. if the form had an `accept-charset` parameter or the
164
- containing page had a different character set.
207
+ Some services add an initial `utf8=✓` value to forms so that old Internet Explorer versions are more likely to submit the form as utf-8.
208
+ Additionally, the server can check the value against wrong encodings of the checkmark character and detect that a query string or `application/x-www-form-urlencoded` body was *not* sent as utf-8, eg. if the form had an `accept-charset` parameter or the containing page had a different character set.
165
209
 
166
210
  **qs** supports this mechanism via the `charsetSentinel` option.
167
- If specified, the `utf8` parameter will be omitted from the
168
- returned object. It will be used to switch to `iso-8859-1`/`utf-8`
169
- mode depending on how the checkmark is encoded.
211
+ If specified, the `utf8` parameter will be omitted from the returned object.
212
+ It will be used to switch to `iso-8859-1`/`utf-8` mode depending on how the checkmark is encoded.
170
213
 
171
- **Important**: When you specify both the `charset` option and the
172
- `charsetSentinel` option, the `charset` will be overridden when
173
- the request contains a `utf8` parameter from which the actual
174
- charset can be deduced. In that sense the `charset` will behave
175
- as the default charset rather than the authoritative charset.
214
+ **Important**: When you specify both the `charset` option and the `charsetSentinel` option, the `charset` will be overridden when the request contains a `utf8` parameter from which the actual charset can be deduced.
215
+ In that sense the `charset` will behave as the default charset rather than the authoritative charset.
176
216
 
177
217
  ```javascript
178
218
  var detectedAsUtf8 = qs.parse('utf8=%E2%9C%93&a=%C3%B8', {
@@ -189,8 +229,7 @@ var detectedAsIso8859_1 = qs.parse('utf8=%26%2310003%3B&a=%F8', {
189
229
  assert.deepEqual(detectedAsIso8859_1, { a: 'ø' });
190
230
  ```
191
231
 
192
- If you want to decode the `&#...;` syntax to the actual character,
193
- you can specify the `interpretNumericEntities` option as well:
232
+ If you want to decode the `&#...;` syntax to the actual character, you can specify the `interpretNumericEntities` option as well:
194
233
 
195
234
  ```javascript
196
235
  var detectedAsIso8859_1 = qs.parse('a=%26%239786%3B', {
@@ -200,8 +239,7 @@ var detectedAsIso8859_1 = qs.parse('a=%26%239786%3B', {
200
239
  assert.deepEqual(detectedAsIso8859_1, { a: '☺' });
201
240
  ```
202
241
 
203
- It also works when the charset has been detected in `charsetSentinel`
204
- mode.
242
+ It also works when the charset has been detected in `charsetSentinel` mode.
205
243
 
206
244
  ### Parsing Arrays
207
245
 
@@ -219,9 +257,8 @@ var withIndexes = qs.parse('a[1]=c&a[0]=b');
219
257
  assert.deepEqual(withIndexes, { a: ['b', 'c'] });
220
258
  ```
221
259
 
222
- Note that the only difference between an index in an array and a key in an object is that the value between the brackets must be a number
223
- to create an array. When creating arrays with specific indices, **qs** will compact a sparse array to only the existing values preserving
224
- their order:
260
+ Note that the only difference between an index in an array and a key in an object is that the value between the brackets must be a number to create an array.
261
+ When creating arrays with specific indices, **qs** will compact a sparse array to only the existing values preserving their order:
225
262
 
226
263
  ```javascript
227
264
  var noSparse = qs.parse('a[1]=b&a[15]=c');
@@ -245,8 +282,9 @@ var withIndexedEmptyString = qs.parse('a[0]=b&a[1]=&a[2]=c');
245
282
  assert.deepEqual(withIndexedEmptyString, { a: ['b', '', 'c'] });
246
283
  ```
247
284
 
248
- **qs** will also limit specifying indices in an array to a maximum index of `20`. Any array members with an index of greater than `20` will
249
- instead be converted to an object with the index as the key. This is needed to handle cases when someone sent, for example, `a[999999999]` and it will take significant time to iterate over this huge array.
285
+ **qs** will also limit specifying indices in an array to a maximum index of `20`.
286
+ Any array members with an index of greater than `20` will instead be converted to an object with the index as the key.
287
+ This is needed to handle cases when someone sent, for example, `a[999999999]` and it will take significant time to iterate over this huge array.
250
288
 
251
289
  ```javascript
252
290
  var withMaxIndex = qs.parse('a[100]=b');
@@ -260,6 +298,18 @@ var withArrayLimit = qs.parse('a[1]=b', { arrayLimit: 0 });
260
298
  assert.deepEqual(withArrayLimit, { a: { '1': 'b' } });
261
299
  ```
262
300
 
301
+ If you want to throw an error whenever the array limit is exceeded, set the `throwOnLimitExceeded` option to `true`. This option will generate a descriptive error if the query string exceeds a configured limit.
302
+ ```javascript
303
+ try {
304
+ qs.parse('a[1]=b', { arrayLimit: 0, throwOnLimitExceeded: true });
305
+ } catch (err) {
306
+ assert(err instanceof Error);
307
+ assert.strictEqual(err.message, 'Array limit exceeded. Only 0 elements allowed in an array.');
308
+ }
309
+ ```
310
+
311
+ When `throwOnLimitExceeded` is set to `false` (default), **qs** will parse up to the specified `arrayLimit` and if the limit is exceeded, the array will instead be converted to an object with the index as the key
312
+
263
313
  To disable array parsing entirely, set `parseArrays` to `false`.
264
314
 
265
315
  ```javascript
@@ -290,7 +340,8 @@ assert.deepEqual(arraysOfObjects, { a: ['b', 'c'] })
290
340
 
291
341
  ### Parsing primitive/scalar values (numbers, booleans, null, etc)
292
342
 
293
- By default, all values are parsed as strings. This behavior will not change and is explained in [issue #91](https://github.com/ljharb/qs/issues/91).
343
+ By default, all values are parsed as strings.
344
+ This behavior will not change and is explained in [issue #91](https://github.com/ljharb/qs/issues/91).
294
345
 
295
346
  ```javascript
296
347
  var primitiveValues = qs.parse('a=15&b=true&c=null');
@@ -373,16 +424,17 @@ var decoded = qs.parse('x=z', { decoder: function (str, defaultDecoder, charset,
373
424
  }})
374
425
  ```
375
426
 
376
- Examples beyond this point will be shown as though the output is not URI encoded for clarity. Please note that the return values in these cases *will* be URI encoded during real usage.
427
+ Examples beyond this point will be shown as though the output is not URI encoded for clarity.
428
+ Please note that the return values in these cases *will* be URI encoded during real usage.
377
429
 
378
- When arrays are stringified, by default they are given explicit indices:
430
+ When arrays are stringified, they follow the `arrayFormat` option, which defaults to `indices`:
379
431
 
380
432
  ```javascript
381
433
  qs.stringify({ a: ['b', 'c', 'd'] });
382
434
  // 'a[0]=b&a[1]=c&a[2]=d'
383
435
  ```
384
436
 
385
- You may override this by setting the `indices` option to `false`:
437
+ You may override this by setting the `indices` option to `false`, or to be more explicit, the `arrayFormat` option to `repeat`:
386
438
 
387
439
  ```javascript
388
440
  qs.stringify({ a: ['b', 'c', 'd'] }, { indices: false });
@@ -418,6 +470,20 @@ qs.stringify({ a: { b: { c: 'd', e: 'f' } } }, { allowDots: true });
418
470
  // 'a.b.c=d&a.b.e=f'
419
471
  ```
420
472
 
473
+ You may encode the dot notation in the keys of object with option `encodeDotInKeys` by setting it to `true`:
474
+ Note: it implies `allowDots`, so `stringify` will error if you set `decodeDotInKeys` to `true`, and `allowDots` to `false`.
475
+ Caveat: when `encodeValuesOnly` is `true` as well as `encodeDotInKeys`, only dots in keys and nothing else will be encoded.
476
+ ```javascript
477
+ qs.stringify({ "name.obj": { "first": "John", "last": "Doe" } }, { allowDots: true, encodeDotInKeys: true })
478
+ // 'name%252Eobj.first=John&name%252Eobj.last=Doe'
479
+ ```
480
+
481
+ You may allow empty array values by setting the `allowEmptyArrays` option to `true`:
482
+ ```javascript
483
+ qs.stringify({ foo: [], bar: 'baz' }, { allowEmptyArrays: true });
484
+ // 'foo[]&bar=baz'
485
+ ```
486
+
421
487
  Empty strings and null values will omit the value, but the equals sign (=) remains in place:
422
488
 
423
489
  ```javascript
@@ -473,8 +539,8 @@ assert.equal(qs.stringify({ a: 'c', z: 'y', b : 'f' }, { sort: alphabeticalSort
473
539
  ```
474
540
 
475
541
  Finally, you can use the `filter` option to restrict which keys will be included in the stringified output.
476
- If you pass a function, it will be called for each key to obtain the replacement value. Otherwise, if you
477
- pass an array, it will be used to select properties and array indices for stringification:
542
+ If you pass a function, it will be called for each key to obtain the replacement value.
543
+ Otherwise, if you pass an array, it will be used to select properties and array indices for stringification:
478
544
 
479
545
  ```javascript
480
546
  function filterFunc(prefix, value) {
@@ -498,6 +564,44 @@ qs.stringify({ a: ['b', 'c', 'd'], e: 'f' }, { filter: ['a', 0, 2] });
498
564
  // 'a[0]=b&a[2]=d'
499
565
  ```
500
566
 
567
+ You could also use `filter` to inject custom serialization for user defined types.
568
+ Consider you're working with some api that expects query strings of the format for ranges:
569
+
570
+ ```
571
+ https://domain.com/endpoint?range=30...70
572
+ ```
573
+
574
+ For which you model as:
575
+
576
+ ```javascript
577
+ class Range {
578
+ constructor(from, to) {
579
+ this.from = from;
580
+ this.to = to;
581
+ }
582
+ }
583
+ ```
584
+
585
+ You could _inject_ a custom serializer to handle values of this type:
586
+
587
+ ```javascript
588
+ qs.stringify(
589
+ {
590
+ range: new Range(30, 70),
591
+ },
592
+ {
593
+ filter: (prefix, value) => {
594
+ if (value instanceof Range) {
595
+ return `${value.from}...${value.to}`;
596
+ }
597
+ // serialize the usual way
598
+ return value;
599
+ },
600
+ }
601
+ );
602
+ // range=30...70
603
+ ```
604
+
501
605
  ### Handling of `null` values
502
606
 
503
607
  By default, `null` values are treated like empty strings:
@@ -507,7 +611,8 @@ var withNull = qs.stringify({ a: null, b: '' });
507
611
  assert.equal(withNull, 'a=&b=');
508
612
  ```
509
613
 
510
- Parsing does not distinguish between parameters with and without equal signs. Both are converted to empty strings.
614
+ Parsing does not distinguish between parameters with and without equal signs.
615
+ Both are converted to empty strings.
511
616
 
512
617
  ```javascript
513
618
  var equalsInsensitive = qs.parse('a&b=');
@@ -536,25 +641,21 @@ var nullsSkipped = qs.stringify({ a: 'b', c: null}, { skipNulls: true });
536
641
  assert.equal(nullsSkipped, 'a=b');
537
642
  ```
538
643
 
539
- If you're communicating with legacy systems, you can switch to `iso-8859-1`
540
- using the `charset` option:
644
+ If you're communicating with legacy systems, you can switch to `iso-8859-1` using the `charset` option:
541
645
 
542
646
  ```javascript
543
647
  var iso = qs.stringify({ æ: 'æ' }, { charset: 'iso-8859-1' });
544
648
  assert.equal(iso, '%E6=%E6');
545
649
  ```
546
650
 
547
- Characters that don't exist in `iso-8859-1` will be converted to numeric
548
- entities, similar to what browsers do:
651
+ Characters that don't exist in `iso-8859-1` will be converted to numeric entities, similar to what browsers do:
549
652
 
550
653
  ```javascript
551
654
  var numeric = qs.stringify({ a: '☺' }, { charset: 'iso-8859-1' });
552
655
  assert.equal(numeric, 'a=%26%239786%3B');
553
656
  ```
554
657
 
555
- You can use the `charsetSentinel` option to announce the character by
556
- including an `utf8=✓` parameter with the proper encoding if the checkmark,
557
- similar to what Ruby on Rails and others do when submitting forms.
658
+ You can use the `charsetSentinel` option to announce the character by including an `utf8=✓` parameter with the proper encoding if the checkmark, similar to what Ruby on Rails and others do when submitting forms.
558
659
 
559
660
  ```javascript
560
661
  var sentinel = qs.stringify({ a: '☺' }, { charsetSentinel: true });
@@ -566,8 +667,7 @@ assert.equal(isoSentinel, 'utf8=%26%2310003%3B&a=%E6');
566
667
 
567
668
  ### Dealing with special character sets
568
669
 
569
- By default the encoding and decoding of characters is done in `utf-8`,
570
- and `iso-8859-1` support is also built in via the `charset` parameter.
670
+ By default the encoding and decoding of characters is done in `utf-8`, and `iso-8859-1` support is also built in via the `charset` parameter.
571
671
 
572
672
  If you wish to encode querystrings to a different character set (i.e.
573
673
  [Shift JIS](https://en.wikipedia.org/wiki/Shift_JIS)) you can use the
@@ -606,7 +706,9 @@ Please email [@ljharb](https://github.com/ljharb) or see https://tidelift.com/se
606
706
 
607
707
  Available as part of the Tidelift Subscription
608
708
 
609
- The maintainers of qs and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use. [Learn more.](https://tidelift.com/subscription/pkg/npm-qs?utm_source=npm-qs&utm_medium=referral&utm_campaign=enterprise&utm_term=repo)
709
+ The maintainers of qs and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications.
710
+ Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use.
711
+ [Learn more.](https://tidelift.com/subscription/pkg/npm-qs?utm_source=npm-qs&utm_medium=referral&utm_campaign=enterprise&utm_term=repo)
610
712
 
611
713
  [package-url]: https://npmjs.org/package/qs
612
714
  [npm-version-svg]: https://versionbadg.es/ljharb/qs.svg
@@ -623,3 +725,9 @@ The maintainers of qs and thousands of other packages are working with Tidelift
623
725
  [codecov-url]: https://app.codecov.io/gh/ljharb/qs/
624
726
  [actions-image]: https://img.shields.io/endpoint?url=https://github-actions-badge-u3jn4tfpocch.runkit.sh/ljharb/qs
625
727
  [actions-url]: https://github.com/ljharb/qs/actions
728
+
729
+ ## Acknowledgements
730
+
731
+ qs logo by [NUMI](https://github.com/numi-hq/open-design):
732
+
733
+ [<img src="https://raw.githubusercontent.com/numi-hq/open-design/main/assets/numi-lockup.png" alt="NUMI Logo" style="width: 200px;"/>](https://numi.tech/?ref=qs)