-
-
Notifications
You must be signed in to change notification settings - Fork 19
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: Also hide when using lean() on Query #58
Comments
This plugin extends the Mongoose API at the model layer, that is after the query has been hydrated into model objects. This is also where transformation functions live which is used to hide unwanted values. To have hook into I don't think monkey patching is the way to go. Since you use lean and not toJSON or toObject could it be that you are streaming your content? In that case it would more sense to clean your data per object basis instead of the whole data set. I'm open to PRs as well of course. |
Hi @mblarsen thanks for your response. I understand, so when i use lean() the query is passed directly from mongo as objects. I was using lean because some people told me that it improves performance but if the price to pay is to bypass all the mongoose api then it is not worth it. Is there any benefit from transforming the objects before sending them through the response? O should just let Mongoose and ExpressJS handle it? Thanks! |
Well, when you call toJSON and toObject they are being transformed. Surely there is a performance gain by using lean but that is mostly when you are dealing with big sums of data. Why not try it out, with and without. If you can live with the non-lean version then all is good :) Closing issue now, but feel free to leave more comments and/or questions. |
I have a solution for us: I created a package Here's a rundown on how it works: const pickOriginal = require('@ladjs/pick-original');
// ...
// this is an example object from `lean()` query
const lean = { foo: 'bar' };
// basically re-create a new document and invoke `toObject` on it
const obj = new Model(lean).toObject();
// pick only the original fields (recursive and supports arrays/nested arrays/etc)
console.log(pickOriginal(obj, lean)); |
@niftylettuce it is a recursive intersection between the props on the the original (allowed) and the transformed (hidden + whatever Mongo adds)? So Mongo specific stuff is removed and whatever is supposed to be hidden stays hidden. Would you be interested in writing a small unit test that uses your library? Then afterwards we can see how the API could be for hooking into lean(). Either as opt-in or -out. |
Hi @mblarsen and thanks for the quick reply! RE: whatever is supposed to be hidden stays hidden - yes, precisely. you can see this in-depth usage here where I already integrated it: https://github.com/forwardemail/forwardemail.net/blob/master/app/controllers/api/v1/aliases.js#L16-L19 RE: tests - I have some here https://github.com/ladjs/pick-original/blob/master/test/test.js |
I have the following model
When i use lean() on a query, i recieve this:
I would like to be able to use mongoose-hidden to hide the password but using lean()
The text was updated successfully, but these errors were encountered: