@cubejs-backend/cubestore-driver 0.31.45 → 0.31.46

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.
@@ -0,0 +1,42 @@
1
+ import { QueueDriverInterface, QueueDriverConnectionInterface, QueryStageStateResponse, QueryDef, RetrieveForProcessingResponse, QueueDriverOptions, AddToQueueQuery, AddToQueueOptions, AddToQueueResponse, QueryKey } from '@cubejs-backend/base-driver';
2
+ import { CubeStoreDriver } from './CubeStoreDriver';
3
+ declare class CubestoreQueueDriverConnection implements QueueDriverConnectionInterface {
4
+ protected readonly driver: CubeStoreDriver;
5
+ protected readonly options: QueueDriverOptions;
6
+ constructor(driver: CubeStoreDriver, options: QueueDriverOptions);
7
+ redisHash(queryKey: QueryKey): string;
8
+ protected prefixKey(queryKey: QueryKey): string;
9
+ addToQueue(keyScore: number, queryKey: QueryKey, orphanedTime: any, queryHandler: string, query: AddToQueueQuery, priority: number, options: AddToQueueOptions): Promise<AddToQueueResponse>;
10
+ getQueryAndRemove(queryKey: string): Promise<[QueryDef]>;
11
+ cancelQuery(queryKey: string): Promise<QueryDef | null>;
12
+ freeProcessingLock(_queryKey: string, _processingId: string, _activated: unknown): Promise<void>;
13
+ getActiveQueries(): Promise<string[]>;
14
+ getToProcessQueries(): Promise<string[]>;
15
+ getActiveAndToProcess(): Promise<[active: string[], toProcess: string[]]>;
16
+ getNextProcessingId(): Promise<number | string>;
17
+ getQueryStageState(onlyKeys: boolean): Promise<QueryStageStateResponse>;
18
+ getResult(queryKey: string): Promise<unknown>;
19
+ getStalledQueries(): Promise<string[]>;
20
+ getOrphanedQueries(): Promise<string[]>;
21
+ getQueriesToCancel(): Promise<string[]>;
22
+ protected decodeQueryDefFromRow(row: any): QueryDef;
23
+ getQueryDef(queryKey: string): Promise<QueryDef | null>;
24
+ optimisticQueryUpdate(queryKey: any, toUpdate: any, _processingId: any): Promise<boolean>;
25
+ release(): void;
26
+ retrieveForProcessing(queryKey: string, _processingId: string): Promise<RetrieveForProcessingResponse>;
27
+ getResultBlocking(queryKey: string): Promise<QueryDef | null>;
28
+ setResultAndRemoveQuery(queryKey: string, executionResult: any, _processingId: any): Promise<boolean>;
29
+ updateHeartBeat(queryKey: string): Promise<void>;
30
+ }
31
+ export declare class CubeStoreQueueDriver implements QueueDriverInterface {
32
+ protected readonly driverFactory: () => Promise<CubeStoreDriver>;
33
+ protected readonly options: QueueDriverOptions;
34
+ constructor(driverFactory: () => Promise<CubeStoreDriver>, options: QueueDriverOptions);
35
+ protected connection: CubeStoreDriver | null;
36
+ redisHash(queryKey: QueryKey): string;
37
+ protected getConnection(): Promise<CubeStoreDriver>;
38
+ createConnection(): Promise<CubestoreQueueDriverConnection>;
39
+ release(): void;
40
+ }
41
+ export {};
42
+ //# sourceMappingURL=CubeStoreQueueDriver.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CubeStoreQueueDriver.d.ts","sourceRoot":"","sources":["../../src/CubeStoreQueueDriver.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,249 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.CubeStoreQueueDriver = void 0;
7
+ const crypto_1 = __importDefault(require("crypto"));
8
+ function hashQueryKey(queryKey) {
9
+ return crypto_1.default.createHash('md5').update(JSON.stringify(queryKey)).digest('hex');
10
+ }
11
+ class CubestoreQueueDriverConnection {
12
+ constructor(driver, options) {
13
+ this.driver = driver;
14
+ this.options = options;
15
+ }
16
+ redisHash(queryKey) {
17
+ return hashQueryKey(queryKey);
18
+ }
19
+ prefixKey(queryKey) {
20
+ return `${this.options.redisQueuePrefix}:${queryKey}`;
21
+ }
22
+ async addToQueue(keyScore, queryKey, orphanedTime, queryHandler, query, priority, options) {
23
+ // TODO: Fix sqlparser, support negative number
24
+ priority = priority < 0 ? 0 : priority;
25
+ const data = {
26
+ queryHandler,
27
+ query,
28
+ queryKey,
29
+ stageQueryKey: options.stageQueryKey,
30
+ priority,
31
+ requestId: options.requestId,
32
+ addedToQueueTime: new Date().getTime()
33
+ };
34
+ const _rows = await this.driver.query('QUEUE ADD PRIORITY ? ? ?', [
35
+ priority,
36
+ this.prefixKey(this.redisHash(queryKey)),
37
+ JSON.stringify(data)
38
+ ]);
39
+ return [
40
+ 1,
41
+ null,
42
+ null,
43
+ 1,
44
+ data.addedToQueueTime
45
+ ];
46
+ }
47
+ // TODO: Looks useless, because we can do it in one step - getQueriesToCancel
48
+ async getQueryAndRemove(queryKey) {
49
+ return [await this.cancelQuery(queryKey)];
50
+ }
51
+ async cancelQuery(queryKey) {
52
+ const rows = await this.driver.query('QUEUE CANCEL ?', [
53
+ this.prefixKey(queryKey)
54
+ ]);
55
+ if (rows && rows.length) {
56
+ return this.decodeQueryDefFromRow(rows[0]);
57
+ }
58
+ return null;
59
+ }
60
+ async freeProcessingLock(_queryKey, _processingId, _activated) {
61
+ // nothing to do
62
+ }
63
+ async getActiveQueries() {
64
+ const rows = await this.driver.query('QUEUE ACTIVE ?', [
65
+ this.options.redisQueuePrefix
66
+ ]);
67
+ return rows.map((row) => row.id);
68
+ }
69
+ async getToProcessQueries() {
70
+ const rows = await this.driver.query('QUEUE PENDING ?', [
71
+ this.options.redisQueuePrefix
72
+ ]);
73
+ return rows.map((row) => row.id);
74
+ }
75
+ async getActiveAndToProcess() {
76
+ const rows = await this.driver.query('QUEUE LIST ?', [
77
+ this.options.redisQueuePrefix
78
+ ]);
79
+ if (rows.length) {
80
+ const active = [];
81
+ const toProcess = [];
82
+ for (const row of rows) {
83
+ if (row.status === 'active') {
84
+ active.push(row.id);
85
+ }
86
+ else {
87
+ toProcess.push(row.id);
88
+ }
89
+ }
90
+ return [
91
+ active,
92
+ toProcess,
93
+ ];
94
+ }
95
+ return [[], []];
96
+ }
97
+ async getNextProcessingId() {
98
+ const rows = await this.driver.query('CACHE INCR ?', [
99
+ `${this.options.redisQueuePrefix}:PROCESSING_COUNTER`
100
+ ]);
101
+ if (rows && rows.length) {
102
+ return rows[0].value;
103
+ }
104
+ throw new Error('Unable to get next processing id');
105
+ }
106
+ async getQueryStageState(onlyKeys) {
107
+ const rows = await this.driver.query(`QUEUE LIST ${onlyKeys ? '?' : 'WITH_PAYLOAD ?'}`, [
108
+ this.options.redisQueuePrefix
109
+ ]);
110
+ const defs = {};
111
+ const toProcess = [];
112
+ const active = [];
113
+ for (const row of rows) {
114
+ if (!onlyKeys) {
115
+ defs[row.id] = this.decodeQueryDefFromRow(row);
116
+ }
117
+ if (row.status === 'pending') {
118
+ toProcess.push(row.id);
119
+ }
120
+ else if (row.status === 'active') {
121
+ active.push(row.id);
122
+ // TODO: getQueryStage is broken for Executing query stage...
123
+ toProcess.push(row.id);
124
+ }
125
+ }
126
+ return [active, toProcess, defs];
127
+ }
128
+ async getResult(queryKey) {
129
+ const rows = await this.driver.query('QUEUE RESULT ?', [
130
+ this.prefixKey(this.redisHash(queryKey)),
131
+ ]);
132
+ if (rows && rows.length) {
133
+ return JSON.parse(rows[0].value);
134
+ }
135
+ return null;
136
+ }
137
+ async getStalledQueries() {
138
+ const rows = await this.driver.query('QUEUE STALLED ? ?', [
139
+ this.options.heartBeatTimeout * 1000,
140
+ this.options.redisQueuePrefix
141
+ ]);
142
+ return rows.map((row) => row.id);
143
+ }
144
+ async getOrphanedQueries() {
145
+ const rows = await this.driver.query('QUEUE ORPHANED ? ?', [
146
+ this.options.orphanedTimeout * 1000,
147
+ this.options.redisQueuePrefix
148
+ ]);
149
+ return rows.map((row) => row.id);
150
+ }
151
+ async getQueriesToCancel() {
152
+ const rows = await this.driver.query('QUEUE TO_CANCEL ? ? ?', [
153
+ this.options.heartBeatTimeout * 1000,
154
+ this.options.orphanedTimeout * 1000,
155
+ this.options.redisQueuePrefix,
156
+ ]);
157
+ return rows.map((row) => row.id);
158
+ }
159
+ decodeQueryDefFromRow(row) {
160
+ const payload = JSON.parse(row.payload);
161
+ if (row.extra) {
162
+ return Object.assign(payload, JSON.parse(row.extra));
163
+ }
164
+ return payload;
165
+ }
166
+ async getQueryDef(queryKey) {
167
+ const rows = await this.driver.query('QUEUE GET ?', [
168
+ this.prefixKey(this.redisHash(queryKey))
169
+ ]);
170
+ if (rows && rows.length) {
171
+ return this.decodeQueryDefFromRow(rows[0]);
172
+ }
173
+ return null;
174
+ }
175
+ async optimisticQueryUpdate(queryKey, toUpdate, _processingId) {
176
+ await this.driver.query('QUEUE MERGE_EXTRA ? ?', [
177
+ this.prefixKey(queryKey),
178
+ JSON.stringify(toUpdate)
179
+ ]);
180
+ return true;
181
+ }
182
+ release() {
183
+ // nothing to release
184
+ }
185
+ async retrieveForProcessing(queryKey, _processingId) {
186
+ const rows = await this.driver.query('QUEUE RETRIEVE CONCURRENCY ? ?', [
187
+ this.options.concurrency,
188
+ this.prefixKey(queryKey),
189
+ ]);
190
+ if (rows && rows.length) {
191
+ const addedCount = 1;
192
+ const active = [this.redisHash(queryKey)];
193
+ const toProcess = 0;
194
+ const lockAcquired = true;
195
+ const def = this.decodeQueryDefFromRow(rows[0]);
196
+ return [
197
+ addedCount, null, active, toProcess, def, lockAcquired
198
+ ];
199
+ }
200
+ return null;
201
+ }
202
+ async getResultBlocking(queryKey) {
203
+ const rows = await this.driver.query('QUEUE RESULT_BLOCKING ? ?', [
204
+ this.options.continueWaitTimeout * 1000,
205
+ this.prefixKey(this.redisHash(queryKey)),
206
+ ]);
207
+ if (rows && rows.length) {
208
+ return this.decodeQueryDefFromRow(rows[0]);
209
+ }
210
+ return null;
211
+ }
212
+ async setResultAndRemoveQuery(queryKey, executionResult, _processingId) {
213
+ await this.driver.query('QUEUE ACK ? ? ', [
214
+ this.prefixKey(queryKey),
215
+ JSON.stringify(executionResult)
216
+ ]);
217
+ return true;
218
+ }
219
+ async updateHeartBeat(queryKey) {
220
+ await this.driver.query('QUEUE HEARTBEAT ?', [
221
+ this.prefixKey(queryKey)
222
+ ]);
223
+ }
224
+ }
225
+ class CubeStoreQueueDriver {
226
+ constructor(driverFactory, options) {
227
+ this.driverFactory = driverFactory;
228
+ this.options = options;
229
+ this.connection = null;
230
+ }
231
+ redisHash(queryKey) {
232
+ return hashQueryKey(queryKey);
233
+ }
234
+ async getConnection() {
235
+ if (this.connection) {
236
+ return this.connection;
237
+ }
238
+ // eslint-disable-next-line no-return-assign
239
+ return this.connection = await this.driverFactory();
240
+ }
241
+ async createConnection() {
242
+ return new CubestoreQueueDriverConnection(await this.getConnection(), this.options);
243
+ }
244
+ release() {
245
+ // nothing to release
246
+ }
247
+ }
248
+ exports.CubeStoreQueueDriver = CubeStoreQueueDriver;
249
+ //# sourceMappingURL=CubeStoreQueueDriver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CubeStoreQueueDriver.js","sourceRoot":"","sources":["../../src/CubeStoreQueueDriver.ts"],"names":[],"mappings":"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"}
@@ -1,5 +1,6 @@
1
1
  export * from './CubeStoreCacheDriver';
2
2
  export * from './CubeStoreDriver';
3
3
  export * from './CubeStoreDevDriver';
4
+ export * from './CubeStoreQueueDriver';
4
5
  export * from './rexport';
5
6
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,WAAW,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,sBAAsB,CAAC;AACrC,cAAc,wBAAwB,CAAC;AACvC,cAAc,WAAW,CAAC"}
package/dist/src/index.js CHANGED
@@ -13,5 +13,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
13
13
  __exportStar(require("./CubeStoreCacheDriver"), exports);
14
14
  __exportStar(require("./CubeStoreDriver"), exports);
15
15
  __exportStar(require("./CubeStoreDevDriver"), exports);
16
+ __exportStar(require("./CubeStoreQueueDriver"), exports);
16
17
  __exportStar(require("./rexport"), exports);
17
18
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,yDAAuC;AACvC,oDAAkC;AAClC,uDAAqC;AACrC,4CAA0B"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,yDAAuC;AACvC,oDAAkC;AAClC,uDAAqC;AACrC,yDAAuC;AACvC,4CAA0B"}
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@cubejs-backend/cubestore-driver",
3
3
  "description": "Cube Store driver",
4
4
  "author": "Cube Dev, Inc.",
5
- "version": "0.31.45",
5
+ "version": "0.31.46",
6
6
  "repository": {
7
7
  "type": "git",
8
8
  "url": "https://github.com/cube-js/cube.js.git",
@@ -26,7 +26,7 @@
26
26
  "lint:fix": "eslint --fix src/*.ts"
27
27
  },
28
28
  "dependencies": {
29
- "@cubejs-backend/base-driver": "^0.31.42",
29
+ "@cubejs-backend/base-driver": "^0.31.46",
30
30
  "@cubejs-backend/cubestore": "^0.31.45",
31
31
  "@cubejs-backend/shared": "^0.31.42",
32
32
  "csv-write-stream": "^2.0.0",
@@ -34,9 +34,8 @@
34
34
  "fs-extra": "^9.1.0",
35
35
  "generic-pool": "^3.6.0",
36
36
  "moment-timezone": "^0.5.31",
37
- "mysql": "^2.16.0",
38
37
  "node-fetch": "^2.6.1",
39
- "sqlstring": "^2.3.2",
38
+ "sqlstring": "^2.3.3",
40
39
  "tempy": "^1.0.1",
41
40
  "uuid": "^8.3.2",
42
41
  "ws": "^7.4.3"
@@ -45,7 +44,6 @@
45
44
  "@cubejs-backend/linter": "^0.31.0",
46
45
  "@types/flatbuffers": "^1.10.0",
47
46
  "@types/generic-pool": "^3.1.9",
48
- "@types/mysql": "^2.15.17",
49
47
  "@types/ws": "^7.4.0",
50
48
  "jest": "^26.6.3",
51
49
  "typescript": "~4.1.5"
@@ -63,5 +61,5 @@
63
61
  "eslintConfig": {
64
62
  "extends": "../cubejs-linter"
65
63
  },
66
- "gitHead": "59a8848692520bc94eb7fb43bd3872fc69b22c19"
64
+ "gitHead": "adb96e94ed8ade4f777c63fbe797a7f8f0bbf67e"
67
65
  }