Add fuzzy $search
to NeDB service.find
queries.
npm install feathers-nedb-fuzzy-search
const search = require('feathers-nedb-fuzzy-search')
const messages = app.service('messages')
// enable for message service, may use app.hooks too
messages.hooks({
before: {
find: search({['name', 'email']})
}
})
let res = await service.find({ query: { name: { $search: 'ello' } } })
let res = await service.find({ query: $search: 'ello' } })
Besure to whitelist non-standard query parameters in your model.
That's ['$text', '$regex']
for MongoDB , and ['$where', '$regex']
for NeDB.
feathers-nedb-fuzzy-search
take two options in NeDB $where
mode:
search({
fields: ['search.this.path', 'this.path.too', 'title'],
deep: true
})
fields
- Specify which fields to search.deep
- If true andfields
is undefined, will search deep in objects.
In NeDB $regex
mode it takes as service options the following:
excludeFields
- Specify which fields to exclude from search.fields
- Specify which fields to search. Mutually exclusive.
As query parameters it also takes $caseSensitive
const feathers = require('feathers')
const hooks = require('feathers-hooks')
const NeDB = require('nedb')
const service = require('feathers-nedb')
const search = require('feathers-nedb-fuzzy-search')
const Model = new NeDB({
filename: './example.db',
autoload: true
})
const app = feathers()
app.configure(hooks())
app.use('/test', service({ Model }))
app.hooks({
before: {
find: search({
// if omitted, then it will search all properties of documents
fields: ['title', 'description']
})
}
})
// you need node v7 or above for async / await syntax
async function testDatabase () {
let service = app.service('test')
await service.create([
{ 'title': 'asdf' },
{ 'title': 'qwerty' },
{ 'title': 'zxcvb' },
{ 'title': 'hello world' },
{ 'title': 'world around' },
{ 'title': 'cats are awesome' },
])
let res = await service.find({ query: { $search: 'world' } })
let res = await service.find({ query: { title: { $search: 'ello' } } })
console.log(res)
// [ { title: 'world around', _id: '1RDM5BJWX4DWr1Jg' },
// { title: 'hello world', _id: 'dX4bpdM1IsAFkAZd' } ]
// { title: 'hello world', _id: 'dX4bpdM1IsAFkAZd' } ]
}
testDatabase()
.catch(e => console.error(e))
- Support MongoDB and NeDB in this adapter
- Implement global search with $regex, instead of $where and $text which have widly different behavior
- Implement a $searchOpts parameter with {$native, $caseSensitive} etc
- Keep the same name, NeDB is the biggest raison d'etre
- Though it's not a bad option to simplify MongoDB search queries
npm test # runs mocha, see test.js
MIT © 2019 Ray Foss MIT © 2017 Arve Seljebu