Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Object document mapper for Open Search Server.
See also parent module node-oss-client.
npm install oss-odm
const oss = require('node-oss-client');
const Index = require('oss-odm').Index;
const index = new Index({
name: 'my_index',
indexers: oss.createClient(),
searcher: oss.createClient()
});
// Insert a new document in "my_index".
index.create({ title: 'My first document' }, (err) => { ... });
// Search in "my_index".
index.search('my query', (err, res) => {
console.log(res.documents); // [{ title: 'My first document' }]
});
Create a new index with some options.
Type: String
Name of the index.
new Index({ name: 'my_index' });
Type: String
Default language of the index, defaults to "ENGLISH".
new Index({
lang: 'FRENCH'
});
Type: Array
or Object
OSS clients used to index document.
var indexer1 = oss.createClient({ host: 'indexer1' });
var indexer2 = oss.createClient({ host: 'indexer2' });
new Index({ indexers: [indexer1, indexer2] });
Type: Object
OSS client used to search.
var searcher = oss.createClient({ host: 'searcher' });
new Index({ searcher });
Type: Object
Search templates that can be used in index.search
, the default template must be called "default".
All search options known by OSS can be specified in the template.
new Index({
templates: {
default: {
returnedFields: [
'id',
'title'
],
searchFields: [
{
field: 'text',
mode: 'TERM_AND_PHRASE',
boost: 1
}
]
},
title: {
returnedFields: [
'id',
'title'
],
searchFields: [
{
field: 'title',
mode: 'TERM_AND_PHRASE',
boost: 1
}
]
}
}
});
Type: Object
You can specify an input (indexing) and an output (search) formatters. These formatter are applied to each documents.
new Index({
formatters: {
input: inputFormatter,
output: outputFormatter
}
});
function inputFormatter(document) {
// Add a timestamp key.
document.timestamp = Date.now();
return document;
}
function outputFormatter(document) {
// Convert id in Number.
document.id = parseInt(document.id, 10);
return document;
}
Type: Object
Filters formatter that can be used in index.search
.
new Index({
filters: {
id: formatIdFilter
}
});
function formatIdFilter(value, context) {
return {
type: 'QueryFilter',
negative: false,
query: 'id:' + value
};
}
Type: Object
Joins that can be used in index.search
.
new Index({
joins: {
myJoin: {
index: customIndex,
queryTemplate: 'customQueryTemplate',
localField: 'local_id',
foreignField: 'id',
type: 'INNER',
returnFields: false,
returnScores: false,
returnFacets: false
}
}
});
Insert a new document in the index.
Note : if an array is provided as value, it triggers a multi-valued field insertion.
index.create([
{
title: 'My first document',
foo: 'bar'
},
{
title: 'My second document',
ids: [23, 34]
}
], (err) => { ... });
Some options are available:
Type: String
The language of the document to index, default to the index language.
index.create([
{ title: 'My first document' }
], { lang: 'FRENCH' }, (err) => { ... });
Destroy a documents in the index.
index.destroy(['182', '85'], (err) => { ... });
Some options are available:
Type: String
The field used to match values, default to "id".
index.destroy(['bob', 'tom'], { field: 'name' }, (err) => { ... });
Search in the index.
index.search('my query', (err, res) => { ... });
Some options are available:
Type: String
The language used for searching documents.
index.search('my query', { lang: 'FRENCH' }, (err, res) => { ... });
Type: String
The template used to process the query, defaults to "default".
index.search('my query', { template: 'custom' }, (err, res) => { ... });
Type: Object
Filters applied to the query. Filters are transformed using filter formatters defined in the constructor.
index.search('my query', {
filters: {
id: 10
},
filterOptions: {
foo: 'bar'
}
}, (err, res) => { ... });
Type: Object
Joins applied to the query. Joins used the joins defined in the constructor.
index.search('my query', {
joins: {
myJoin: {
query: 'join query',
template: 'myTemplate',
filters: {
myJoinFilter: 'test'
}
}
}
})
All search options known by OSS can be used in the search function.
const indexer1 = oss.createClient({ host: 'indexer1' });
const indexer2 = oss.createClient({ host: 'indexer2' });
syncManager.sync([indexer1, indexer2], [
{
name: 'articles',
uniqueField: 'id',
defaultField: 'text',
fields: [
{
name: 'id',
indexed: true,
stored: true
},
{
name: 'text',
indexed: true,
stored: true
}
]
}
]);
const indexer1 = oss.createClient({ host: 'indexer1' });
const indexer2 = oss.createClient({ host: 'indexer2' });
syncManager.drop([indexer1, indexer2], ['articles']);
Creates as many as replication indexes (based on schemas argument) on searchers passed as argument in clients and starts a replication on each of the searchers.
const indexer1 = oss.createClient({ host: 'indexer1' });
const indexes = [ { name: 'my_index_1' }, { name: 'my_index_2' } ]
replicaManager.replicateAllIndexes(indexer1, indexes, (err, res ) => {
// Code callback here ....
});
MIT
FAQs
Object document mapper for Open Search Server.
We found that oss-odm demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 9 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.