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.
baucis-decorator-deep-select
Advanced tools
Adds automatic deep populate + select functionality.
Adds automatic deep populate + select functionality.
npm install baucis-decorators baucis-decorator-deep-select --save
Just add the decorator and it should work if you're using a version of mongoose
that supports deep population. The latest release does not yet support this but 4.1 should. Until then, use npm install timbur/mongoose --save
.
controllers/Comment.js
var baucis = require('baucis');
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var ObjectId = Schema.Types.ObjectId;
var CommentProps = {};
CommentProps.by = {
type: ObjectId,
ref: 'User'
};
CommentProps.comment = {
type: String
};
CommentProps.replies = {
type: [{
type: ObjectId,
ref: 'Comment'
}]
};
var CommentSchema = new Schema(CommentProps);
var CommentModel = mongoose.model('Comment', CommentSchema);
var CommentController = baucis.rest('Comment');
var decorators = require('baucis-decorators');
decorators.add.call(CommentController, [
'baucis-decorator-deep-select'
]);
/**
* Expose controller.
*/
module.exports = CommentController;
Then to select and populate some comments a few levels deep, GET a URL as follows.
From single comment:
localhost:8080/api/comments/123?select=replies.replies.replies
From query:
localhost:8080/api/comments?by=someUserId&select=replies.replies.replies
Or select certain fields:
localhost:8080/api/comments?by=someUserId&select=comment by.name by.image comment replies.comment replies.replies.comment replies.replies.replies.comment
This should pair quite well with something that might convert a GraphQL-like string to the above select
parameters.
FAQs
Adds automatic deep populate + select functionality.
We found that baucis-decorator-deep-select demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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.