mongodb-livedata-server 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (94) hide show
  1. package/README.md +63 -0
  2. package/dist/livedata_server.js +9 -0
  3. package/dist/meteor/binary-heap/max_heap.js +186 -0
  4. package/dist/meteor/binary-heap/min_heap.js +17 -0
  5. package/dist/meteor/binary-heap/min_max_heap.js +48 -0
  6. package/dist/meteor/callback-hook/hook.js +78 -0
  7. package/dist/meteor/ddp/crossbar.js +136 -0
  8. package/dist/meteor/ddp/heartbeat.js +77 -0
  9. package/dist/meteor/ddp/livedata_server.js +403 -0
  10. package/dist/meteor/ddp/method-invocation.js +72 -0
  11. package/dist/meteor/ddp/random-stream.js +100 -0
  12. package/dist/meteor/ddp/session-collection-view.js +106 -0
  13. package/dist/meteor/ddp/session-document-view.js +82 -0
  14. package/dist/meteor/ddp/session.js +570 -0
  15. package/dist/meteor/ddp/stream_server.js +181 -0
  16. package/dist/meteor/ddp/subscription.js +347 -0
  17. package/dist/meteor/ddp/utils.js +104 -0
  18. package/dist/meteor/ddp/writefence.js +111 -0
  19. package/dist/meteor/diff-sequence/diff.js +257 -0
  20. package/dist/meteor/ejson/ejson.js +569 -0
  21. package/dist/meteor/ejson/stringify.js +119 -0
  22. package/dist/meteor/ejson/utils.js +42 -0
  23. package/dist/meteor/id-map/id_map.js +92 -0
  24. package/dist/meteor/mongo/caching_change_observer.js +94 -0
  25. package/dist/meteor/mongo/doc_fetcher.js +53 -0
  26. package/dist/meteor/mongo/geojson_utils.js +41 -0
  27. package/dist/meteor/mongo/live_connection.js +264 -0
  28. package/dist/meteor/mongo/live_cursor.js +57 -0
  29. package/dist/meteor/mongo/minimongo_common.js +2002 -0
  30. package/dist/meteor/mongo/minimongo_matcher.js +217 -0
  31. package/dist/meteor/mongo/minimongo_sorter.js +268 -0
  32. package/dist/meteor/mongo/observe_driver_utils.js +73 -0
  33. package/dist/meteor/mongo/observe_multiplexer.js +228 -0
  34. package/dist/meteor/mongo/oplog-observe-driver.js +919 -0
  35. package/dist/meteor/mongo/oplog_tailing.js +352 -0
  36. package/dist/meteor/mongo/oplog_v2_converter.js +126 -0
  37. package/dist/meteor/mongo/polling_observe_driver.js +195 -0
  38. package/dist/meteor/mongo/synchronous-cursor.js +261 -0
  39. package/dist/meteor/mongo/synchronous-queue.js +110 -0
  40. package/dist/meteor/ordered-dict/ordered_dict.js +198 -0
  41. package/dist/meteor/random/AbstractRandomGenerator.js +92 -0
  42. package/dist/meteor/random/AleaRandomGenerator.js +90 -0
  43. package/dist/meteor/random/NodeRandomGenerator.js +42 -0
  44. package/dist/meteor/random/createAleaGenerator.js +32 -0
  45. package/dist/meteor/random/createRandom.js +22 -0
  46. package/dist/meteor/random/main.js +12 -0
  47. package/livedata_server.ts +3 -0
  48. package/meteor/LICENSE +28 -0
  49. package/meteor/binary-heap/max_heap.ts +225 -0
  50. package/meteor/binary-heap/min_heap.ts +15 -0
  51. package/meteor/binary-heap/min_max_heap.ts +53 -0
  52. package/meteor/callback-hook/hook.ts +85 -0
  53. package/meteor/ddp/crossbar.ts +148 -0
  54. package/meteor/ddp/heartbeat.ts +97 -0
  55. package/meteor/ddp/livedata_server.ts +473 -0
  56. package/meteor/ddp/method-invocation.ts +86 -0
  57. package/meteor/ddp/random-stream.ts +102 -0
  58. package/meteor/ddp/session-collection-view.ts +119 -0
  59. package/meteor/ddp/session-document-view.ts +92 -0
  60. package/meteor/ddp/session.ts +708 -0
  61. package/meteor/ddp/stream_server.ts +204 -0
  62. package/meteor/ddp/subscription.ts +392 -0
  63. package/meteor/ddp/utils.ts +119 -0
  64. package/meteor/ddp/writefence.ts +130 -0
  65. package/meteor/diff-sequence/diff.ts +295 -0
  66. package/meteor/ejson/ejson.ts +601 -0
  67. package/meteor/ejson/stringify.ts +122 -0
  68. package/meteor/ejson/utils.ts +38 -0
  69. package/meteor/id-map/id_map.ts +84 -0
  70. package/meteor/mongo/caching_change_observer.ts +120 -0
  71. package/meteor/mongo/doc_fetcher.ts +52 -0
  72. package/meteor/mongo/geojson_utils.ts +42 -0
  73. package/meteor/mongo/live_connection.ts +302 -0
  74. package/meteor/mongo/live_cursor.ts +79 -0
  75. package/meteor/mongo/minimongo_common.ts +2440 -0
  76. package/meteor/mongo/minimongo_matcher.ts +275 -0
  77. package/meteor/mongo/minimongo_sorter.ts +331 -0
  78. package/meteor/mongo/observe_driver_utils.ts +79 -0
  79. package/meteor/mongo/observe_multiplexer.ts +256 -0
  80. package/meteor/mongo/oplog-observe-driver.ts +1049 -0
  81. package/meteor/mongo/oplog_tailing.ts +414 -0
  82. package/meteor/mongo/oplog_v2_converter.ts +124 -0
  83. package/meteor/mongo/polling_observe_driver.ts +247 -0
  84. package/meteor/mongo/synchronous-cursor.ts +293 -0
  85. package/meteor/mongo/synchronous-queue.ts +119 -0
  86. package/meteor/ordered-dict/ordered_dict.ts +229 -0
  87. package/meteor/random/AbstractRandomGenerator.ts +99 -0
  88. package/meteor/random/AleaRandomGenerator.ts +96 -0
  89. package/meteor/random/NodeRandomGenerator.ts +37 -0
  90. package/meteor/random/createAleaGenerator.ts +31 -0
  91. package/meteor/random/createRandom.ts +19 -0
  92. package/meteor/random/main.ts +8 -0
  93. package/package.json +30 -0
  94. package/tsconfig.json +10 -0
@@ -0,0 +1,119 @@
1
+ import { DiffSequence } from "../diff-sequence/diff";
2
+ import { equals } from "../ejson/ejson";
3
+ import { SessionDocumentView } from "./session-document-view";
4
+
5
+ interface SubscriptionCallbacks {
6
+ added: (collectionName: string, id: string, fields: Record<string, any>) => void;
7
+ changed: (collectionName: string, id: string, fields: Record<string, any>) => void;
8
+ removed: (collectionName: string, id: string) => void;
9
+ }
10
+
11
+ interface SubscriptionHandle {
12
+
13
+ }
14
+
15
+ /**
16
+ * Represents a client's view of a single collection
17
+ * @param {String} collectionName Name of the collection it represents
18
+ * @param {Object.<String, Function>} sessionCallbacks The callbacks for added, changed, removed
19
+ * @class SessionCollectionView
20
+ */
21
+ export class SessionCollectionView {
22
+
23
+ private documents = new Map();
24
+ constructor (private collectionName: string, private callbacks: SubscriptionCallbacks) { }
25
+
26
+ isEmpty() {
27
+ return this.documents.size === 0;
28
+ }
29
+
30
+ diff(previous: SessionCollectionView) {
31
+ DiffSequence.diffMaps(previous.documents, this.documents, {
32
+ both: this.diffDocument.bind(this),
33
+
34
+ rightOnly: (id, nowDV) => {
35
+ this.callbacks.added(this.collectionName, id, nowDV.getFields());
36
+ },
37
+
38
+ leftOnly: (id, prevDV) => {
39
+ this.callbacks.removed(this.collectionName, id);
40
+ }
41
+ });
42
+ }
43
+
44
+ diffDocument(id: string, prevDV: SessionDocumentView, nowDV: SessionDocumentView) {
45
+ const fields = {};
46
+ DiffSequence.diffObjects(prevDV.getFields(), nowDV.getFields(), {
47
+ both: (key: string, prev: any, now: any) => {
48
+ if (!equals(prev, now))
49
+ fields[key] = now;
50
+ },
51
+ rightOnly: (key: string, now: any) => {
52
+ fields[key] = now;
53
+ },
54
+ leftOnly: (key: string, prev: any) => {
55
+ fields[key] = undefined;
56
+ }
57
+ });
58
+ this.callbacks.changed(this.collectionName, id, fields);
59
+ }
60
+
61
+ added(subscriptionHandle: SubscriptionHandle, id: string, fields: Record<string, any>) {
62
+ var self = this;
63
+ var docView = self.documents.get(id);
64
+ var added = false;
65
+ if (!docView) {
66
+ added = true;
67
+ docView = new SessionDocumentView();
68
+ self.documents.set(id, docView);
69
+ }
70
+ docView.existsIn.add(subscriptionHandle);
71
+ var changeCollector = {};
72
+ for (const [key, value] of Object.entries(fields)) {
73
+ docView.changeField(subscriptionHandle, key, value, changeCollector, true);
74
+ }
75
+ if (added)
76
+ self.callbacks.added(self.collectionName, id, changeCollector);
77
+ else
78
+ self.callbacks.changed(self.collectionName, id, changeCollector);
79
+ }
80
+
81
+ changed(subscriptionHandle: SubscriptionHandle, id: string, changed: Record<string, any>) {
82
+ var self = this;
83
+ var changedResult = {};
84
+ var docView = self.documents.get(id);
85
+ if (!docView)
86
+ throw new Error("Could not find element with id " + id + " to change");
87
+ for (const [key, value] of Object.entries(changed)) {
88
+ if (value === undefined)
89
+ docView.clearField(subscriptionHandle, key, changedResult);
90
+ else
91
+ docView.changeField(subscriptionHandle, key, value, changedResult);
92
+ }
93
+ self.callbacks.changed(self.collectionName, id, changedResult);
94
+ }
95
+
96
+ removed(subscriptionHandle, id: string) {
97
+ var self = this;
98
+ var docView = self.documents.get(id);
99
+ if (!docView) {
100
+ var err = new Error("Removed nonexistent document " + id);
101
+ throw err;
102
+ }
103
+ docView.existsIn.delete(subscriptionHandle);
104
+ if (docView.existsIn.size === 0) {
105
+ // it is gone from everyone
106
+ self.callbacks.removed(self.collectionName, id);
107
+ self.documents.delete(id);
108
+ } else {
109
+ var changed = {};
110
+ // remove this subscription from every precedence list
111
+ // and record the changes
112
+ docView.dataByKey.forEach((precedenceList, key) => {
113
+ docView.clearField(subscriptionHandle, key, changed);
114
+ });
115
+
116
+ self.callbacks.changed(self.collectionName, id, changed);
117
+ }
118
+ }
119
+ }
@@ -0,0 +1,92 @@
1
+ import { clone, equals } from "../ejson/ejson";
2
+
3
+ interface PrecedenceItem {
4
+ subscriptionHandle: any;
5
+ value: any;
6
+ }
7
+
8
+ // Represents a single document in a SessionCollectionView
9
+ export class SessionDocumentView {
10
+ public existsIn: Set<any>; // set of subscriptionHandle
11
+ private dataByKey: Map<string, PrecedenceItem[]>; // key-> [ {subscriptionHandle, value} by precedence]
12
+ constructor() {
13
+ this.existsIn = new Set();
14
+ this.dataByKey = new Map();
15
+ };
16
+
17
+ getFields() {
18
+ var ret: Record<string, any> = {};
19
+ this.dataByKey.forEach((precedenceList, key) => {
20
+ ret[key] = precedenceList[0].value;
21
+ });
22
+ return ret;
23
+ }
24
+
25
+ clearField(subscriptionHandle, key: string, changeCollector: Object) {
26
+ // Publish API ignores _id if present in fields
27
+ if (key === "_id")
28
+ return;
29
+ const precedenceList = this.dataByKey.get(key);
30
+
31
+ // It's okay to clear fields that didn't exist. No need to throw
32
+ // an error.
33
+ if (!precedenceList)
34
+ return;
35
+
36
+ let removedValue = undefined;
37
+ for (var i = 0; i < precedenceList.length; i++) {
38
+ var precedence = precedenceList[i];
39
+ if (precedence.subscriptionHandle === subscriptionHandle) {
40
+ // The view's value can only change if this subscription is the one that
41
+ // used to have precedence.
42
+ if (i === 0)
43
+ removedValue = precedence.value;
44
+ precedenceList.splice(i, 1);
45
+ break;
46
+ }
47
+ }
48
+ if (precedenceList.length === 0) {
49
+ this.dataByKey.delete(key);
50
+ changeCollector[key] = undefined;
51
+ } else if (removedValue !== undefined && !equals(removedValue, precedenceList[0].value)) {
52
+ changeCollector[key] = precedenceList[0].value;
53
+ }
54
+ }
55
+
56
+ changeField(subscriptionHandle, key: string, value: any, changeCollector: Object, isAdd: boolean) {
57
+ // Publish API ignores _id if present in fields
58
+ if (key === "_id")
59
+ return;
60
+
61
+ // Don't share state with the data passed in by the user.
62
+ value = clone(value);
63
+
64
+ if (!this.dataByKey.has(key)) {
65
+ this.dataByKey.set(key, [{
66
+ subscriptionHandle: subscriptionHandle,
67
+ value: value
68
+ }]);
69
+ changeCollector[key] = value;
70
+ return;
71
+ }
72
+ const precedenceList = this.dataByKey.get(key);
73
+ let elt;
74
+ if (!isAdd) {
75
+ elt = precedenceList.find(precedence => {
76
+ return precedence.subscriptionHandle === subscriptionHandle;
77
+ });
78
+ }
79
+
80
+ if (elt) {
81
+ if (elt === precedenceList[0] && !equals(value, elt.value)) {
82
+ // this subscription is changing the value of this field.
83
+ changeCollector[key] = value;
84
+ }
85
+ elt.value = value;
86
+ } else {
87
+ // this subscription is newly caring about this field
88
+ precedenceList.push({ subscriptionHandle: subscriptionHandle, value: value });
89
+ }
90
+
91
+ }
92
+ }