summaryrefslogtreecommitdiff
path: root/alarm/node_modules/@polka
diff options
context:
space:
mode:
Diffstat (limited to 'alarm/node_modules/@polka')
-rw-r--r--alarm/node_modules/@polka/url/index.js22
-rw-r--r--alarm/node_modules/@polka/url/package.json18
-rw-r--r--alarm/node_modules/@polka/url/readme.md86
3 files changed, 126 insertions, 0 deletions
diff --git a/alarm/node_modules/@polka/url/index.js b/alarm/node_modules/@polka/url/index.js
new file mode 100644
index 0000000..aa84fda
--- /dev/null
+++ b/alarm/node_modules/@polka/url/index.js
@@ -0,0 +1,22 @@
+module.exports = function (req) {
+ let url = req.url;
+ if (url === void 0) return url;
+
+ let obj = req._parsedUrl;
+ if (obj && obj._raw === url) return obj;
+
+ obj = {};
+ obj.query = obj.search = null;
+ obj.href = obj.path = obj.pathname = url;
+
+ let idx = url.indexOf('?', 1);
+ if (idx !== -1) {
+ obj.search = url.substring(idx);
+ obj.query = obj.search.substring(1);
+ obj.pathname = url.substring(0, idx);
+ }
+
+ obj._raw = url;
+
+ return (req._parsedUrl = obj);
+}
diff --git a/alarm/node_modules/@polka/url/package.json b/alarm/node_modules/@polka/url/package.json
new file mode 100644
index 0000000..3673b47
--- /dev/null
+++ b/alarm/node_modules/@polka/url/package.json
@@ -0,0 +1,18 @@
+{
+ "name": "@polka/url",
+ "version": "0.5.0",
+ "description": "Super fast, memoized `req.url` parser",
+ "repository": "lukeed/polka",
+ "license": "MIT",
+ "files": [
+ "*.js"
+ ],
+ "author": {
+ "name": "Luke Edwards",
+ "email": "luke@lukeed.com",
+ "url": "https://lukeed.com"
+ },
+ "publishConfig": {
+ "access": "public"
+ }
+}
diff --git a/alarm/node_modules/@polka/url/readme.md b/alarm/node_modules/@polka/url/readme.md
new file mode 100644
index 0000000..dda8379
--- /dev/null
+++ b/alarm/node_modules/@polka/url/readme.md
@@ -0,0 +1,86 @@
+# @polka/url [![npm](https://badgen.now.sh/npm/v/@polka/url)](https://npmjs.org/package/@polka/url)
+
+> Super fast, memoized `req.url` parser; _not_ limited to [Polka][polka]!
+
+Parses the `url` from a [`IncomingMessage`](https://nodejs.org/api/http.html#http_class_http_incomingmessage) request. The returned object will always only contain the following keys: `search`, `query`, `pathname`, `path`, `href`, and `_raw`.
+
+> **Note:** This library does not process `protocol`, `hostname`, `port`, etc.<br>This is because the incoming `req.url` value only begins with the path information.
+
+Parsed requests will be mutated with a `_parsedUrl` key, containing the returned output. This is used for future memoization, so as to avoid parsing the same `url` value multiple times.
+
+## Install
+
+```
+$ npm install --save @polka/url
+```
+
+## Usage
+
+```js
+const parse = require('@polka/url');
+
+let req = { url: '/foo/bar?fizz=buzz' };
+let foo = parse(req);
+//=> { search: '?fizz=buzz',
+//=> query: 'fizz=buzz',
+//=> pathname: '/foo/bar',
+//=> path: '/foo/bar?fizz=buzz',
+//=> href: '/foo/bar?fizz=buzz',
+//=> _raw: '/foo/bar?fizz=buzz' }
+
+// Attaches result for future memoization
+assert.deepEqual(foo, req._parsedUrl); //=> true
+```
+
+## API
+
+### url(req)
+Returns: `Object` or `undefined`
+
+> **Important:** The `req` must have a `url` key, otherwise `undefined` will be returned.<br>If no input is provided at all, a `TypeError` will be thrown.
+
+#### req
+Type: `IncomingMessage` or `Object`
+
+The incoming HTTP request (`req`) or a plain `Object` with a `url` key.
+
+> **Note:** In Node.js servers, the [`req.url`](https://nodejs.org/api/http.html#http_message_url) begins with a pathname & does not include a `hash`.
+
+
+## Benchmarks
+
+> Running the `parseurl` benchmark suite on Node 10.9.0
+
+```
+Parsing: "/foo/bar?user=tj&pet=fluffy"
+ nativeurl x 3,496,593 ops/sec ±0.78% (194 runs sampled)
+ parseurl x 5,702,515 ops/sec ±0.59% (194 runs sampled)
+ @polka/url x 11,510,281 ops/sec ±1.93% (192 runs sampled)
+
+REPEAT: "/foo/bar?user=tj&pet=fluffy"
+ nativeurl x 3,344,884 ops/sec ±0.13% (191 runs sampled)
+ parseurl x 20,386,848 ops/sec ±0.22% (192 runs sampled)
+ @polka/url x 21,088,923 ops/sec ±0.58% (191 runs sampled)
+
+Parsing: "/foo/bar"
+ nativeurl x 9,808,119 ops/sec ±0.51% (190 runs sampled)
+ parseurl x 26,186,627 ops/sec ±0.16% (195 runs sampled)
+ @polka/url x 43,946,765 ops/sec ±0.55% (194 runs sampled)
+
+Parsing: "/"
+ nativeurl x 15,698,746 ops/sec ±0.79% (192 runs sampled)
+ parseurl x 36,861,339 ops/sec ±0.19% (195 runs sampled)
+ @polka/url x 48,295,119 ops/sec ±0.51% (194 runs sampled)
+```
+
+
+## Support
+
+Any issues or questions can be sent to the [Polka][polka] repository.<br>However, please specify that your inquiry is about `@polka/url` specifically.
+
+
+## License
+
+MIT © [Luke Edwards](https://lukeed.com)
+
+[polka]: https://github.com/lukeed/polka