equipped 4.1.0 → 4.1.2

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.
package/CHANGELOG.md CHANGED
@@ -2,6 +2,10 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
4
4
 
5
+ ### [4.1.2](https://github.com/kevinand11/equipped/compare/v4.1.1...v4.1.2) (2023-03-11)
6
+
7
+ ### [4.1.1](https://github.com/kevinand11/equipped/compare/v4.1.0...v4.1.1) (2023-03-10)
8
+
5
9
  ## [4.1.0](https://github.com/kevinand11/equipped/compare/v4.0.2-alpha.3...v4.1.0) (2023-03-07)
6
10
 
7
11
 
@@ -4,6 +4,9 @@ exports.DefaultDebeziumSetup = exports.TopicPrefix = void 0;
4
4
  exports.TopicPrefix = 'equipped';
5
5
  exports.DefaultDebeziumSetup = {
6
6
  'topic.prefix': exports.TopicPrefix,
7
+ 'topic.creation.enable': 'false',
8
+ 'topic.creation.default.replication.factor': '1',
9
+ 'topic.creation.default.partitions': '1',
7
10
  'key.converter': 'org.apache.kafka.connect.json.JsonConverter',
8
11
  'key.converter.schemas.enable': 'false',
9
12
  'value.converter': 'org.apache.kafka.connect.json.JsonConverter',
@@ -39,7 +39,7 @@ class MongoDbChange extends _instance_1.DbChange {
39
39
  const colName = model.collection.name;
40
40
  const dbColName = `${dbName}.${colName}`;
41
41
  const topic = `${debezium_1.TopicPrefix}.${dbColName}`;
42
- (0, retry_1.retry)(async () => {
42
+ await (0, retry_1.retry)(async () => {
43
43
  const { hosts, replicaSet, credentials } = model.collection.conn.getClient().options;
44
44
  const started = await this._setup(topic, {
45
45
  'connector.class': 'io.debezium.connector.mongodb.MongoDbConnector',
@@ -53,45 +53,43 @@ class MongoDbChange extends _instance_1.DbChange {
53
53
  'collection.include.list': dbColName
54
54
  });
55
55
  const TestId = new mongoose_1.default.Types.ObjectId('__equipped__');
56
+ const hydrate = (data) => model.hydrate({
57
+ ...data, _id: new mongoose_1.default.Types.ObjectId(data._id['$oid'])
58
+ }).toObject({ getters: true, virtuals: true });
59
+ instance_1.Instance.get().eventBus.createSubscriber(topic, async (data) => {
60
+ const op = data.op;
61
+ let before = JSON.parse(data.before ?? 'null');
62
+ let after = JSON.parse(data.after ?? 'null');
63
+ if (before)
64
+ before = hydrate(before);
65
+ if (after)
66
+ after = hydrate(after);
67
+ if (before?.__id === TestId || after?.__id === TestId)
68
+ return;
69
+ if (op === 'c' && this.callbacks.created && after)
70
+ await this.callbacks.created({
71
+ before: null,
72
+ after: this.mapper(after)
73
+ });
74
+ else if (op === 'u' && this.callbacks.updated && before)
75
+ await this.callbacks.updated({
76
+ before: this.mapper(before),
77
+ after: this.mapper(after),
78
+ changes: validations_1.Validation.Differ.from(validations_1.Validation.Differ.diff(before, after))
79
+ });
80
+ else if (op === 'd' && this.callbacks.deleted && before)
81
+ await this.callbacks.deleted({
82
+ before: this.mapper(before),
83
+ after: null
84
+ });
85
+ });
56
86
  if (!started) {
57
87
  await model.findByIdAndUpdate(TestId, { $set: { colName } }, { upsert: true });
58
88
  await model.findByIdAndDelete(TestId);
59
- throw new Error(`Wait a few minutes for db changes for ${colName} to initialize...`);
89
+ await instance_1.Instance.get().logger.warn(`Waiting for db changes for ${dbColName} to start...`);
90
+ throw new Error(`Wait a few minutes for db changes for ${dbColName} to initialize...`);
60
91
  }
61
- const hydrate = (data) => model.hydrate({
62
- ...data, _id: new mongoose_1.default.Types.ObjectId(data._id['$oid'])
63
- }).toObject({ getters: true, virtuals: true });
64
- if (started)
65
- await instance_1.Instance.get().eventBus
66
- .createSubscriber(topic, async (data) => {
67
- const op = data.op;
68
- let before = JSON.parse(data.before ?? 'null');
69
- let after = JSON.parse(data.after ?? 'null');
70
- if (before?.__id === TestId || after?.__id === TestId)
71
- return;
72
- if (before)
73
- before = hydrate(before);
74
- if (after)
75
- after = hydrate(after);
76
- if (op === 'c' && this.callbacks.created && after)
77
- await this.callbacks.created({
78
- before: null,
79
- after: this.mapper(after)
80
- });
81
- else if (op === 'u' && this.callbacks.updated && before)
82
- await this.callbacks.updated({
83
- before: this.mapper(before),
84
- after: this.mapper(after),
85
- changes: validations_1.Validation.Differ.from(validations_1.Validation.Differ.diff(before, after))
86
- });
87
- else if (op === 'd' && this.callbacks.deleted && before)
88
- await this.callbacks.deleted({
89
- before: this.mapper(before),
90
- after: null
91
- });
92
- })
93
- .subscribe();
94
- }, 10, 60000)
92
+ }, 5, 60000)
95
93
  .catch((err) => (0, exit_1.exit)(err.message));
96
94
  }
97
95
  }
@@ -13,9 +13,9 @@ export declare class Listener {
13
13
  #private;
14
14
  constructor(socket: io.Server, callers: SocketCallers);
15
15
  start(): Promise<void>;
16
- created(channel: string, data: BaseEntity): Promise<void>;
17
- updated(channel: string, data: BaseEntity): Promise<void>;
18
- deleted(channel: string, data: BaseEntity): Promise<void>;
16
+ created(channels: string[], data: BaseEntity): Promise<void>;
17
+ updated(channels: string[], data: BaseEntity): Promise<void>;
18
+ deleted(channels: string[], data: BaseEntity): Promise<void>;
19
19
  set callers(callers: SocketCallers);
20
20
  register(channel: string, onJoin?: OnJoinFn): this;
21
21
  }
@@ -100,14 +100,14 @@ class Listener {
100
100
  async start() {
101
101
  await __classPrivateFieldGet(this, _Listener_subscriber, "f").subscribe();
102
102
  }
103
- async created(channel, data) {
104
- await __classPrivateFieldGet(this, _Listener_instances, "m", _Listener_emit).call(this, channel, EmitTypes.created, data);
103
+ async created(channels, data) {
104
+ await __classPrivateFieldGet(this, _Listener_instances, "m", _Listener_emit).call(this, channels, EmitTypes.created, data);
105
105
  }
106
- async updated(channel, data) {
107
- await __classPrivateFieldGet(this, _Listener_instances, "m", _Listener_emit).call(this, channel, EmitTypes.updated, data);
106
+ async updated(channels, data) {
107
+ await __classPrivateFieldGet(this, _Listener_instances, "m", _Listener_emit).call(this, channels, EmitTypes.updated, data);
108
108
  }
109
- async deleted(channel, data) {
110
- await __classPrivateFieldGet(this, _Listener_instances, "m", _Listener_emit).call(this, channel, EmitTypes.deleted, data);
109
+ async deleted(channels, data) {
110
+ await __classPrivateFieldGet(this, _Listener_instances, "m", _Listener_emit).call(this, channels, EmitTypes.deleted, data);
111
111
  }
112
112
  set callers(callers) {
113
113
  __classPrivateFieldSet(this, _Listener_callers, callers, "f");
@@ -134,7 +134,9 @@ _Listener_socket = new WeakMap(), _Listener_callers = new WeakMap(), _Listener_r
134
134
  onJoin: __classPrivateFieldGet(this, _Listener_routes, "f")[matchedChannel],
135
135
  params: JSON.parse(JSON.stringify(match.params))
136
136
  };
137
- }, _Listener_emit = async function _Listener_emit(channel, type, data) {
138
- const emitData = { channel, type, data };
139
- __classPrivateFieldGet(this, _Listener_publisher, "f").publish(emitData);
137
+ }, _Listener_emit = async function _Listener_emit(channels, type, data) {
138
+ await Promise.all(channels.map(async (channel) => {
139
+ const emitData = { channel, type, data };
140
+ await __classPrivateFieldGet(this, _Listener_publisher, "f").publish(emitData);
141
+ }));
140
142
  };
@@ -4,9 +4,13 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
4
4
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
5
5
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
6
6
  };
7
+ var __importDefault = (this && this.__importDefault) || function (mod) {
8
+ return (mod && mod.__esModule) ? mod : { "default": mod };
9
+ };
7
10
  var _ConsoleLogger_log;
8
11
  Object.defineProperty(exports, "__esModule", { value: true });
9
12
  exports.ConsoleLogger = exports.Logger = void 0;
13
+ const chalk_1 = __importDefault(require("chalk"));
10
14
  class Logger {
11
15
  }
12
16
  exports.Logger = Logger;
@@ -16,16 +20,16 @@ class ConsoleLogger extends Logger {
16
20
  _ConsoleLogger_log.set(this, console.log);
17
21
  }
18
22
  async error(...args) {
19
- __classPrivateFieldGet(this, _ConsoleLogger_log, "f").call(this, 'LOG:ERROR:', ...args);
23
+ __classPrivateFieldGet(this, _ConsoleLogger_log, "f").call(this, chalk_1.default.red('ERROR:', ...args));
20
24
  }
21
25
  async success(...args) {
22
- __classPrivateFieldGet(this, _ConsoleLogger_log, "f").call(this, 'LOG:SUCCESS:', ...args);
26
+ __classPrivateFieldGet(this, _ConsoleLogger_log, "f").call(this, chalk_1.default.greenBright('SUCCESS:', ...args));
23
27
  }
24
28
  async info(...args) {
25
- __classPrivateFieldGet(this, _ConsoleLogger_log, "f").call(this, 'LOG:INFO:', ...args);
29
+ __classPrivateFieldGet(this, _ConsoleLogger_log, "f").call(this, chalk_1.default.blueBright('INFO:', ...args));
26
30
  }
27
31
  async warn(...args) {
28
- __classPrivateFieldGet(this, _ConsoleLogger_log, "f").call(this, 'LOG:WARN:', ...args);
32
+ __classPrivateFieldGet(this, _ConsoleLogger_log, "f").call(this, chalk_1.default.yellow('WARNING:', ...args));
29
33
  }
30
34
  }
31
35
  exports.ConsoleLogger = ConsoleLogger;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "equipped",
3
- "version": "4.1.0",
3
+ "version": "4.1.2",
4
4
  "private": false,
5
5
  "description": "",
6
6
  "main": "lib/index.js",
@@ -42,6 +42,7 @@
42
42
  "axios": "^1.3.4",
43
43
  "bcryptjs": "^2.4.3",
44
44
  "bull": "^4.10.4",
45
+ "chalk": "^4.1.2",
45
46
  "compression": "^1.7.4",
46
47
  "cookie-parser": "^1.4.6",
47
48
  "cors": "^2.8.5",