Saya memeriksa pendekatan yang berbeda. Masalahnya dapat diselesaikan berdasarkan kasus per kasus dengan memilih bidang secara hati-hati dan memperhatikan urutan langganan, tetapi solusi ini lemah dan bergantung pada kondisi arbitrer yang tidak terdokumentasi.
Satu-satunya solusi generik yang nyata adalah koleksi virtual . Kasus paling sederhana adalah menerbitkan kursor di bawah nama koleksi sisi klien yang berbeda. Misalnya:
function publishVirtual(sub, name, cursor) {
var observer = cursor.observeChanges({
added : function(id, fields) { sub.added(name, id, fields) },
changed: function(id, fields) { sub.changed(name, id, fields) },
removed: function(id) { sub.remove(name, id) }
})
sub.onStop(function() {
observer.stop() // important. Otherwise, it keeps running forever
})
}
Dan kemudian, dalam publikasi Anda, alih-alih mengembalikan cursor
:
var cursor = Users.find()
publishVirtual(this, 'virtualUsers', cursor)
this.ready()