-
-
Notifications
You must be signed in to change notification settings - Fork 93
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
Multi-document updates uses "dirty" modifier from previous calls to the collection hook #254
Comments
I'm trying to understand what you mean by this - if you're updating a bunch of documents using the same query and modifier with You're certainly free to update/overwrite/cancel the modifier for each document's update (i.e. each iteration of the hook). And though likely not optimal for multiple documents, you can even query the database if you need current data from pervious iteration (e.g. counts, flags, etc.) What's the use-case here? BTW, there's no one really updating this package - you may want to try checking if there's any currently updated forks. |
@evolross — yep, totally understand that and I did end up manually iterating through each object and updating one by one. The problem is that the hook runs once per document that is updated — misleading the developer into thinking that it's a hook which is running for just a single document update. I was more suggesting that it's made clear in the docs / readme, or the logic is changed to return a set of documents that will be affected by the modifier (rather than running the hook potentially thousands of times, once for each document...). Appreciate the library isn't really maintained these days, though. Which is a shame, as Meteor is such a brilliant framework to work with! :) |
I just bumped into this in one of our apps. Here is the use case : you use the before.update function to compute the field computed of the collection with something like: field computed = field a + field b Let's say you have two documents with Propositions of possible ways to fix the behavior of the package :
After having a look at the code, both options seems difficult to implement. The only simple thing is to add a note in the documentation @StorytellerCZ what do you think ? Thanks ! |
Well, let's start with the note in the documentation to get the simple thing done. @vparpoil since you have broken it down, can you do the PR? |
Here is a try for an update to the documentation If we want to avoid the multiple calls of |
I have noticed that when calling
Collection.update
with{ multi: true }
set as an option, thecollection.before.update
hook is called once per document, however, the modifier parameter is the same object that was used in the previous iteration.This is dangerous if we are setting modifier values based solely on the individual properties of the document we are currently iterating over.
Is this intended behaviour?
If this is working correctly, then I think the
doc
parameter should really be the whole set of documents that are going to be updated (an array of docs), as opposed to looping through each document one by one and running the hook each time. The way this is currently working makes it seem like you should be able to work with each individual document, along with a 'clean' modifier in each iteration, allowing you to add/edit/remove properties on each specific update.It would be good to clear this up for others, as it seems like a pretty big oversight that has likely tripped up many people...
For reference, we are using the latest version of Meteor (v1.8.1).
The text was updated successfully, but these errors were encountered: