├── .gitignore ├── .travis.yml ├── README.md ├── example.js ├── index.js ├── package-lock.json ├── package.json └── test.js /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | data 3 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - "stable" 4 | services: mongodb 5 | # text search is experimental in mongodb 2.4 -> use mongodb 3.2 6 | # https://www.mongodb.com/blog/post/mongodb-text-search-experimental-feature-in 7 | addons: 8 | apt: 9 | sources: 10 | - mongodb-upstart 11 | - mongodb-3.2-precise 12 | packages: 13 | - mongodb-org-server 14 | - mongodb-org-shell 15 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | [![npm version](https://badge.fury.io/js/feathers-mongodb-fuzzy-search.svg)](https://badge.fury.io/js/feathers-mongodb-fuzzy-search) [![Build Status](https://travis-ci.org/arve0/feathers-mongodb-fuzzy-search.svg?branch=master)](https://travis-ci.org/arve0/feathers-mongodb-fuzzy-search) 2 | 3 | # feathers-mongodb-fuzzy-search 4 | Add `$search` to mongodb `service.find`, `update`, `patch` and `remove` queries. Full-text search on documents with [stemming](https://en.wikipedia.org/wiki/Stemming) as well as pattern matching on individual fields. 5 | 6 | For full-text search, be sure to index your text fields, as this plugin uses [mongodb $text](https://docs.mongodb.com/manual/reference/operator/query/text/). 7 | 8 | For field pattern matching, [mongodb $regex](https://docs.mongodb.com/manual/reference/operator/query/regex/) is used. 9 | 10 | ## Install 11 | ``` 12 | npm install feathers-mongodb-fuzzy-search 13 | ``` 14 | 15 | ## Usage 16 | ```js 17 | const service = require('feathers-mongodb') 18 | const search = require('feathers-mongodb-fuzzy-search') 19 | 20 | app.use('/messages', service({ 21 | Model: db.collection('messages'), 22 | whitelist: ['$text', '$search'], // fields used by feathers-mongodb-fuzzy-search 23 | })) 24 | 25 | // add search hook 26 | // may also use service.hooks to apply it on individual services only 27 | app.hooks({ 28 | before: { 29 | all: [ 30 | search(), // full text search on text indexes 31 | search({ // regex search on given fields 32 | fields: ['firstName', 'lastName'] 33 | }) 34 | ] 35 | } 36 | }) 37 | 38 | // create a text index on title property, for full-text search 39 | // you may add multiple fields to the text index 40 | // see the mongodb documentation for more on $text 41 | const messages = app.service('messages') 42 | 43 | // If you're using MongoDB database adapter: 44 | messages.Model.createIndex({ title: 'text' }) 45 | // or if you're using Mongoose database adapter: 46 | // messages.Model.index({ title: 'text' }) 47 | 48 | // find documents with title containing 'cat' 49 | // will find titles including 'cat', 'cats', etc. thanks to mongodb stemming 50 | // note: you can only use await inside async functions 51 | let catDocuments = await messages.find({ query: { $search: 'cat' } }) 52 | 53 | // find users with first name containing a 's' and last name containing 'art' 54 | let userDocuments = await app.service('users').find({ 55 | query: { 56 | firstName: { $search: 's' }, 57 | lastName: { $search: 'art' } 58 | } 59 | }) 60 | ``` 61 | 62 | Complete example [here](./example.js). 63 | 64 | ## REST usage 65 | Full text search for `qwerty` with mongodb $text: 66 | ```sh 67 | curl http://localhost:3030/messages?$search=qwerty 68 | ``` 69 | 70 | Search for `qwerty` on field `firstName` with mongodb $regex: 71 | ```sh 72 | curl http://localhost:3030/users?firstName[$search]=qwerty 73 | ``` 74 | 75 | ## Notes 76 | 77 | ### Full-text search 78 | As default `"` in `$search` is removed and `$search` is padded with `"`. E.g. `some " text` becomes `"some text"`. If you want to disable this behaviour and leverage the full MongoDB $text API, you can disable escaping like this: 79 | 80 | ```js 81 | app.hooks({ 82 | before: { 83 | find: search({ escape: false }) 84 | } 85 | }) 86 | ``` 87 | 88 | ### RegExp field search 89 | Remember to allow `$regex` in the service: 90 | 91 | ```js 92 | app.use('/messages', service({ 93 | Model: db.collection('messages'), 94 | whitelist: ['$regex'], // field used by feathers-mongodb-fuzzy-search 95 | })) 96 | ``` 97 | 98 | If not, you will get the error `BadRequest: Invalid query parameter $regex` on requests. 99 | 100 | 101 | The `options` object given to `search(options)` supports the following: 102 | 103 | - `fields`: Array of field names to allow searching in. 104 | - `excludedFields`: Array of field names that *can't* be searched. If given, any field not in array can be searched. 105 | - `fieldsNotEscaped`: Array of fields to be excluded from RegExp escape. As default any field not given are escaped to avoid [RegExp denial of service attacks](https://www.owasp.org/index.php/Regular_expression_Denial_of_Service_-_ReDoS). 106 | 107 | 108 | ```js 109 | app.service('users').hooks({ 110 | before: { 111 | find: search({ 112 | // make all fields but 'fullName' are searchable 113 | excludedFields: ['fullName'], 114 | // do not escape RegExp special characters for the field 'firstName' 115 | fieldsNotEscaped: ['firstName'] 116 | }) 117 | } 118 | }) 119 | ``` 120 | 121 | ### MongoDB options 122 | You can pass MongoDB options for `$text`, like `$language`, `$caseSensitive` and `$diacriticSensitive` with your query. E.g. If you'd like to disable [stemming](https://en.wikipedia.org/wiki/Stemming) add `$language: 'none'` to your query parameters: 123 | 124 | ```js 125 | users.find({ 126 | query: { 127 | $search: 'cats', 128 | $language: 'none' 129 | } 130 | }) 131 | ``` 132 | 133 | **NOTE:** Remeber to allow the fields in your service: 134 | ```js 135 | app.use('/messages', service({ 136 | Model: db.collection('messages'), 137 | // fields used by feathers-mongodb-fuzzy-search 138 | whitelist: ['$text', '$search', '$caseSensitive', '$language', '$diacriticSensitive'], 139 | })) 140 | ``` 141 | 142 | ### Additional information 143 | This package is tested with MongoDB version 3.2. You will probably run into problems using older versions of MongoDB, for example version 2.4 does not support `$text` search. 144 | 145 | See [mongodb documentation](https://docs.mongodb.com/manual/reference/operator/query/text/#search-field) for more details about `$text`. 146 | 147 | See [mongodb documentation](https://docs.mongodb.com/manual/reference/operator/query/regex) for more details about `$regex`. 148 | 149 | ## Development 150 | ``` 151 | npm test # runs mocha 152 | ``` 153 | 154 | ## License 155 | MIT © 2017 Arve Seljebu / Luc Claustres 156 | -------------------------------------------------------------------------------- /example.js: -------------------------------------------------------------------------------- 1 | const feathers = require('@feathersjs/feathers') 2 | const MongoClient = require('mongodb').MongoClient 3 | const service = require('feathers-mongodb') 4 | const search = require('feathers-mongodb-fuzzy-search') 5 | 6 | // use async function for await syntax 7 | async function testDatabase () { 8 | let client = await MongoClient.connect('mongodb://localhost:27017/') 9 | let db = client.db('feathers') 10 | 11 | let app = feathers() 12 | 13 | // setup messages service 14 | app.use('/messages', service({ 15 | Model: db.collection('messages'), 16 | whitelist: ['$text', '$search'], // fields used by feathers-mongodb-fuzzy-search 17 | })) 18 | let messages = app.service('messages') 19 | // enable text index on title property 20 | messages.Model.createIndex({ title: 'text' }) 21 | // add fuzzy search hook, may also use app.hooks for all services 22 | messages.hooks({ 23 | before: { 24 | find: search() 25 | } 26 | }) 27 | // add documents 28 | let documents = [ 29 | { title: 'lorem ipsum' }, 30 | { title: 'lorem asdf ipsum' }, 31 | { title: 'hello world' }, 32 | { title: 'qwerty qwerty qwerty qwerty world' }, 33 | { title: 'cats are awesome.-animales' } 34 | ] 35 | for (let document of documents) { 36 | await messages.create(document) 37 | } 38 | // find documents 39 | let docs = await messages.find({ query: { $search: 'world' } }) 40 | console.log(docs) 41 | // [ { _id: 595173771dab955e373ac721, title: 'qwerty qwerty qwerty qwerty world' }, 42 | // { _id: 595173771dab955e373ac720, title: 'hello world' } ] 43 | 44 | // remove all documents 45 | let allDocs = await messages.find() 46 | for (let doc of allDocs) { 47 | await messages.remove(doc._id) 48 | } 49 | 50 | client.close() // close connection to mongodb and exit 51 | } 52 | 53 | testDatabase() 54 | .catch(e => console.error(e)) 55 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | const utils = require('@feathersjs/commons') 2 | const errors = require('@feathersjs/errors') 3 | 4 | /** 5 | * Adds " around `str` and removes any " in `str`. 6 | * @param {string} str 7 | */ 8 | function escape (str) { 9 | return '"' + str.replace(/"/g, '') + '"' 10 | } 11 | 12 | /** 13 | * Escapes characters in the string that are not safe to use in a RegExp. 14 | * @param {*} s The string to escape. If not a string, 15 | * it will be casted to one. 16 | * @return {string} A RegExp safe, escaped copy of {@code s}. 17 | * from https://github.com/google/closure-library/blob/master/closure/goog/string/string.js#L1148 18 | */ 19 | function regExpEscape (s) { 20 | return String(s) 21 | .replace(/([-()\[\]{}+?*.$\^|,:# { 27 | if (key === '$text') { 28 | return 29 | } 30 | // Process current attribute or recurse 31 | if (value && typeof value === 'object') { 32 | // Searchable field ? 33 | if (!value.hasOwnProperty('$search')) { 34 | return transformSearchFieldsInQuery(value, options, key) 35 | } 36 | // Field should either be included, or not excluded 37 | if ((options.fields.length && !options.fields.includes(key)) || 38 | options.excludedFields.includes(key)) { 39 | throw new errors.BadRequest('You are not allowed to perform $search on field ' + key) 40 | } 41 | /** 42 | * { 43 | * field: { 44 | * $search: '' 45 | * } 46 | * } 47 | */ 48 | transformSearchFieldsInQuery(value, options, key) 49 | } else if (key === '$search') { 50 | // Default to case insensitive if not given 51 | // Sanitize when required 52 | if (!options.fieldsNotEscaped.includes(fieldName)) { 53 | value = regExpEscape(value) 54 | } 55 | // Update query 56 | query['$regex'] = query.$caseSensitive ? new RegExp(value) : new RegExp(value, 'i') 57 | // Delete unused field 58 | delete query['$search'] 59 | delete query['$caseSensitive'] 60 | } 61 | }) 62 | } 63 | 64 | module.exports = function (opts = {}) { 65 | // if escape is undefined -> escape = true 66 | opts.escape = opts.escape !== false 67 | opts.fieldsNotEscaped = Array.isArray(opts.fieldsNotEscaped) ? opts.fieldsNotEscaped : [] 68 | // hook for full-text search or field-based search ? 69 | if (Array.isArray(opts.fields) && opts.fields.length) { 70 | opts.excludedFields = [] // one should not both include and exclude fields 71 | return regexFieldSearch 72 | } else if (Array.isArray(opts.excludedFields) && opts.excludedFields.length) { 73 | opts.fields = [] 74 | return regexFieldSearch 75 | } 76 | 77 | return fullTextSearch 78 | 79 | function regexFieldSearch (hook) { 80 | transformSearchFieldsInQuery(hook.params.query, opts) 81 | } 82 | 83 | function fullTextSearch (hook) { 84 | if (hook.id || !hook.params.query || !hook.params.query.$search) { 85 | return 86 | } 87 | let query = hook.params.query 88 | query.$text = { 89 | $search: opts.escape ? escape(query.$search) : query.$search 90 | } 91 | delete query.$search 92 | if (query.$language) { 93 | query.$text.$language = query.$language 94 | delete query.$language 95 | } 96 | if (query.$caseSensitive) { 97 | query.$text.$caseSensitive = query.$caseSensitive 98 | delete query.$caseSensitive 99 | } 100 | if (query.$diacriticSensitive) { 101 | query.$text.$diacriticSensitive = query.$diacriticSensitive 102 | delete query.$diacriticSensitive 103 | } 104 | } 105 | } 106 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "feathers-mongodb-fuzzy-search", 3 | "version": "2.0.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@feathersjs/adapter-commons": { 8 | "version": "4.5.2", 9 | "resolved": "https://registry.npmjs.org/@feathersjs/adapter-commons/-/adapter-commons-4.5.2.tgz", 10 | "integrity": "sha512-7NF4WO/R0OOZo6/mPnMml4Hz+Ynr0JMCp4TDO6JIf3ITAwc78A7b6jrORw1sw3Cq3hkD0sC342sk7mRk3BwPDg==", 11 | "dev": true, 12 | "requires": { 13 | "@feathersjs/commons": "^4.5.2", 14 | "@feathersjs/errors": "^4.5.2", 15 | "@feathersjs/feathers": "^4.5.2" 16 | }, 17 | "dependencies": { 18 | "@feathersjs/commons": { 19 | "version": "4.5.8", 20 | "resolved": "https://registry.npmjs.org/@feathersjs/commons/-/commons-4.5.8.tgz", 21 | "integrity": "sha512-8HFQjJ5fkciLbvwWOsbtUvAIOFKMRIXLg+Ynm4HLjK2wHwpWtppkYxe3TfVbc254SYigmQ1c9kK0ERjrn6CqqQ==", 22 | "dev": true 23 | }, 24 | "@feathersjs/errors": { 25 | "version": "4.5.8", 26 | "resolved": "https://registry.npmjs.org/@feathersjs/errors/-/errors-4.5.8.tgz", 27 | "integrity": "sha512-PPpTHpCuWR0nbs4vvQEdXC5gLnWHmeDCF+hm9IJouzYkYIjt0UG/vKvPCBNqCREVHVfSrszdzI1MSeHRSUQddQ==", 28 | "dev": true, 29 | "requires": { 30 | "debug": "^4.1.1" 31 | } 32 | }, 33 | "@feathersjs/feathers": { 34 | "version": "4.5.8", 35 | "resolved": "https://registry.npmjs.org/@feathersjs/feathers/-/feathers-4.5.8.tgz", 36 | "integrity": "sha512-6d8oOPGZu4unda4XXNXV8nzaUI/OsUXY7s30HFDFvf7c81A2oe2uQ/u8OdGEiKpKcX5Ugq9lKYhiYCvMM3dibA==", 37 | "dev": true, 38 | "requires": { 39 | "@feathersjs/commons": "^4.5.8", 40 | "debug": "^4.1.1", 41 | "events": "^3.2.0", 42 | "uberproto": "^2.0.6" 43 | } 44 | } 45 | } 46 | }, 47 | "@feathersjs/commons": { 48 | "version": "4.3.7", 49 | "resolved": "https://registry.npmjs.org/@feathersjs/commons/-/commons-4.3.7.tgz", 50 | "integrity": "sha512-AX7fh88MUW3d5T+Zb0lVvwrWqioOhtsCwk9LJtQvexS3CTK6E/xzf6qKFfOv3IQ8x82/6OtMW+F2Yjc3clMFiw==" 51 | }, 52 | "@feathersjs/errors": { 53 | "version": "4.3.10", 54 | "resolved": "https://registry.npmjs.org/@feathersjs/errors/-/errors-4.3.10.tgz", 55 | "integrity": "sha512-OWPCfXcife8DRkdP4u1aC4ZZgaov5vfowEtacFX+/l91YsMlvIeI6mEmhK/tcVyF5TK/kuzkai5KJtZlp+R4KQ==", 56 | "requires": { 57 | "debug": "^4.1.1" 58 | }, 59 | "dependencies": { 60 | "debug": { 61 | "version": "4.1.1", 62 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 63 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 64 | "requires": { 65 | "ms": "^2.1.1" 66 | } 67 | }, 68 | "ms": { 69 | "version": "2.1.2", 70 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 71 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 72 | } 73 | } 74 | }, 75 | "@feathersjs/express": { 76 | "version": "4.3.10", 77 | "resolved": "https://registry.npmjs.org/@feathersjs/express/-/express-4.3.10.tgz", 78 | "integrity": "sha512-B1TcVjn6glFQNIWmuHusk5I1oo+DYls9wZ9OyI4nUlQSBucCFYKSuexyPInVdQdd57iY8cjBGqclI6W1YwqL0Q==", 79 | "dev": true, 80 | "requires": { 81 | "@feathersjs/commons": "^4.3.7", 82 | "@feathersjs/errors": "^4.3.10", 83 | "@types/express": "^4.17.1", 84 | "debug": "^4.1.1", 85 | "express": "^4.17.1", 86 | "lodash": "^4.17.15", 87 | "uberproto": "^2.0.4" 88 | }, 89 | "dependencies": { 90 | "@types/express": { 91 | "version": "4.17.2", 92 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.2.tgz", 93 | "integrity": "sha512-5mHFNyavtLoJmnusB8OKJ5bshSzw+qkMIBAobLrIM48HJvunFva9mOa6aBwh64lBFyNwBbs0xiEFuj4eU/NjCA==", 94 | "dev": true, 95 | "requires": { 96 | "@types/body-parser": "*", 97 | "@types/express-serve-static-core": "*", 98 | "@types/serve-static": "*" 99 | } 100 | }, 101 | "accepts": { 102 | "version": "1.3.7", 103 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 104 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 105 | "dev": true, 106 | "requires": { 107 | "mime-types": "~2.1.24", 108 | "negotiator": "0.6.2" 109 | } 110 | }, 111 | "content-disposition": { 112 | "version": "0.5.3", 113 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 114 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 115 | "dev": true, 116 | "requires": { 117 | "safe-buffer": "5.1.2" 118 | } 119 | }, 120 | "content-type": { 121 | "version": "1.0.4", 122 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 123 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 124 | "dev": true 125 | }, 126 | "cookie": { 127 | "version": "0.4.0", 128 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 129 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==", 130 | "dev": true 131 | }, 132 | "debug": { 133 | "version": "4.1.1", 134 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 135 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 136 | "dev": true, 137 | "requires": { 138 | "ms": "^2.1.1" 139 | } 140 | }, 141 | "depd": { 142 | "version": "1.1.2", 143 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 144 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 145 | "dev": true 146 | }, 147 | "encodeurl": { 148 | "version": "1.0.2", 149 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 150 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", 151 | "dev": true 152 | }, 153 | "etag": { 154 | "version": "1.8.1", 155 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 156 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", 157 | "dev": true 158 | }, 159 | "express": { 160 | "version": "4.17.1", 161 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 162 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 163 | "dev": true, 164 | "requires": { 165 | "accepts": "~1.3.7", 166 | "array-flatten": "1.1.1", 167 | "body-parser": "1.19.0", 168 | "content-disposition": "0.5.3", 169 | "content-type": "~1.0.4", 170 | "cookie": "0.4.0", 171 | "cookie-signature": "1.0.6", 172 | "debug": "2.6.9", 173 | "depd": "~1.1.2", 174 | "encodeurl": "~1.0.2", 175 | "escape-html": "~1.0.3", 176 | "etag": "~1.8.1", 177 | "finalhandler": "~1.1.2", 178 | "fresh": "0.5.2", 179 | "merge-descriptors": "1.0.1", 180 | "methods": "~1.1.2", 181 | "on-finished": "~2.3.0", 182 | "parseurl": "~1.3.3", 183 | "path-to-regexp": "0.1.7", 184 | "proxy-addr": "~2.0.5", 185 | "qs": "6.7.0", 186 | "range-parser": "~1.2.1", 187 | "safe-buffer": "5.1.2", 188 | "send": "0.17.1", 189 | "serve-static": "1.14.1", 190 | "setprototypeof": "1.1.1", 191 | "statuses": "~1.5.0", 192 | "type-is": "~1.6.18", 193 | "utils-merge": "1.0.1", 194 | "vary": "~1.1.2" 195 | }, 196 | "dependencies": { 197 | "debug": { 198 | "version": "2.6.9", 199 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 200 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 201 | "dev": true, 202 | "requires": { 203 | "ms": "2.0.0" 204 | } 205 | }, 206 | "ms": { 207 | "version": "2.0.0", 208 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 209 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 210 | "dev": true 211 | } 212 | } 213 | }, 214 | "finalhandler": { 215 | "version": "1.1.2", 216 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 217 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 218 | "dev": true, 219 | "requires": { 220 | "debug": "2.6.9", 221 | "encodeurl": "~1.0.2", 222 | "escape-html": "~1.0.3", 223 | "on-finished": "~2.3.0", 224 | "parseurl": "~1.3.3", 225 | "statuses": "~1.5.0", 226 | "unpipe": "~1.0.0" 227 | }, 228 | "dependencies": { 229 | "debug": { 230 | "version": "2.6.9", 231 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 232 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 233 | "dev": true, 234 | "requires": { 235 | "ms": "2.0.0" 236 | } 237 | }, 238 | "ms": { 239 | "version": "2.0.0", 240 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 241 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 242 | "dev": true 243 | } 244 | } 245 | }, 246 | "forwarded": { 247 | "version": "0.1.2", 248 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 249 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=", 250 | "dev": true 251 | }, 252 | "fresh": { 253 | "version": "0.5.2", 254 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 255 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", 256 | "dev": true 257 | }, 258 | "http-errors": { 259 | "version": "1.7.3", 260 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.3.tgz", 261 | "integrity": "sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw==", 262 | "dev": true, 263 | "requires": { 264 | "depd": "~1.1.2", 265 | "inherits": "2.0.4", 266 | "setprototypeof": "1.1.1", 267 | "statuses": ">= 1.5.0 < 2", 268 | "toidentifier": "1.0.0" 269 | } 270 | }, 271 | "inherits": { 272 | "version": "2.0.4", 273 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 274 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 275 | "dev": true 276 | }, 277 | "ipaddr.js": { 278 | "version": "1.9.0", 279 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.0.tgz", 280 | "integrity": "sha512-M4Sjn6N/+O6/IXSJseKqHoFc+5FdGJ22sXqnjTpdZweHK64MzEPAyQZyEU3R/KRv2GLoa7nNtg/C2Ev6m7z+eA==", 281 | "dev": true 282 | }, 283 | "mime": { 284 | "version": "1.6.0", 285 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 286 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 287 | "dev": true 288 | }, 289 | "mime-db": { 290 | "version": "1.40.0", 291 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", 292 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==", 293 | "dev": true 294 | }, 295 | "mime-types": { 296 | "version": "2.1.24", 297 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", 298 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", 299 | "dev": true, 300 | "requires": { 301 | "mime-db": "1.40.0" 302 | } 303 | }, 304 | "ms": { 305 | "version": "2.1.2", 306 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 307 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 308 | "dev": true 309 | }, 310 | "negotiator": { 311 | "version": "0.6.2", 312 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 313 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==", 314 | "dev": true 315 | }, 316 | "parseurl": { 317 | "version": "1.3.3", 318 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 319 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 320 | "dev": true 321 | }, 322 | "proxy-addr": { 323 | "version": "2.0.5", 324 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz", 325 | "integrity": "sha512-t/7RxHXPH6cJtP0pRG6smSr9QJidhB+3kXu0KgXnbGYMgzEnUxRQ4/LDdfOwZEMyIh3/xHb8PX3t+lfL9z+YVQ==", 326 | "dev": true, 327 | "requires": { 328 | "forwarded": "~0.1.2", 329 | "ipaddr.js": "1.9.0" 330 | } 331 | }, 332 | "qs": { 333 | "version": "6.7.0", 334 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 335 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==", 336 | "dev": true 337 | }, 338 | "range-parser": { 339 | "version": "1.2.1", 340 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 341 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 342 | "dev": true 343 | }, 344 | "safe-buffer": { 345 | "version": "5.1.2", 346 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 347 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 348 | "dev": true 349 | }, 350 | "send": { 351 | "version": "0.17.1", 352 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 353 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 354 | "dev": true, 355 | "requires": { 356 | "debug": "2.6.9", 357 | "depd": "~1.1.2", 358 | "destroy": "~1.0.4", 359 | "encodeurl": "~1.0.2", 360 | "escape-html": "~1.0.3", 361 | "etag": "~1.8.1", 362 | "fresh": "0.5.2", 363 | "http-errors": "~1.7.2", 364 | "mime": "1.6.0", 365 | "ms": "2.1.1", 366 | "on-finished": "~2.3.0", 367 | "range-parser": "~1.2.1", 368 | "statuses": "~1.5.0" 369 | }, 370 | "dependencies": { 371 | "debug": { 372 | "version": "2.6.9", 373 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 374 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 375 | "dev": true, 376 | "requires": { 377 | "ms": "2.0.0" 378 | }, 379 | "dependencies": { 380 | "ms": { 381 | "version": "2.0.0", 382 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 383 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 384 | "dev": true 385 | } 386 | } 387 | }, 388 | "ms": { 389 | "version": "2.1.1", 390 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 391 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 392 | "dev": true 393 | } 394 | } 395 | }, 396 | "serve-static": { 397 | "version": "1.14.1", 398 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 399 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 400 | "dev": true, 401 | "requires": { 402 | "encodeurl": "~1.0.2", 403 | "escape-html": "~1.0.3", 404 | "parseurl": "~1.3.3", 405 | "send": "0.17.1" 406 | } 407 | }, 408 | "setprototypeof": { 409 | "version": "1.1.1", 410 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 411 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==", 412 | "dev": true 413 | }, 414 | "statuses": { 415 | "version": "1.5.0", 416 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 417 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 418 | "dev": true 419 | }, 420 | "type-is": { 421 | "version": "1.6.18", 422 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 423 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 424 | "dev": true, 425 | "requires": { 426 | "media-typer": "0.3.0", 427 | "mime-types": "~2.1.24" 428 | } 429 | }, 430 | "uberproto": { 431 | "version": "2.0.4", 432 | "resolved": "https://registry.npmjs.org/uberproto/-/uberproto-2.0.4.tgz", 433 | "integrity": "sha512-c/5xjTcztW9XVhrkCycHQRBIAxww5JpDKk/q0zc2tVdQn6ZQvnChWgLvQaWAT1Al5JvRyvloUI15ad41m6dYwg==", 434 | "dev": true 435 | }, 436 | "utils-merge": { 437 | "version": "1.0.1", 438 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 439 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 440 | "dev": true 441 | }, 442 | "vary": { 443 | "version": "1.1.2", 444 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 445 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 446 | "dev": true 447 | } 448 | } 449 | }, 450 | "@feathersjs/feathers": { 451 | "version": "4.3.10", 452 | "resolved": "https://registry.npmjs.org/@feathersjs/feathers/-/feathers-4.3.10.tgz", 453 | "integrity": "sha512-KswXZsl0e9XDy/RS4NkSSqXoKWYuP5X5+38LOtGIYAKnPnGSa+tI99YDzJyZtGDOQ3t+77hYjGwBrqST62aALA==", 454 | "dev": true, 455 | "requires": { 456 | "@feathersjs/commons": "^4.3.7", 457 | "debug": "^4.1.1", 458 | "events": "^3.0.0", 459 | "uberproto": "^2.0.4" 460 | }, 461 | "dependencies": { 462 | "debug": { 463 | "version": "4.1.1", 464 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 465 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 466 | "dev": true, 467 | "requires": { 468 | "ms": "^2.1.1" 469 | } 470 | }, 471 | "events": { 472 | "version": "3.0.0", 473 | "resolved": "https://registry.npmjs.org/events/-/events-3.0.0.tgz", 474 | "integrity": "sha512-Dc381HFWJzEOhQ+d8pkNon++bk9h6cdAoAj4iE6Q4y6xgTzySWXlKn05/TVNpjnfRqi/X0EpJEJohPjNI3zpVA==", 475 | "dev": true 476 | }, 477 | "ms": { 478 | "version": "2.1.2", 479 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 480 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 481 | "dev": true 482 | }, 483 | "uberproto": { 484 | "version": "2.0.4", 485 | "resolved": "https://registry.npmjs.org/uberproto/-/uberproto-2.0.4.tgz", 486 | "integrity": "sha512-c/5xjTcztW9XVhrkCycHQRBIAxww5JpDKk/q0zc2tVdQn6ZQvnChWgLvQaWAT1Al5JvRyvloUI15ad41m6dYwg==", 487 | "dev": true 488 | } 489 | } 490 | }, 491 | "@types/body-parser": { 492 | "version": "1.17.1", 493 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.17.1.tgz", 494 | "integrity": "sha512-RoX2EZjMiFMjZh9lmYrwgoP9RTpAjSHiJxdp4oidAQVO02T7HER3xj9UKue5534ULWeqVEkujhWcyvUce+d68w==", 495 | "dev": true, 496 | "requires": { 497 | "@types/connect": "*", 498 | "@types/node": "*" 499 | } 500 | }, 501 | "@types/color-name": { 502 | "version": "1.1.1", 503 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 504 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 505 | "dev": true 506 | }, 507 | "@types/connect": { 508 | "version": "3.4.32", 509 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.32.tgz", 510 | "integrity": "sha512-4r8qa0quOvh7lGD0pre62CAb1oni1OO6ecJLGCezTmhQ8Fz50Arx9RUszryR8KlgK6avuSXvviL6yWyViQABOg==", 511 | "dev": true, 512 | "requires": { 513 | "@types/node": "*" 514 | } 515 | }, 516 | "@types/express-serve-static-core": { 517 | "version": "4.0.50", 518 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.0.50.tgz", 519 | "integrity": "sha512-0n1YgeUfZEIaMMu82LuOFIFDyMtFtcEP0yjQKihJlNjpCiygDVri7C26DC7jaUOwFXL6ZU2x4tGtNYNEgeO3tw==", 520 | "dev": true, 521 | "requires": { 522 | "@types/node": "*" 523 | } 524 | }, 525 | "@types/mime": { 526 | "version": "1.3.1", 527 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.1.tgz", 528 | "integrity": "sha512-rek8twk9C58gHYqIrUlJsx8NQMhlxqHzln9Z9ODqiNgv3/s+ZwIrfr+djqzsnVM12xe9hL98iJ20lj2RvCBv6A==", 529 | "dev": true 530 | }, 531 | "@types/node": { 532 | "version": "8.0.26", 533 | "resolved": "https://registry.npmjs.org/@types/node/-/node-8.0.26.tgz", 534 | "integrity": "sha512-wbKN0MB4XsjdnSE04HiCzLoBDirGCM6zXrqavSj44nZnPFYpnrTF64E9O6Xmf0ca/IuKK/BHUcXwMiwk92gW6Q==", 535 | "dev": true 536 | }, 537 | "@types/serve-static": { 538 | "version": "1.7.32", 539 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.7.32.tgz", 540 | "integrity": "sha512-WpI0g7M1FiOmJ/a97Qrjafq2I938tjAZ3hZr9O7sXyA6oUhH3bqUNZIt7r1KZg8TQAKxcvxt6JjQ5XuLfIBFvg==", 541 | "dev": true, 542 | "requires": { 543 | "@types/express-serve-static-core": "*", 544 | "@types/mime": "*" 545 | } 546 | }, 547 | "ansi-colors": { 548 | "version": "4.1.1", 549 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-4.1.1.tgz", 550 | "integrity": "sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA==", 551 | "dev": true 552 | }, 553 | "ansi-regex": { 554 | "version": "3.0.0", 555 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 556 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 557 | "dev": true 558 | }, 559 | "ansi-styles": { 560 | "version": "4.2.1", 561 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 562 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 563 | "dev": true, 564 | "requires": { 565 | "@types/color-name": "^1.1.1", 566 | "color-convert": "^2.0.1" 567 | } 568 | }, 569 | "anymatch": { 570 | "version": "3.1.1", 571 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", 572 | "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", 573 | "dev": true, 574 | "requires": { 575 | "normalize-path": "^3.0.0", 576 | "picomatch": "^2.0.4" 577 | } 578 | }, 579 | "argparse": { 580 | "version": "1.0.10", 581 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 582 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 583 | "dev": true, 584 | "requires": { 585 | "sprintf-js": "~1.0.2" 586 | } 587 | }, 588 | "array-flatten": { 589 | "version": "1.1.1", 590 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 591 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=", 592 | "dev": true 593 | }, 594 | "array.prototype.map": { 595 | "version": "1.0.2", 596 | "resolved": "https://registry.npmjs.org/array.prototype.map/-/array.prototype.map-1.0.2.tgz", 597 | "integrity": "sha512-Az3OYxgsa1g7xDYp86l0nnN4bcmuEITGe1rbdEBVkrqkzMgDcbdQ2R7r41pNzti+4NMces3H8gMmuioZUilLgw==", 598 | "dev": true, 599 | "requires": { 600 | "define-properties": "^1.1.3", 601 | "es-abstract": "^1.17.0-next.1", 602 | "es-array-method-boxes-properly": "^1.0.0", 603 | "is-string": "^1.0.4" 604 | } 605 | }, 606 | "asynckit": { 607 | "version": "0.4.0", 608 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 609 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 610 | "dev": true 611 | }, 612 | "balanced-match": { 613 | "version": "1.0.0", 614 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 615 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 616 | "dev": true 617 | }, 618 | "binary-extensions": { 619 | "version": "2.1.0", 620 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.1.0.tgz", 621 | "integrity": "sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ==", 622 | "dev": true 623 | }, 624 | "bl": { 625 | "version": "2.2.1", 626 | "resolved": "https://registry.npmjs.org/bl/-/bl-2.2.1.tgz", 627 | "integrity": "sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g==", 628 | "dev": true, 629 | "requires": { 630 | "readable-stream": "^2.3.5", 631 | "safe-buffer": "^5.1.1" 632 | }, 633 | "dependencies": { 634 | "process-nextick-args": { 635 | "version": "2.0.1", 636 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 637 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 638 | "dev": true 639 | }, 640 | "readable-stream": { 641 | "version": "2.3.7", 642 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 643 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 644 | "dev": true, 645 | "requires": { 646 | "core-util-is": "~1.0.0", 647 | "inherits": "~2.0.3", 648 | "isarray": "~1.0.0", 649 | "process-nextick-args": "~2.0.0", 650 | "safe-buffer": "~5.1.1", 651 | "string_decoder": "~1.1.1", 652 | "util-deprecate": "~1.0.1" 653 | } 654 | }, 655 | "string_decoder": { 656 | "version": "1.1.1", 657 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 658 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 659 | "dev": true, 660 | "requires": { 661 | "safe-buffer": "~5.1.0" 662 | } 663 | } 664 | } 665 | }, 666 | "body-parser": { 667 | "version": "1.19.0", 668 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 669 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 670 | "dev": true, 671 | "requires": { 672 | "bytes": "3.1.0", 673 | "content-type": "~1.0.4", 674 | "debug": "2.6.9", 675 | "depd": "~1.1.2", 676 | "http-errors": "1.7.2", 677 | "iconv-lite": "0.4.24", 678 | "on-finished": "~2.3.0", 679 | "qs": "6.7.0", 680 | "raw-body": "2.4.0", 681 | "type-is": "~1.6.17" 682 | }, 683 | "dependencies": { 684 | "content-type": { 685 | "version": "1.0.4", 686 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 687 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 688 | "dev": true 689 | }, 690 | "debug": { 691 | "version": "2.6.9", 692 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 693 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 694 | "dev": true, 695 | "requires": { 696 | "ms": "2.0.0" 697 | } 698 | }, 699 | "depd": { 700 | "version": "1.1.2", 701 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 702 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 703 | "dev": true 704 | }, 705 | "http-errors": { 706 | "version": "1.7.2", 707 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 708 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 709 | "dev": true, 710 | "requires": { 711 | "depd": "~1.1.2", 712 | "inherits": "2.0.3", 713 | "setprototypeof": "1.1.1", 714 | "statuses": ">= 1.5.0 < 2", 715 | "toidentifier": "1.0.0" 716 | } 717 | }, 718 | "mime-db": { 719 | "version": "1.40.0", 720 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", 721 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==", 722 | "dev": true 723 | }, 724 | "mime-types": { 725 | "version": "2.1.24", 726 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", 727 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", 728 | "dev": true, 729 | "requires": { 730 | "mime-db": "1.40.0" 731 | } 732 | }, 733 | "qs": { 734 | "version": "6.7.0", 735 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 736 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==", 737 | "dev": true 738 | }, 739 | "setprototypeof": { 740 | "version": "1.1.1", 741 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 742 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==", 743 | "dev": true 744 | }, 745 | "statuses": { 746 | "version": "1.5.0", 747 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 748 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 749 | "dev": true 750 | }, 751 | "type-is": { 752 | "version": "1.6.18", 753 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 754 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 755 | "dev": true, 756 | "requires": { 757 | "media-typer": "0.3.0", 758 | "mime-types": "~2.1.24" 759 | } 760 | } 761 | } 762 | }, 763 | "brace-expansion": { 764 | "version": "1.1.11", 765 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 766 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 767 | "dev": true, 768 | "requires": { 769 | "balanced-match": "^1.0.0", 770 | "concat-map": "0.0.1" 771 | } 772 | }, 773 | "braces": { 774 | "version": "3.0.2", 775 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 776 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 777 | "dev": true, 778 | "requires": { 779 | "fill-range": "^7.0.1" 780 | } 781 | }, 782 | "browser-stdout": { 783 | "version": "1.3.1", 784 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 785 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 786 | "dev": true 787 | }, 788 | "bson": { 789 | "version": "1.1.5", 790 | "resolved": "https://registry.npmjs.org/bson/-/bson-1.1.5.tgz", 791 | "integrity": "sha512-kDuEzldR21lHciPQAIulLs1LZlCXdLziXI6Mb/TDkwXhb//UORJNPXgcRs2CuO4H0DcMkpfT3/ySsP3unoZjBg==", 792 | "dev": true 793 | }, 794 | "buffer-shims": { 795 | "version": "1.0.0", 796 | "resolved": "https://registry.npmjs.org/buffer-shims/-/buffer-shims-1.0.0.tgz", 797 | "integrity": "sha1-mXjOMXOIxkmth5MCjDR37wRKi1E=", 798 | "dev": true 799 | }, 800 | "bytes": { 801 | "version": "3.1.0", 802 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 803 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", 804 | "dev": true 805 | }, 806 | "camelcase": { 807 | "version": "5.3.1", 808 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 809 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 810 | "dev": true 811 | }, 812 | "chalk": { 813 | "version": "4.1.0", 814 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 815 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 816 | "dev": true, 817 | "requires": { 818 | "ansi-styles": "^4.1.0", 819 | "supports-color": "^7.1.0" 820 | } 821 | }, 822 | "chokidar": { 823 | "version": "3.4.2", 824 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.4.2.tgz", 825 | "integrity": "sha512-IZHaDeBeI+sZJRX7lGcXsdzgvZqKv6sECqsbErJA4mHWfpRrD8B97kSFN4cQz6nGBGiuFia1MKR4d6c1o8Cv7A==", 826 | "dev": true, 827 | "requires": { 828 | "anymatch": "~3.1.1", 829 | "braces": "~3.0.2", 830 | "fsevents": "~2.1.2", 831 | "glob-parent": "~5.1.0", 832 | "is-binary-path": "~2.1.0", 833 | "is-glob": "~4.0.1", 834 | "normalize-path": "~3.0.0", 835 | "readdirp": "~3.4.0" 836 | } 837 | }, 838 | "cliui": { 839 | "version": "5.0.0", 840 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", 841 | "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", 842 | "dev": true, 843 | "requires": { 844 | "string-width": "^3.1.0", 845 | "strip-ansi": "^5.2.0", 846 | "wrap-ansi": "^5.1.0" 847 | }, 848 | "dependencies": { 849 | "ansi-regex": { 850 | "version": "4.1.0", 851 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 852 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 853 | "dev": true 854 | }, 855 | "string-width": { 856 | "version": "3.1.0", 857 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 858 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 859 | "dev": true, 860 | "requires": { 861 | "emoji-regex": "^7.0.1", 862 | "is-fullwidth-code-point": "^2.0.0", 863 | "strip-ansi": "^5.1.0" 864 | } 865 | }, 866 | "strip-ansi": { 867 | "version": "5.2.0", 868 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 869 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 870 | "dev": true, 871 | "requires": { 872 | "ansi-regex": "^4.1.0" 873 | } 874 | } 875 | } 876 | }, 877 | "color-convert": { 878 | "version": "2.0.1", 879 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 880 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 881 | "dev": true, 882 | "requires": { 883 | "color-name": "~1.1.4" 884 | } 885 | }, 886 | "color-name": { 887 | "version": "1.1.4", 888 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 889 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 890 | "dev": true 891 | }, 892 | "combined-stream": { 893 | "version": "1.0.5", 894 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", 895 | "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", 896 | "dev": true, 897 | "requires": { 898 | "delayed-stream": "~1.0.0" 899 | } 900 | }, 901 | "component-emitter": { 902 | "version": "1.2.1", 903 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", 904 | "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", 905 | "dev": true 906 | }, 907 | "concat-map": { 908 | "version": "0.0.1", 909 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 910 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 911 | "dev": true 912 | }, 913 | "cookie-signature": { 914 | "version": "1.0.6", 915 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 916 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=", 917 | "dev": true 918 | }, 919 | "cookiejar": { 920 | "version": "2.1.1", 921 | "resolved": "https://registry.npmjs.org/cookiejar/-/cookiejar-2.1.1.tgz", 922 | "integrity": "sha1-Qa1XsbVVlR7BcUEqgZQrHoIA00o=", 923 | "dev": true 924 | }, 925 | "core-util-is": { 926 | "version": "1.0.2", 927 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 928 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 929 | "dev": true 930 | }, 931 | "debug": { 932 | "version": "4.1.1", 933 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 934 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 935 | "dev": true, 936 | "requires": { 937 | "ms": "^2.1.1" 938 | }, 939 | "dependencies": { 940 | "ms": { 941 | "version": "2.1.2", 942 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 943 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 944 | "dev": true 945 | } 946 | } 947 | }, 948 | "decamelize": { 949 | "version": "1.2.0", 950 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 951 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 952 | "dev": true 953 | }, 954 | "define-properties": { 955 | "version": "1.1.3", 956 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 957 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 958 | "dev": true, 959 | "requires": { 960 | "object-keys": "^1.0.12" 961 | } 962 | }, 963 | "delayed-stream": { 964 | "version": "1.0.0", 965 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 966 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 967 | "dev": true 968 | }, 969 | "denque": { 970 | "version": "1.4.1", 971 | "resolved": "https://registry.npmjs.org/denque/-/denque-1.4.1.tgz", 972 | "integrity": "sha512-OfzPuSZKGcgr96rf1oODnfjqBFmr1DVoc/TrItj3Ohe0Ah1C5WX5Baquw/9U9KovnQ88EqmJbD66rKYUQYN1tQ==", 973 | "dev": true 974 | }, 975 | "destroy": { 976 | "version": "1.0.4", 977 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 978 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=", 979 | "dev": true 980 | }, 981 | "diff": { 982 | "version": "4.0.2", 983 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", 984 | "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", 985 | "dev": true 986 | }, 987 | "ee-first": { 988 | "version": "1.1.1", 989 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 990 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=", 991 | "dev": true 992 | }, 993 | "emoji-regex": { 994 | "version": "7.0.3", 995 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 996 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 997 | "dev": true 998 | }, 999 | "es-abstract": { 1000 | "version": "1.17.6", 1001 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.6.tgz", 1002 | "integrity": "sha512-Fr89bON3WFyUi5EvAeI48QTWX0AyekGgLA8H+c+7fbfCkJwRWRMLd8CQedNEyJuoYYhmtEqY92pgte1FAhBlhw==", 1003 | "dev": true, 1004 | "requires": { 1005 | "es-to-primitive": "^1.2.1", 1006 | "function-bind": "^1.1.1", 1007 | "has": "^1.0.3", 1008 | "has-symbols": "^1.0.1", 1009 | "is-callable": "^1.2.0", 1010 | "is-regex": "^1.1.0", 1011 | "object-inspect": "^1.7.0", 1012 | "object-keys": "^1.1.1", 1013 | "object.assign": "^4.1.0", 1014 | "string.prototype.trimend": "^1.0.1", 1015 | "string.prototype.trimstart": "^1.0.1" 1016 | } 1017 | }, 1018 | "es-array-method-boxes-properly": { 1019 | "version": "1.0.0", 1020 | "resolved": "https://registry.npmjs.org/es-array-method-boxes-properly/-/es-array-method-boxes-properly-1.0.0.tgz", 1021 | "integrity": "sha512-wd6JXUmyHmt8T5a2xreUwKcGPq6f1f+WwIJkijUqiGcJz1qqnZgP6XIK+QyIWU5lT7imeNxUll48bziG+TSYcA==", 1022 | "dev": true 1023 | }, 1024 | "es-get-iterator": { 1025 | "version": "1.1.0", 1026 | "resolved": "https://registry.npmjs.org/es-get-iterator/-/es-get-iterator-1.1.0.tgz", 1027 | "integrity": "sha512-UfrmHuWQlNMTs35e1ypnvikg6jCz3SK8v8ImvmDsh36fCVUR1MqoFDiyn0/k52C8NqO3YsO8Oe0azeesNuqSsQ==", 1028 | "dev": true, 1029 | "requires": { 1030 | "es-abstract": "^1.17.4", 1031 | "has-symbols": "^1.0.1", 1032 | "is-arguments": "^1.0.4", 1033 | "is-map": "^2.0.1", 1034 | "is-set": "^2.0.1", 1035 | "is-string": "^1.0.5", 1036 | "isarray": "^2.0.5" 1037 | }, 1038 | "dependencies": { 1039 | "isarray": { 1040 | "version": "2.0.5", 1041 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", 1042 | "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", 1043 | "dev": true 1044 | } 1045 | } 1046 | }, 1047 | "es-to-primitive": { 1048 | "version": "1.2.1", 1049 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 1050 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 1051 | "dev": true, 1052 | "requires": { 1053 | "is-callable": "^1.1.4", 1054 | "is-date-object": "^1.0.1", 1055 | "is-symbol": "^1.0.2" 1056 | } 1057 | }, 1058 | "escape-html": { 1059 | "version": "1.0.3", 1060 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 1061 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=", 1062 | "dev": true 1063 | }, 1064 | "escape-string-regexp": { 1065 | "version": "4.0.0", 1066 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 1067 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 1068 | "dev": true 1069 | }, 1070 | "esprima": { 1071 | "version": "4.0.1", 1072 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1073 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1074 | "dev": true 1075 | }, 1076 | "events": { 1077 | "version": "3.2.0", 1078 | "resolved": "https://registry.npmjs.org/events/-/events-3.2.0.tgz", 1079 | "integrity": "sha512-/46HWwbfCX2xTawVfkKLGxMifJYQBWMwY1mjywRtb4c9x8l5NP3KoJtnIOiL1hfdRkIuYhETxQlo62IF8tcnlg==", 1080 | "dev": true 1081 | }, 1082 | "extend": { 1083 | "version": "3.0.2", 1084 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 1085 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 1086 | "dev": true 1087 | }, 1088 | "feathers-mongodb": { 1089 | "version": "6.1.0", 1090 | "resolved": "https://registry.npmjs.org/feathers-mongodb/-/feathers-mongodb-6.1.0.tgz", 1091 | "integrity": "sha512-oeKLccn0y5GjWw5oa/Imb5Ym1kc71m7cYYMun4WuTpGYmQhtZbSFShY0DYPXxEr/JDOoDjZDDAzvsqkS6TzYtw==", 1092 | "dev": true, 1093 | "requires": { 1094 | "@feathersjs/adapter-commons": "^4.3.8", 1095 | "@feathersjs/commons": "^4.3.0", 1096 | "@feathersjs/errors": "^4.3.4" 1097 | } 1098 | }, 1099 | "fill-range": { 1100 | "version": "7.0.1", 1101 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1102 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1103 | "dev": true, 1104 | "requires": { 1105 | "to-regex-range": "^5.0.1" 1106 | } 1107 | }, 1108 | "find-up": { 1109 | "version": "5.0.0", 1110 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 1111 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 1112 | "dev": true, 1113 | "requires": { 1114 | "locate-path": "^6.0.0", 1115 | "path-exists": "^4.0.0" 1116 | } 1117 | }, 1118 | "flat": { 1119 | "version": "4.1.0", 1120 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 1121 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 1122 | "dev": true, 1123 | "requires": { 1124 | "is-buffer": "~2.0.3" 1125 | } 1126 | }, 1127 | "form-data": { 1128 | "version": "2.3.1", 1129 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.1.tgz", 1130 | "integrity": "sha1-b7lPvXGIUwbXPRXMSX/kzE7NRL8=", 1131 | "dev": true, 1132 | "requires": { 1133 | "asynckit": "^0.4.0", 1134 | "combined-stream": "^1.0.5", 1135 | "mime-types": "^2.1.12" 1136 | } 1137 | }, 1138 | "formidable": { 1139 | "version": "1.1.1", 1140 | "resolved": "https://registry.npmjs.org/formidable/-/formidable-1.1.1.tgz", 1141 | "integrity": "sha1-lriIb3w8NQi5Mta9cMTTqI818ak=", 1142 | "dev": true 1143 | }, 1144 | "fs.realpath": { 1145 | "version": "1.0.0", 1146 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1147 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1148 | "dev": true 1149 | }, 1150 | "fsevents": { 1151 | "version": "2.1.3", 1152 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", 1153 | "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", 1154 | "dev": true, 1155 | "optional": true 1156 | }, 1157 | "function-bind": { 1158 | "version": "1.1.1", 1159 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1160 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1161 | "dev": true 1162 | }, 1163 | "get-caller-file": { 1164 | "version": "2.0.5", 1165 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1166 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1167 | "dev": true 1168 | }, 1169 | "glob": { 1170 | "version": "7.1.6", 1171 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1172 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1173 | "dev": true, 1174 | "requires": { 1175 | "fs.realpath": "^1.0.0", 1176 | "inflight": "^1.0.4", 1177 | "inherits": "2", 1178 | "minimatch": "^3.0.4", 1179 | "once": "^1.3.0", 1180 | "path-is-absolute": "^1.0.0" 1181 | } 1182 | }, 1183 | "glob-parent": { 1184 | "version": "5.1.1", 1185 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.1.tgz", 1186 | "integrity": "sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ==", 1187 | "dev": true, 1188 | "requires": { 1189 | "is-glob": "^4.0.1" 1190 | } 1191 | }, 1192 | "growl": { 1193 | "version": "1.10.5", 1194 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 1195 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 1196 | "dev": true 1197 | }, 1198 | "has": { 1199 | "version": "1.0.3", 1200 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1201 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1202 | "dev": true, 1203 | "requires": { 1204 | "function-bind": "^1.1.1" 1205 | } 1206 | }, 1207 | "has-flag": { 1208 | "version": "4.0.0", 1209 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1210 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1211 | "dev": true 1212 | }, 1213 | "has-symbols": { 1214 | "version": "1.0.1", 1215 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 1216 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==", 1217 | "dev": true 1218 | }, 1219 | "he": { 1220 | "version": "1.2.0", 1221 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1222 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1223 | "dev": true 1224 | }, 1225 | "iconv-lite": { 1226 | "version": "0.4.24", 1227 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1228 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1229 | "dev": true, 1230 | "requires": { 1231 | "safer-buffer": ">= 2.1.2 < 3" 1232 | } 1233 | }, 1234 | "inflight": { 1235 | "version": "1.0.6", 1236 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1237 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1238 | "dev": true, 1239 | "requires": { 1240 | "once": "^1.3.0", 1241 | "wrappy": "1" 1242 | } 1243 | }, 1244 | "inherits": { 1245 | "version": "2.0.3", 1246 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1247 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 1248 | "dev": true 1249 | }, 1250 | "is-arguments": { 1251 | "version": "1.0.4", 1252 | "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.0.4.tgz", 1253 | "integrity": "sha512-xPh0Rmt8NE65sNzvyUmWgI1tz3mKq74lGA0mL8LYZcoIzKOzDh6HmrYm3d18k60nHerC8A9Km8kYu87zfSFnLA==", 1254 | "dev": true 1255 | }, 1256 | "is-binary-path": { 1257 | "version": "2.1.0", 1258 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", 1259 | "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", 1260 | "dev": true, 1261 | "requires": { 1262 | "binary-extensions": "^2.0.0" 1263 | } 1264 | }, 1265 | "is-buffer": { 1266 | "version": "2.0.4", 1267 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.4.tgz", 1268 | "integrity": "sha512-Kq1rokWXOPXWuaMAqZiJW4XxsmD9zGx9q4aePabbn3qCRGedtH7Cm+zV8WETitMfu1wdh+Rvd6w5egwSngUX2A==", 1269 | "dev": true 1270 | }, 1271 | "is-callable": { 1272 | "version": "1.2.1", 1273 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.1.tgz", 1274 | "integrity": "sha512-wliAfSzx6V+6WfMOmus1xy0XvSgf/dlStkvTfq7F0g4bOIW0PSUbnyse3NhDwdyYS1ozfUtAAySqTws3z9Eqgg==", 1275 | "dev": true 1276 | }, 1277 | "is-date-object": { 1278 | "version": "1.0.2", 1279 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 1280 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==", 1281 | "dev": true 1282 | }, 1283 | "is-extglob": { 1284 | "version": "2.1.1", 1285 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1286 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1287 | "dev": true 1288 | }, 1289 | "is-fullwidth-code-point": { 1290 | "version": "2.0.0", 1291 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1292 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1293 | "dev": true 1294 | }, 1295 | "is-glob": { 1296 | "version": "4.0.1", 1297 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1298 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1299 | "dev": true, 1300 | "requires": { 1301 | "is-extglob": "^2.1.1" 1302 | } 1303 | }, 1304 | "is-map": { 1305 | "version": "2.0.1", 1306 | "resolved": "https://registry.npmjs.org/is-map/-/is-map-2.0.1.tgz", 1307 | "integrity": "sha512-T/S49scO8plUiAOA2DBTBG3JHpn1yiw0kRp6dgiZ0v2/6twi5eiB0rHtHFH9ZIrvlWc6+4O+m4zg5+Z833aXgw==", 1308 | "dev": true 1309 | }, 1310 | "is-number": { 1311 | "version": "7.0.0", 1312 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1313 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1314 | "dev": true 1315 | }, 1316 | "is-plain-obj": { 1317 | "version": "1.1.0", 1318 | "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", 1319 | "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=", 1320 | "dev": true 1321 | }, 1322 | "is-regex": { 1323 | "version": "1.1.1", 1324 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.1.tgz", 1325 | "integrity": "sha512-1+QkEcxiLlB7VEyFtyBg94e08OAsvq7FUBgApTq/w2ymCLyKJgDPsybBENVtA7XCQEgEXxKPonG+mvYRxh/LIg==", 1326 | "dev": true, 1327 | "requires": { 1328 | "has-symbols": "^1.0.1" 1329 | } 1330 | }, 1331 | "is-set": { 1332 | "version": "2.0.1", 1333 | "resolved": "https://registry.npmjs.org/is-set/-/is-set-2.0.1.tgz", 1334 | "integrity": "sha512-eJEzOtVyenDs1TMzSQ3kU3K+E0GUS9sno+F0OBT97xsgcJsF9nXMBtkT9/kut5JEpM7oL7X/0qxR17K3mcwIAA==", 1335 | "dev": true 1336 | }, 1337 | "is-string": { 1338 | "version": "1.0.5", 1339 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz", 1340 | "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==", 1341 | "dev": true 1342 | }, 1343 | "is-symbol": { 1344 | "version": "1.0.3", 1345 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 1346 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 1347 | "dev": true, 1348 | "requires": { 1349 | "has-symbols": "^1.0.1" 1350 | } 1351 | }, 1352 | "isarray": { 1353 | "version": "1.0.0", 1354 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1355 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1356 | "dev": true 1357 | }, 1358 | "isexe": { 1359 | "version": "2.0.0", 1360 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1361 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1362 | "dev": true 1363 | }, 1364 | "iterate-iterator": { 1365 | "version": "1.0.1", 1366 | "resolved": "https://registry.npmjs.org/iterate-iterator/-/iterate-iterator-1.0.1.tgz", 1367 | "integrity": "sha512-3Q6tudGN05kbkDQDI4CqjaBf4qf85w6W6GnuZDtUVYwKgtC1q8yxYX7CZed7N+tLzQqS6roujWvszf13T+n9aw==", 1368 | "dev": true 1369 | }, 1370 | "iterate-value": { 1371 | "version": "1.0.2", 1372 | "resolved": "https://registry.npmjs.org/iterate-value/-/iterate-value-1.0.2.tgz", 1373 | "integrity": "sha512-A6fMAio4D2ot2r/TYzr4yUWrmwNdsN5xL7+HUiyACE4DXm+q8HtPcnFTp+NnW3k4N05tZ7FVYFFb2CR13NxyHQ==", 1374 | "dev": true, 1375 | "requires": { 1376 | "es-get-iterator": "^1.0.2", 1377 | "iterate-iterator": "^1.0.1" 1378 | } 1379 | }, 1380 | "js-yaml": { 1381 | "version": "3.14.0", 1382 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz", 1383 | "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==", 1384 | "dev": true, 1385 | "requires": { 1386 | "argparse": "^1.0.7", 1387 | "esprima": "^4.0.0" 1388 | } 1389 | }, 1390 | "locate-path": { 1391 | "version": "6.0.0", 1392 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 1393 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 1394 | "dev": true, 1395 | "requires": { 1396 | "p-locate": "^5.0.0" 1397 | } 1398 | }, 1399 | "lodash": { 1400 | "version": "4.17.20", 1401 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.20.tgz", 1402 | "integrity": "sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA==", 1403 | "dev": true 1404 | }, 1405 | "log-symbols": { 1406 | "version": "4.0.0", 1407 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.0.0.tgz", 1408 | "integrity": "sha512-FN8JBzLx6CzeMrB0tg6pqlGU1wCrXW+ZXGH481kfsBqer0hToTIiHdjH4Mq8xJUbvATujKCvaREGWpGUionraA==", 1409 | "dev": true, 1410 | "requires": { 1411 | "chalk": "^4.0.0" 1412 | } 1413 | }, 1414 | "media-typer": { 1415 | "version": "0.3.0", 1416 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1417 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", 1418 | "dev": true 1419 | }, 1420 | "memory-pager": { 1421 | "version": "1.5.0", 1422 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 1423 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==", 1424 | "dev": true, 1425 | "optional": true 1426 | }, 1427 | "merge-descriptors": { 1428 | "version": "1.0.1", 1429 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1430 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=", 1431 | "dev": true 1432 | }, 1433 | "methods": { 1434 | "version": "1.1.2", 1435 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1436 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 1437 | "dev": true 1438 | }, 1439 | "mime-db": { 1440 | "version": "1.29.0", 1441 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.29.0.tgz", 1442 | "integrity": "sha1-SNJtI1WJZRcErFkWygYAGRQmaHg=", 1443 | "dev": true 1444 | }, 1445 | "mime-types": { 1446 | "version": "2.1.16", 1447 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.16.tgz", 1448 | "integrity": "sha1-K4WKUuXs1RbbiXrCvodIeDBpjiM=", 1449 | "dev": true, 1450 | "requires": { 1451 | "mime-db": "~1.29.0" 1452 | } 1453 | }, 1454 | "minimatch": { 1455 | "version": "3.0.4", 1456 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1457 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1458 | "dev": true, 1459 | "requires": { 1460 | "brace-expansion": "^1.1.7" 1461 | } 1462 | }, 1463 | "mocha": { 1464 | "version": "8.1.3", 1465 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-8.1.3.tgz", 1466 | "integrity": "sha512-ZbaYib4hT4PpF4bdSO2DohooKXIn4lDeiYqB+vTmCdr6l2woW0b6H3pf5x4sM5nwQMru9RvjjHYWVGltR50ZBw==", 1467 | "dev": true, 1468 | "requires": { 1469 | "ansi-colors": "4.1.1", 1470 | "browser-stdout": "1.3.1", 1471 | "chokidar": "3.4.2", 1472 | "debug": "4.1.1", 1473 | "diff": "4.0.2", 1474 | "escape-string-regexp": "4.0.0", 1475 | "find-up": "5.0.0", 1476 | "glob": "7.1.6", 1477 | "growl": "1.10.5", 1478 | "he": "1.2.0", 1479 | "js-yaml": "3.14.0", 1480 | "log-symbols": "4.0.0", 1481 | "minimatch": "3.0.4", 1482 | "ms": "2.1.2", 1483 | "object.assign": "4.1.0", 1484 | "promise.allsettled": "1.0.2", 1485 | "serialize-javascript": "4.0.0", 1486 | "strip-json-comments": "3.0.1", 1487 | "supports-color": "7.1.0", 1488 | "which": "2.0.2", 1489 | "wide-align": "1.1.3", 1490 | "workerpool": "6.0.0", 1491 | "yargs": "13.3.2", 1492 | "yargs-parser": "13.1.2", 1493 | "yargs-unparser": "1.6.1" 1494 | }, 1495 | "dependencies": { 1496 | "debug": { 1497 | "version": "4.1.1", 1498 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 1499 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 1500 | "dev": true, 1501 | "requires": { 1502 | "ms": "^2.1.1" 1503 | } 1504 | }, 1505 | "ms": { 1506 | "version": "2.1.2", 1507 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1508 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1509 | "dev": true 1510 | } 1511 | } 1512 | }, 1513 | "mongodb": { 1514 | "version": "3.6.2", 1515 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-3.6.2.tgz", 1516 | "integrity": "sha512-sSZOb04w3HcnrrXC82NEh/YGCmBuRgR+C1hZgmmv4L6dBz4BkRse6Y8/q/neXer9i95fKUBbFi4KgeceXmbsOA==", 1517 | "dev": true, 1518 | "requires": { 1519 | "bl": "^2.2.1", 1520 | "bson": "^1.1.4", 1521 | "denque": "^1.4.1", 1522 | "require_optional": "^1.0.1", 1523 | "safe-buffer": "^5.1.2", 1524 | "saslprep": "^1.0.0" 1525 | }, 1526 | "dependencies": { 1527 | "safe-buffer": { 1528 | "version": "5.2.1", 1529 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 1530 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 1531 | "dev": true 1532 | } 1533 | } 1534 | }, 1535 | "ms": { 1536 | "version": "2.0.0", 1537 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1538 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1539 | "dev": true 1540 | }, 1541 | "normalize-path": { 1542 | "version": "3.0.0", 1543 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1544 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1545 | "dev": true 1546 | }, 1547 | "object-inspect": { 1548 | "version": "1.8.0", 1549 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz", 1550 | "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==", 1551 | "dev": true 1552 | }, 1553 | "object-keys": { 1554 | "version": "1.1.1", 1555 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1556 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1557 | "dev": true 1558 | }, 1559 | "object.assign": { 1560 | "version": "4.1.0", 1561 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1562 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1563 | "dev": true, 1564 | "requires": { 1565 | "define-properties": "^1.1.2", 1566 | "function-bind": "^1.1.1", 1567 | "has-symbols": "^1.0.0", 1568 | "object-keys": "^1.0.11" 1569 | } 1570 | }, 1571 | "on-finished": { 1572 | "version": "2.3.0", 1573 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1574 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1575 | "dev": true, 1576 | "requires": { 1577 | "ee-first": "1.1.1" 1578 | } 1579 | }, 1580 | "once": { 1581 | "version": "1.4.0", 1582 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1583 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1584 | "dev": true, 1585 | "requires": { 1586 | "wrappy": "1" 1587 | } 1588 | }, 1589 | "p-limit": { 1590 | "version": "3.0.2", 1591 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.0.2.tgz", 1592 | "integrity": "sha512-iwqZSOoWIW+Ew4kAGUlN16J4M7OB3ysMLSZtnhmqx7njIHFPlxWBX8xo3lVTyFVq6mI/lL9qt2IsN1sHwaxJkg==", 1593 | "dev": true, 1594 | "requires": { 1595 | "p-try": "^2.0.0" 1596 | } 1597 | }, 1598 | "p-locate": { 1599 | "version": "5.0.0", 1600 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 1601 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 1602 | "dev": true, 1603 | "requires": { 1604 | "p-limit": "^3.0.2" 1605 | } 1606 | }, 1607 | "p-try": { 1608 | "version": "2.2.0", 1609 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1610 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1611 | "dev": true 1612 | }, 1613 | "path-exists": { 1614 | "version": "4.0.0", 1615 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1616 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1617 | "dev": true 1618 | }, 1619 | "path-is-absolute": { 1620 | "version": "1.0.1", 1621 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1622 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1623 | "dev": true 1624 | }, 1625 | "path-to-regexp": { 1626 | "version": "0.1.7", 1627 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1628 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=", 1629 | "dev": true 1630 | }, 1631 | "picomatch": { 1632 | "version": "2.2.2", 1633 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", 1634 | "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", 1635 | "dev": true 1636 | }, 1637 | "process-nextick-args": { 1638 | "version": "1.0.7", 1639 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 1640 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=", 1641 | "dev": true 1642 | }, 1643 | "promise.allsettled": { 1644 | "version": "1.0.2", 1645 | "resolved": "https://registry.npmjs.org/promise.allsettled/-/promise.allsettled-1.0.2.tgz", 1646 | "integrity": "sha512-UpcYW5S1RaNKT6pd+s9jp9K9rlQge1UXKskec0j6Mmuq7UJCvlS2J2/s/yuPN8ehftf9HXMxWlKiPbGGUzpoRg==", 1647 | "dev": true, 1648 | "requires": { 1649 | "array.prototype.map": "^1.0.1", 1650 | "define-properties": "^1.1.3", 1651 | "es-abstract": "^1.17.0-next.1", 1652 | "function-bind": "^1.1.1", 1653 | "iterate-value": "^1.0.0" 1654 | } 1655 | }, 1656 | "randombytes": { 1657 | "version": "2.1.0", 1658 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 1659 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 1660 | "dev": true, 1661 | "requires": { 1662 | "safe-buffer": "^5.1.0" 1663 | } 1664 | }, 1665 | "raw-body": { 1666 | "version": "2.4.0", 1667 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 1668 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 1669 | "dev": true, 1670 | "requires": { 1671 | "bytes": "3.1.0", 1672 | "http-errors": "1.7.2", 1673 | "iconv-lite": "0.4.24", 1674 | "unpipe": "1.0.0" 1675 | }, 1676 | "dependencies": { 1677 | "depd": { 1678 | "version": "1.1.2", 1679 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 1680 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 1681 | "dev": true 1682 | }, 1683 | "http-errors": { 1684 | "version": "1.7.2", 1685 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 1686 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 1687 | "dev": true, 1688 | "requires": { 1689 | "depd": "~1.1.2", 1690 | "inherits": "2.0.3", 1691 | "setprototypeof": "1.1.1", 1692 | "statuses": ">= 1.5.0 < 2", 1693 | "toidentifier": "1.0.0" 1694 | } 1695 | }, 1696 | "setprototypeof": { 1697 | "version": "1.1.1", 1698 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1699 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==", 1700 | "dev": true 1701 | }, 1702 | "statuses": { 1703 | "version": "1.5.0", 1704 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1705 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 1706 | "dev": true 1707 | } 1708 | } 1709 | }, 1710 | "readable-stream": { 1711 | "version": "2.2.7", 1712 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.2.7.tgz", 1713 | "integrity": "sha1-BwV6y+JGeyIELTb5jFrVBwVOlbE=", 1714 | "dev": true, 1715 | "requires": { 1716 | "buffer-shims": "~1.0.0", 1717 | "core-util-is": "~1.0.0", 1718 | "inherits": "~2.0.1", 1719 | "isarray": "~1.0.0", 1720 | "process-nextick-args": "~1.0.6", 1721 | "string_decoder": "~1.0.0", 1722 | "util-deprecate": "~1.0.1" 1723 | } 1724 | }, 1725 | "readdirp": { 1726 | "version": "3.4.0", 1727 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.4.0.tgz", 1728 | "integrity": "sha512-0xe001vZBnJEK+uKcj8qOhyAKPzIT+gStxWr3LCB0DwcXR5NZJ3IaC+yGnHCYzB/S7ov3m3EEbZI2zeNvX+hGQ==", 1729 | "dev": true, 1730 | "requires": { 1731 | "picomatch": "^2.2.1" 1732 | } 1733 | }, 1734 | "require-directory": { 1735 | "version": "2.1.1", 1736 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1737 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1738 | "dev": true 1739 | }, 1740 | "require-main-filename": { 1741 | "version": "2.0.0", 1742 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 1743 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 1744 | "dev": true 1745 | }, 1746 | "require_optional": { 1747 | "version": "1.0.1", 1748 | "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz", 1749 | "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==", 1750 | "dev": true, 1751 | "requires": { 1752 | "resolve-from": "^2.0.0", 1753 | "semver": "^5.1.0" 1754 | } 1755 | }, 1756 | "resolve-from": { 1757 | "version": "2.0.0", 1758 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz", 1759 | "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c=", 1760 | "dev": true 1761 | }, 1762 | "safe-buffer": { 1763 | "version": "5.1.1", 1764 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 1765 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==", 1766 | "dev": true 1767 | }, 1768 | "safer-buffer": { 1769 | "version": "2.1.2", 1770 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1771 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1772 | "dev": true 1773 | }, 1774 | "saslprep": { 1775 | "version": "1.0.3", 1776 | "resolved": "https://registry.npmjs.org/saslprep/-/saslprep-1.0.3.tgz", 1777 | "integrity": "sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag==", 1778 | "dev": true, 1779 | "optional": true, 1780 | "requires": { 1781 | "sparse-bitfield": "^3.0.3" 1782 | } 1783 | }, 1784 | "semver": { 1785 | "version": "5.7.1", 1786 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1787 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1788 | "dev": true 1789 | }, 1790 | "serialize-javascript": { 1791 | "version": "4.0.0", 1792 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-4.0.0.tgz", 1793 | "integrity": "sha512-GaNA54380uFefWghODBWEGisLZFj00nS5ACs6yHa9nLqlLpVLO8ChDGeKRjZnV4Nh4n0Qi7nhYZD/9fCPzEqkw==", 1794 | "dev": true, 1795 | "requires": { 1796 | "randombytes": "^2.1.0" 1797 | } 1798 | }, 1799 | "set-blocking": { 1800 | "version": "2.0.0", 1801 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1802 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 1803 | "dev": true 1804 | }, 1805 | "sparse-bitfield": { 1806 | "version": "3.0.3", 1807 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 1808 | "integrity": "sha1-/0rm5oZWBWuks+eSqzM004JzyhE=", 1809 | "dev": true, 1810 | "optional": true, 1811 | "requires": { 1812 | "memory-pager": "^1.0.2" 1813 | } 1814 | }, 1815 | "sprintf-js": { 1816 | "version": "1.0.3", 1817 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1818 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1819 | "dev": true 1820 | }, 1821 | "string-width": { 1822 | "version": "2.1.1", 1823 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1824 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1825 | "dev": true, 1826 | "requires": { 1827 | "is-fullwidth-code-point": "^2.0.0", 1828 | "strip-ansi": "^4.0.0" 1829 | } 1830 | }, 1831 | "string.prototype.trimend": { 1832 | "version": "1.0.1", 1833 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz", 1834 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==", 1835 | "dev": true, 1836 | "requires": { 1837 | "define-properties": "^1.1.3", 1838 | "es-abstract": "^1.17.5" 1839 | } 1840 | }, 1841 | "string.prototype.trimstart": { 1842 | "version": "1.0.1", 1843 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz", 1844 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==", 1845 | "dev": true, 1846 | "requires": { 1847 | "define-properties": "^1.1.3", 1848 | "es-abstract": "^1.17.5" 1849 | } 1850 | }, 1851 | "string_decoder": { 1852 | "version": "1.0.3", 1853 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 1854 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 1855 | "dev": true, 1856 | "requires": { 1857 | "safe-buffer": "~5.1.0" 1858 | } 1859 | }, 1860 | "strip-ansi": { 1861 | "version": "4.0.0", 1862 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1863 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1864 | "dev": true, 1865 | "requires": { 1866 | "ansi-regex": "^3.0.0" 1867 | } 1868 | }, 1869 | "strip-json-comments": { 1870 | "version": "3.0.1", 1871 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz", 1872 | "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==", 1873 | "dev": true 1874 | }, 1875 | "superagent": { 1876 | "version": "3.8.1", 1877 | "resolved": "https://registry.npmjs.org/superagent/-/superagent-3.8.1.tgz", 1878 | "integrity": "sha512-VMBFLYgFuRdfeNQSMLbxGSLfmXL/xc+OO+BZp41Za/NRDBet/BNbkRJrYzCUu0u4GU0i/ml2dtT8b9qgkw9z6Q==", 1879 | "dev": true, 1880 | "requires": { 1881 | "component-emitter": "^1.2.0", 1882 | "cookiejar": "^2.1.0", 1883 | "debug": "^3.1.0", 1884 | "extend": "^3.0.0", 1885 | "form-data": "^2.3.1", 1886 | "formidable": "^1.1.1", 1887 | "methods": "^1.1.1", 1888 | "mime": "^1.4.1", 1889 | "qs": "^6.5.1", 1890 | "readable-stream": "^2.0.5" 1891 | }, 1892 | "dependencies": { 1893 | "debug": { 1894 | "version": "3.1.0", 1895 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1896 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1897 | "dev": true, 1898 | "requires": { 1899 | "ms": "2.0.0" 1900 | } 1901 | }, 1902 | "mime": { 1903 | "version": "1.4.1", 1904 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", 1905 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==", 1906 | "dev": true 1907 | }, 1908 | "qs": { 1909 | "version": "6.5.1", 1910 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 1911 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==", 1912 | "dev": true 1913 | } 1914 | } 1915 | }, 1916 | "supports-color": { 1917 | "version": "7.1.0", 1918 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 1919 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 1920 | "dev": true, 1921 | "requires": { 1922 | "has-flag": "^4.0.0" 1923 | } 1924 | }, 1925 | "to-regex-range": { 1926 | "version": "5.0.1", 1927 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1928 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1929 | "dev": true, 1930 | "requires": { 1931 | "is-number": "^7.0.0" 1932 | } 1933 | }, 1934 | "toidentifier": { 1935 | "version": "1.0.0", 1936 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 1937 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", 1938 | "dev": true 1939 | }, 1940 | "uberproto": { 1941 | "version": "2.0.6", 1942 | "resolved": "https://registry.npmjs.org/uberproto/-/uberproto-2.0.6.tgz", 1943 | "integrity": "sha512-68H97HffZoFaa3HFtpstahWorN9dSp5uTU6jo3GjIQ6JkJBR3hC2Nx/e/HFOoYHdUyT/Z1MRWfxN1EiQJZUyCQ==", 1944 | "dev": true 1945 | }, 1946 | "unpipe": { 1947 | "version": "1.0.0", 1948 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1949 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 1950 | "dev": true 1951 | }, 1952 | "util-deprecate": { 1953 | "version": "1.0.2", 1954 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1955 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 1956 | "dev": true 1957 | }, 1958 | "which": { 1959 | "version": "2.0.2", 1960 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 1961 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 1962 | "dev": true, 1963 | "requires": { 1964 | "isexe": "^2.0.0" 1965 | } 1966 | }, 1967 | "which-module": { 1968 | "version": "2.0.0", 1969 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 1970 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 1971 | "dev": true 1972 | }, 1973 | "wide-align": { 1974 | "version": "1.1.3", 1975 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1976 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1977 | "dev": true, 1978 | "requires": { 1979 | "string-width": "^1.0.2 || 2" 1980 | } 1981 | }, 1982 | "workerpool": { 1983 | "version": "6.0.0", 1984 | "resolved": "https://registry.npmjs.org/workerpool/-/workerpool-6.0.0.tgz", 1985 | "integrity": "sha512-fU2OcNA/GVAJLLyKUoHkAgIhKb0JoCpSjLC/G2vYKxUjVmQwGbRVeoPJ1a8U4pnVofz4AQV5Y/NEw8oKqxEBtA==", 1986 | "dev": true 1987 | }, 1988 | "wrap-ansi": { 1989 | "version": "5.1.0", 1990 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", 1991 | "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", 1992 | "dev": true, 1993 | "requires": { 1994 | "ansi-styles": "^3.2.0", 1995 | "string-width": "^3.0.0", 1996 | "strip-ansi": "^5.0.0" 1997 | }, 1998 | "dependencies": { 1999 | "ansi-regex": { 2000 | "version": "4.1.0", 2001 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2002 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2003 | "dev": true 2004 | }, 2005 | "ansi-styles": { 2006 | "version": "3.2.1", 2007 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 2008 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 2009 | "dev": true, 2010 | "requires": { 2011 | "color-convert": "^1.9.0" 2012 | } 2013 | }, 2014 | "color-convert": { 2015 | "version": "1.9.3", 2016 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2017 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2018 | "dev": true, 2019 | "requires": { 2020 | "color-name": "1.1.3" 2021 | } 2022 | }, 2023 | "color-name": { 2024 | "version": "1.1.3", 2025 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2026 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 2027 | "dev": true 2028 | }, 2029 | "string-width": { 2030 | "version": "3.1.0", 2031 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2032 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2033 | "dev": true, 2034 | "requires": { 2035 | "emoji-regex": "^7.0.1", 2036 | "is-fullwidth-code-point": "^2.0.0", 2037 | "strip-ansi": "^5.1.0" 2038 | } 2039 | }, 2040 | "strip-ansi": { 2041 | "version": "5.2.0", 2042 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2043 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2044 | "dev": true, 2045 | "requires": { 2046 | "ansi-regex": "^4.1.0" 2047 | } 2048 | } 2049 | } 2050 | }, 2051 | "wrappy": { 2052 | "version": "1.0.2", 2053 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2054 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2055 | "dev": true 2056 | }, 2057 | "y18n": { 2058 | "version": "4.0.0", 2059 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", 2060 | "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", 2061 | "dev": true 2062 | }, 2063 | "yargs": { 2064 | "version": "13.3.2", 2065 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", 2066 | "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", 2067 | "dev": true, 2068 | "requires": { 2069 | "cliui": "^5.0.0", 2070 | "find-up": "^3.0.0", 2071 | "get-caller-file": "^2.0.1", 2072 | "require-directory": "^2.1.1", 2073 | "require-main-filename": "^2.0.0", 2074 | "set-blocking": "^2.0.0", 2075 | "string-width": "^3.0.0", 2076 | "which-module": "^2.0.0", 2077 | "y18n": "^4.0.0", 2078 | "yargs-parser": "^13.1.2" 2079 | }, 2080 | "dependencies": { 2081 | "ansi-regex": { 2082 | "version": "4.1.0", 2083 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2084 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2085 | "dev": true 2086 | }, 2087 | "find-up": { 2088 | "version": "3.0.0", 2089 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 2090 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 2091 | "dev": true, 2092 | "requires": { 2093 | "locate-path": "^3.0.0" 2094 | } 2095 | }, 2096 | "locate-path": { 2097 | "version": "3.0.0", 2098 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 2099 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 2100 | "dev": true, 2101 | "requires": { 2102 | "p-locate": "^3.0.0", 2103 | "path-exists": "^3.0.0" 2104 | } 2105 | }, 2106 | "p-limit": { 2107 | "version": "2.3.0", 2108 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 2109 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 2110 | "dev": true, 2111 | "requires": { 2112 | "p-try": "^2.0.0" 2113 | } 2114 | }, 2115 | "p-locate": { 2116 | "version": "3.0.0", 2117 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 2118 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 2119 | "dev": true, 2120 | "requires": { 2121 | "p-limit": "^2.0.0" 2122 | } 2123 | }, 2124 | "path-exists": { 2125 | "version": "3.0.0", 2126 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2127 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2128 | "dev": true 2129 | }, 2130 | "string-width": { 2131 | "version": "3.1.0", 2132 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2133 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2134 | "dev": true, 2135 | "requires": { 2136 | "emoji-regex": "^7.0.1", 2137 | "is-fullwidth-code-point": "^2.0.0", 2138 | "strip-ansi": "^5.1.0" 2139 | } 2140 | }, 2141 | "strip-ansi": { 2142 | "version": "5.2.0", 2143 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2144 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2145 | "dev": true, 2146 | "requires": { 2147 | "ansi-regex": "^4.1.0" 2148 | } 2149 | } 2150 | } 2151 | }, 2152 | "yargs-parser": { 2153 | "version": "13.1.2", 2154 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", 2155 | "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", 2156 | "dev": true, 2157 | "requires": { 2158 | "camelcase": "^5.0.0", 2159 | "decamelize": "^1.2.0" 2160 | } 2161 | }, 2162 | "yargs-unparser": { 2163 | "version": "1.6.1", 2164 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.6.1.tgz", 2165 | "integrity": "sha512-qZV14lK9MWsGCmcr7u5oXGH0dbGqZAIxTDrWXZDo5zUr6b6iUmelNKO6x6R1dQT24AH3LgRxJpr8meWy2unolA==", 2166 | "dev": true, 2167 | "requires": { 2168 | "camelcase": "^5.3.1", 2169 | "decamelize": "^1.2.0", 2170 | "flat": "^4.1.0", 2171 | "is-plain-obj": "^1.1.0", 2172 | "yargs": "^14.2.3" 2173 | }, 2174 | "dependencies": { 2175 | "ansi-regex": { 2176 | "version": "4.1.0", 2177 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 2178 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 2179 | "dev": true 2180 | }, 2181 | "find-up": { 2182 | "version": "3.0.0", 2183 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 2184 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 2185 | "dev": true, 2186 | "requires": { 2187 | "locate-path": "^3.0.0" 2188 | } 2189 | }, 2190 | "locate-path": { 2191 | "version": "3.0.0", 2192 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 2193 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 2194 | "dev": true, 2195 | "requires": { 2196 | "p-locate": "^3.0.0", 2197 | "path-exists": "^3.0.0" 2198 | } 2199 | }, 2200 | "p-limit": { 2201 | "version": "2.3.0", 2202 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 2203 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 2204 | "dev": true, 2205 | "requires": { 2206 | "p-try": "^2.0.0" 2207 | } 2208 | }, 2209 | "p-locate": { 2210 | "version": "3.0.0", 2211 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 2212 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 2213 | "dev": true, 2214 | "requires": { 2215 | "p-limit": "^2.0.0" 2216 | } 2217 | }, 2218 | "path-exists": { 2219 | "version": "3.0.0", 2220 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2221 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2222 | "dev": true 2223 | }, 2224 | "string-width": { 2225 | "version": "3.1.0", 2226 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 2227 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 2228 | "dev": true, 2229 | "requires": { 2230 | "emoji-regex": "^7.0.1", 2231 | "is-fullwidth-code-point": "^2.0.0", 2232 | "strip-ansi": "^5.1.0" 2233 | } 2234 | }, 2235 | "strip-ansi": { 2236 | "version": "5.2.0", 2237 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 2238 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 2239 | "dev": true, 2240 | "requires": { 2241 | "ansi-regex": "^4.1.0" 2242 | } 2243 | }, 2244 | "yargs": { 2245 | "version": "14.2.3", 2246 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-14.2.3.tgz", 2247 | "integrity": "sha512-ZbotRWhF+lkjijC/VhmOT9wSgyBQ7+zr13+YLkhfsSiTriYsMzkTUFP18pFhWwBeMa5gUc1MzbhrO6/VB7c9Xg==", 2248 | "dev": true, 2249 | "requires": { 2250 | "cliui": "^5.0.0", 2251 | "decamelize": "^1.2.0", 2252 | "find-up": "^3.0.0", 2253 | "get-caller-file": "^2.0.1", 2254 | "require-directory": "^2.1.1", 2255 | "require-main-filename": "^2.0.0", 2256 | "set-blocking": "^2.0.0", 2257 | "string-width": "^3.0.0", 2258 | "which-module": "^2.0.0", 2259 | "y18n": "^4.0.0", 2260 | "yargs-parser": "^15.0.1" 2261 | } 2262 | }, 2263 | "yargs-parser": { 2264 | "version": "15.0.1", 2265 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-15.0.1.tgz", 2266 | "integrity": "sha512-0OAMV2mAZQrs3FkNpDQcBk1x5HXb8X4twADss4S0Iuk+2dGnLOE/fRHrsYm542GduMveyA77OF4wrNJuanRCWw==", 2267 | "dev": true, 2268 | "requires": { 2269 | "camelcase": "^5.0.0", 2270 | "decamelize": "^1.2.0" 2271 | } 2272 | } 2273 | } 2274 | } 2275 | } 2276 | } 2277 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "feathers-mongodb-fuzzy-search", 3 | "version": "2.0.1", 4 | "description": "hook which adds fuzzy search for mongodb through $search in find query", 5 | "main": "index.js", 6 | "scripts": { 7 | "mongo": "docker run --rm -p 27017:27017 mongo", 8 | "preversion": "npm test", 9 | "postpublish": "git push && git push --tags", 10 | "test": "mocha --exit" 11 | }, 12 | "repository": { 13 | "type": "git", 14 | "url": "git+https://github.com/arve0/feathers-mongodb-fuzzy-search.git" 15 | }, 16 | "keywords": [ 17 | "feathers", 18 | "mongodb", 19 | "search", 20 | "fuzzy", 21 | "text" 22 | ], 23 | "author": "Arve Seljebu", 24 | "license": "MIT", 25 | "bugs": { 26 | "url": "https://github.com/arve0/feathers-mongodb-fuzzy-search/issues" 27 | }, 28 | "homepage": "https://github.com/arve0/feathers-mongodb-fuzzy-search#readme", 29 | "devDependencies": { 30 | "@feathersjs/feathers": "^4.3.10", 31 | "@feathersjs/express": "^4.3.10", 32 | "feathers-mongodb": "^6.1.0", 33 | "mocha": "^8.1.3", 34 | "mongodb": "^3.6.2", 35 | "superagent": "^3.8.1" 36 | }, 37 | "dependencies": { 38 | "@feathersjs/commons": "^4.3.7", 39 | "@feathersjs/errors": "^4.3.10" 40 | }, 41 | "runkitExampleFilename": "example.js" 42 | } 43 | -------------------------------------------------------------------------------- /test.js: -------------------------------------------------------------------------------- 1 | const feathers = require('@feathersjs/feathers') 2 | const express = require('@feathersjs/express') 3 | const rest = require('@feathersjs/express/rest') 4 | const request = require('superagent') 5 | const MongoClient = require('mongodb').MongoClient 6 | const service = require('feathers-mongodb') 7 | const search = require('./') 8 | const assert = require('assert') 9 | 10 | const messageDocuments = [ 11 | { title: 'lorem ipsum' }, 12 | { title: 'lorem asdf ipsum' }, 13 | { title: 'hello different world' }, 14 | { title: 'qwerty qwerty qwerty qwerty World' }, 15 | { title: 'cats are awesome.-animales' } 16 | ] 17 | const userDocuments = [ 18 | { firstName: 'John', lastName: 'Doe', fullName: 'John Doe' }, 19 | { firstName: 'Maya', lastName: 'White', fullName: 'Maya White' }, 20 | { firstName: 'Maya', lastName: 'Black', fullName: 'Maya Black' }, 21 | { firstName: 'Steve', lastName: 'Martins', fullName: 'Steve Martins' }, 22 | { firstName: 'Steve', lastName: 'Artins', fullName: 'Steve Martins' } 23 | ] 24 | 25 | let app 26 | before(async function () { 27 | let client = await MongoClient.connect('mongodb://localhost:27017/') 28 | let db = client.db('feathers') 29 | app = express(feathers()) 30 | app.configure(rest()) 31 | 32 | let serviceOptions = { 33 | whitelist: ['$search', '$caseSensitive', '$text', '$regex'], // allow these mongodb fields 34 | multi: true, // allow inserting multiple documents at once 35 | } 36 | 37 | app.use('/messages', service({ 38 | Model: db.collection('messages'), 39 | ...serviceOptions 40 | })) 41 | app.service('messages').Model.createIndex({ title: 'text' }) 42 | app.service('messages').hooks({ 43 | before: { 44 | all: search() // full text search 45 | } 46 | }) 47 | 48 | app.use('/users', service({ 49 | Model: db.collection('users'), 50 | ...serviceOptions 51 | })) 52 | app.service('users').hooks({ 53 | before: { 54 | all: search({ 55 | excludedFields: ['fullName'], // regex search 56 | fieldsNotEscaped: ['lastName'] 57 | }) 58 | } 59 | }) 60 | 61 | app.use('/both', service({ 62 | Model: db.collection('both'), 63 | ...serviceOptions 64 | })) 65 | app.service('both').Model.createIndex({ title: 'text' }) 66 | app.service('both').hooks({ 67 | before: { 68 | all: [ 69 | search(), // full text search 70 | search({ // regex search 71 | fields: ['title'] 72 | }) 73 | ] 74 | } 75 | }) 76 | 77 | await app.service('messages').create(messageDocuments) 78 | await app.service('users').create(userDocuments) 79 | await app.service('both').create(messageDocuments) 80 | }) 81 | 82 | after(async function remove () { 83 | await app.service('messages').remove(null) 84 | await app.service('users').remove(null) 85 | await app.service('both').remove(null) 86 | }) 87 | 88 | it('should find 2 documents with title containing World when case insensitive', async function () { 89 | let docs = await app.service('messages').find({ query: { $search: 'World' } }) 90 | assert.equal(docs.length, 2) 91 | }) 92 | 93 | it('should patch 1 document with title containing World when case sensitive', async function () { 94 | let docs = await app.service('messages').patch(null, { patched: true }, { query: { $search: 'World', $caseSensitive: true } }) 95 | assert.equal(docs.length, 1) 96 | }) 97 | 98 | it('should find 1 document with title containing World when case sensitive', async function () { 99 | let docs = await app.service('messages').find({ query: { $search: 'World', $caseSensitive: true } }) 100 | assert.equal(docs.length, 1) 101 | }) 102 | 103 | it('should find 1 document with cat/differ due to stemming', async function () { 104 | let docs = await app.service('messages').find({ query: { $search: 'cat' } }) 105 | assert.equal(docs.length, 1) 106 | docs = await app.service('messages').find({ query: { $search: 'differ' } }) 107 | assert.equal(docs.length, 1) 108 | }) 109 | 110 | it('should patch 1 document with title containing World when case sensitive', async function () { 111 | let docs = await app.service('messages').patch(null, { patched: true }, { query: { $search: 'World', $caseSensitive: true } }) 112 | assert.equal(docs.length, 1) 113 | }) 114 | 115 | it('should not use or when searching with space', async function () { 116 | let docs = await app.service('messages').find({ query: { $search: 'lorem ipsum' } }) 117 | assert.equal(docs.length, 1) 118 | }) 119 | 120 | it('should not be able to quit " escape', async function () { 121 | let docs = await app.service('messages').find({ query: { $search: 'lorem" "ipsum' } }) 122 | // " are stripped, and we get match for { title: "lorem ipsum" } 123 | assert.equal(docs.length, 1) 124 | }) 125 | 126 | it('should be able to search strings with .-"', async function () { 127 | let docs = await app.service('messages').find({ query: { $search: 'awesome.-animales' } }) 128 | assert.equal(docs.length, 1) 129 | }) 130 | 131 | it('should not allow search request based on excluded field', async function () { 132 | try { 133 | await app.service('users').find({ query: { fullName: { $search: 'a' } } }) 134 | assert.fail('should have raised error') 135 | } catch (error) { 136 | assert.ok(error) 137 | } 138 | }) 139 | 140 | it('should find 2 users with first name field containing "ay"', async function () { 141 | let docs = await app.service('users').find({ query: { firstName: { $search: 'ay' } } }) 142 | assert.equal(docs.length, 2) 143 | }) 144 | 145 | it('should find 2 users with last name field containing "art"', async function () { 146 | let docs = await app.service('users').find({ query: { lastName: { $search: 'art' } } }) 147 | assert.equal(docs.length, 2) 148 | }) 149 | 150 | it('should find 1 user with first name field containing "ay" and last name field containing "b" (case insensitive)', async function () { 151 | let docs = await app.service('users').find({ query: { firstName: { $search: 'ay' }, lastName: { $search: 'b' } } }) 152 | assert.equal(docs.length, 1) 153 | }) 154 | 155 | it('should not find user with first name field containing "ay" and last name field containing "b" (case sensitive)', async function () { 156 | let docs = await app.service('users').find({ query: { firstName: { $search: 'ay' }, lastName: { $search: 'b', caseSensitive: true } } }) 157 | assert.equal(docs.length, 0) 158 | }) 159 | 160 | it('should find 1 user with last name field starting with "art" using a regex', async function () { 161 | let docs = await app.service('users').find({ query: { lastName: { $search: '^art' } } }) 162 | assert.equal(docs.length, 1) 163 | }) 164 | 165 | it('should sanitize search request based on regex on escaped field', async function () { 166 | let docs = await app.service('users').find({ query: { firstName: { $search: '^a' } } }) 167 | assert.equal(docs.length, 0) 168 | }) 169 | 170 | it('should manage field matching with complex operators', async function () { 171 | let docs = await app.service('users').find({ query: { $or: [ { firstName: { $search: 'ay' } }, { lastName: { $search: 'm' } } ] } }) 172 | assert.equal(docs.length, 3) 173 | }) 174 | 175 | it('should work with both full text search and regex search', async function () { 176 | let ft = await app.service('both').find({ query: { $search: 'World' } }) 177 | let reg = await app.service('both').find({ query: { title: { $search: 'World' } } }) 178 | assert.equal(ft.length, 2) 179 | assert.equal(reg.length, 2) 180 | }) 181 | 182 | it('should find 2 documents with title containing World when case insensitive using REST API', function (done) { 183 | let server = app.listen(3030) 184 | server.once('listening', async _ => { 185 | try { 186 | let response = await request.get('http://localhost:3030/messages').query({ $search: 'World' }) 187 | assert.equal(response.body.length, 2) 188 | done() 189 | } catch (error) { 190 | done(error) 191 | } 192 | }) 193 | }) 194 | 195 | it('should find 2 users with first name field containing "ay" using REST API', async function () { 196 | let response = await request.get('http://localhost:3030/users').query({ firstName: { $search: 'ay' } }) 197 | assert.equal(response.body.length, 2) 198 | }) 199 | 200 | --------------------------------------------------------------------------------