summaryrefslogtreecommitdiff
path: root/node_modules/needle/lib/querystring.js
diff options
context:
space:
mode:
author8cy <[email protected]>2020-04-03 02:37:42 -0700
committer8cy <[email protected]>2020-04-03 02:37:42 -0700
commit60867fb030bae582082340ead7dbc7efdc2f5398 (patch)
tree4c6a7356351be2e4914e15c4703172597c45656e /node_modules/needle/lib/querystring.js
parentcommenting (diff)
downloads5nical-60867fb030bae582082340ead7dbc7efdc2f5398.tar.xz
s5nical-60867fb030bae582082340ead7dbc7efdc2f5398.zip
2020/04/03, 02:34, v1.2.0
Diffstat (limited to 'node_modules/needle/lib/querystring.js')
-rw-r--r--node_modules/needle/lib/querystring.js49
1 files changed, 49 insertions, 0 deletions
diff --git a/node_modules/needle/lib/querystring.js b/node_modules/needle/lib/querystring.js
new file mode 100644
index 0000000..e58cc42
--- /dev/null
+++ b/node_modules/needle/lib/querystring.js
@@ -0,0 +1,49 @@
+// based on the qs module, but handles null objects as expected
+// fixes by Tomas Pollak.
+
+var toString = Object.prototype.toString;
+
+function stringify(obj, prefix) {
+ if (prefix && (obj === null || typeof obj == 'undefined')) {
+ return prefix + '=';
+ } else if (toString.call(obj) == '[object Array]') {
+ return stringifyArray(obj, prefix);
+ } else if (toString.call(obj) == '[object Object]') {
+ return stringifyObject(obj, prefix);
+ } else if (toString.call(obj) == '[object Date]') {
+ return obj.toISOString();
+ } else if (prefix) { // string inside array or hash
+ return prefix + '=' + encodeURIComponent(String(obj));
+ } else if (String(obj).indexOf('=') !== -1) { // string with equal sign
+ return String(obj);
+ } else {
+ throw new TypeError('Cannot build a querystring out of: ' + obj);
+ }
+};
+
+function stringifyArray(arr, prefix) {
+ var ret = [];
+
+ for (var i = 0, len = arr.length; i < len; i++) {
+ if (prefix)
+ ret.push(stringify(arr[i], prefix + '[]'));
+ else
+ ret.push(stringify(arr[i]));
+ }
+
+ return ret.join('&');
+}
+
+function stringifyObject(obj, prefix) {
+ var ret = [];
+
+ Object.keys(obj).forEach(function(key) {
+ ret.push(stringify(obj[key], prefix
+ ? prefix + '[' + encodeURIComponent(key) + ']'
+ : encodeURIComponent(key)));
+ })
+
+ return ret.join('&');
+}
+
+exports.build = stringify;