@apibara/indexer 2.0.0-beta.9 → 2.1.0-beta.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/dist/index.cjs +271 -39
- package/dist/index.d.cts +1 -16
- package/dist/index.d.mts +1 -16
- package/dist/index.d.ts +1 -16
- package/dist/index.mjs +262 -25
- package/dist/internal/index.cjs +10 -0
- package/dist/internal/index.d.cts +3 -0
- package/dist/internal/index.d.mts +3 -0
- package/dist/internal/index.d.ts +3 -0
- package/dist/internal/index.mjs +8 -0
- package/dist/internal/plugins.cjs +38 -0
- package/dist/internal/plugins.d.cts +13 -0
- package/dist/internal/plugins.d.mts +13 -0
- package/dist/internal/plugins.d.ts +13 -0
- package/dist/internal/plugins.mjs +34 -0
- package/dist/internal/testing.cjs +118 -0
- package/dist/internal/testing.d.cts +42 -0
- package/dist/internal/testing.d.mts +42 -0
- package/dist/internal/testing.d.ts +42 -0
- package/dist/internal/testing.mjs +113 -0
- package/dist/plugins/index.cjs +39 -3
- package/dist/plugins/index.d.cts +16 -2
- package/dist/plugins/index.d.mts +16 -2
- package/dist/plugins/index.d.ts +16 -2
- package/dist/plugins/index.mjs +36 -3
- package/dist/shared/indexer.077335f3.cjs +15 -0
- package/dist/shared/indexer.2416906c.cjs +29 -0
- package/dist/shared/indexer.601ceab0.cjs +7 -0
- package/dist/shared/indexer.9b21ddd2.mjs +5 -0
- package/dist/shared/indexer.a55ad619.mjs +12 -0
- package/dist/shared/indexer.fedcd831.d.cts +100 -0
- package/dist/shared/indexer.fedcd831.d.mts +100 -0
- package/dist/shared/indexer.fedcd831.d.ts +100 -0
- package/dist/shared/indexer.ff25c953.mjs +26 -0
- package/dist/testing/index.cjs +52 -50
- package/dist/testing/index.d.cts +8 -36
- package/dist/testing/index.d.mts +8 -36
- package/dist/testing/index.d.ts +8 -36
- package/dist/testing/index.mjs +47 -47
- package/dist/vcr/index.cjs +84 -17
- package/dist/vcr/index.d.cts +16 -7
- package/dist/vcr/index.d.mts +16 -7
- package/dist/vcr/index.d.ts +16 -7
- package/dist/vcr/index.mjs +75 -11
- package/package.json +22 -42
- package/src/compose.test.ts +76 -0
- package/src/compose.ts +71 -0
- package/src/context.ts +14 -8
- package/src/index.ts +0 -5
- package/src/indexer.test.ts +125 -186
- package/src/indexer.ts +278 -151
- package/src/internal/index.ts +6 -0
- package/src/internal/plugins.ts +1 -0
- package/src/internal/testing.ts +148 -0
- package/src/plugins/config.ts +4 -4
- package/src/plugins/context.ts +40 -0
- package/src/plugins/index.ts +8 -1
- package/src/plugins/logger.ts +30 -0
- package/src/plugins/persistence.ts +24 -187
- package/src/testing/index.ts +58 -3
- package/src/vcr/record.ts +5 -3
- package/src/vcr/replay.ts +8 -18
- package/dist/plugins/kv.cjs +0 -131
- package/dist/plugins/kv.d.cts +0 -32
- package/dist/plugins/kv.d.mts +0 -32
- package/dist/plugins/kv.d.ts +0 -32
- package/dist/plugins/kv.mjs +0 -124
- package/dist/plugins/persistence.cjs +0 -182
- package/dist/plugins/persistence.d.cts +0 -50
- package/dist/plugins/persistence.d.mts +0 -50
- package/dist/plugins/persistence.d.ts +0 -50
- package/dist/plugins/persistence.mjs +0 -179
- package/dist/shared/indexer.2c23c9cd.mjs +0 -35
- package/dist/shared/indexer.318d3617.cjs +0 -47
- package/dist/shared/indexer.36530330.mjs +0 -249
- package/dist/shared/indexer.500fd281.d.cts +0 -23
- package/dist/shared/indexer.541d43eb.cjs +0 -266
- package/dist/shared/indexer.93d6b2eb.mjs +0 -17
- package/dist/shared/indexer.a8b7ab1f.cjs +0 -25
- package/dist/shared/indexer.b9c8f0d8.d.cts +0 -19
- package/dist/shared/indexer.b9c8f0d8.d.mts +0 -19
- package/dist/shared/indexer.b9c8f0d8.d.ts +0 -19
- package/dist/shared/indexer.c7ed6b83.d.cts +0 -82
- package/dist/shared/indexer.e1856641.d.mts +0 -23
- package/dist/shared/indexer.e4f2430f.d.ts +0 -23
- package/dist/shared/indexer.e8bd138d.d.mts +0 -82
- package/dist/shared/indexer.f761abcd.d.ts +0 -82
- package/dist/sinks/csv.cjs +0 -85
- package/dist/sinks/csv.d.cts +0 -66
- package/dist/sinks/csv.d.mts +0 -66
- package/dist/sinks/csv.d.ts +0 -66
- package/dist/sinks/csv.mjs +0 -78
- package/dist/sinks/drizzle/index.cjs +0 -212
- package/dist/sinks/drizzle/index.d.cts +0 -153
- package/dist/sinks/drizzle/index.d.mts +0 -153
- package/dist/sinks/drizzle/index.d.ts +0 -153
- package/dist/sinks/drizzle/index.mjs +0 -198
- package/dist/sinks/sqlite.cjs +0 -90
- package/dist/sinks/sqlite.d.cts +0 -71
- package/dist/sinks/sqlite.d.mts +0 -71
- package/dist/sinks/sqlite.d.ts +0 -71
- package/dist/sinks/sqlite.mjs +0 -87
- package/src/hooks/index.ts +0 -2
- package/src/hooks/useKVStore.ts +0 -12
- package/src/hooks/useSink.ts +0 -13
- package/src/plugins/kv.test.ts +0 -120
- package/src/plugins/kv.ts +0 -132
- package/src/plugins/persistence.test.ts +0 -151
- package/src/sink.ts +0 -36
- package/src/sinks/csv.test.ts +0 -65
- package/src/sinks/csv.ts +0 -159
- package/src/sinks/drizzle/Int8Range.ts +0 -52
- package/src/sinks/drizzle/delete.ts +0 -42
- package/src/sinks/drizzle/drizzle.test.ts +0 -239
- package/src/sinks/drizzle/drizzle.ts +0 -115
- package/src/sinks/drizzle/index.ts +0 -6
- package/src/sinks/drizzle/insert.ts +0 -42
- package/src/sinks/drizzle/select.ts +0 -44
- package/src/sinks/drizzle/transaction.ts +0 -49
- package/src/sinks/drizzle/update.ts +0 -47
- package/src/sinks/drizzle/utils.ts +0 -99
- package/src/sinks/sqlite.test.ts +0 -99
- package/src/sinks/sqlite.ts +0 -170
- package/src/testing/helper.ts +0 -13
- package/src/testing/indexer.ts +0 -35
- package/src/testing/setup.ts +0 -59
- package/src/testing/vcr.ts +0 -54
package/dist/sinks/csv.cjs
DELETED
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const fs = require('node:fs');
|
|
4
|
-
const csvStringify = require('csv-stringify');
|
|
5
|
-
const sink = require('../shared/indexer.a8b7ab1f.cjs');
|
|
6
|
-
require('consola');
|
|
7
|
-
|
|
8
|
-
function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e.default : e; }
|
|
9
|
-
|
|
10
|
-
const fs__default = /*#__PURE__*/_interopDefaultCompat(fs);
|
|
11
|
-
|
|
12
|
-
const transactionHelper = (context) => {
|
|
13
|
-
return {
|
|
14
|
-
insert: (data) => {
|
|
15
|
-
context.buffer.push(...data);
|
|
16
|
-
}
|
|
17
|
-
};
|
|
18
|
-
};
|
|
19
|
-
class CsvSink extends sink.Sink {
|
|
20
|
-
constructor(_stringifier, _config) {
|
|
21
|
-
super();
|
|
22
|
-
this._stringifier = _stringifier;
|
|
23
|
-
this._config = _config;
|
|
24
|
-
}
|
|
25
|
-
async write({
|
|
26
|
-
data,
|
|
27
|
-
endCursor
|
|
28
|
-
}) {
|
|
29
|
-
data = this.processCursorColumn(data, endCursor);
|
|
30
|
-
await this.insertToCSV(data);
|
|
31
|
-
}
|
|
32
|
-
async transaction({ cursor, endCursor, finality }, cb) {
|
|
33
|
-
const context = {
|
|
34
|
-
buffer: []
|
|
35
|
-
};
|
|
36
|
-
const writer = transactionHelper(context);
|
|
37
|
-
await cb({ writer });
|
|
38
|
-
await this.write({ data: context.buffer, endCursor });
|
|
39
|
-
}
|
|
40
|
-
async invalidate(cursor) {
|
|
41
|
-
throw new Error("Not implemented");
|
|
42
|
-
}
|
|
43
|
-
async insertToCSV(data) {
|
|
44
|
-
if (data.length === 0)
|
|
45
|
-
return;
|
|
46
|
-
return await new Promise((resolve, reject) => {
|
|
47
|
-
for (const row of data) {
|
|
48
|
-
this._stringifier.write(row, (err) => {
|
|
49
|
-
if (err)
|
|
50
|
-
throw new Error(err.message);
|
|
51
|
-
if (row === data[data.length - 1]) {
|
|
52
|
-
resolve();
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
processCursorColumn(data, endCursor) {
|
|
59
|
-
const { cursorColumn } = this._config;
|
|
60
|
-
if (cursorColumn && data.some(
|
|
61
|
-
(row) => Number(row[cursorColumn]) !== Number(endCursor?.orderKey)
|
|
62
|
-
)) {
|
|
63
|
-
throw new Error(
|
|
64
|
-
`Mismatch of ${cursorColumn} and Cursor ${Number(endCursor?.orderKey)}`
|
|
65
|
-
);
|
|
66
|
-
}
|
|
67
|
-
if (cursorColumn) {
|
|
68
|
-
return data;
|
|
69
|
-
}
|
|
70
|
-
return data.map((row) => ({
|
|
71
|
-
...row,
|
|
72
|
-
_cursor: Number(endCursor?.orderKey)
|
|
73
|
-
}));
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
const csv = (args) => {
|
|
77
|
-
const { csvOptions, filepath, ...sinkOptions } = args;
|
|
78
|
-
const stringifier = csvStringify.stringify({ ...csvOptions });
|
|
79
|
-
const writeStream = fs__default.createWriteStream(filepath, { flags: "a" });
|
|
80
|
-
stringifier.pipe(writeStream);
|
|
81
|
-
return new CsvSink(stringifier, sinkOptions);
|
|
82
|
-
};
|
|
83
|
-
|
|
84
|
-
exports.CsvSink = CsvSink;
|
|
85
|
-
exports.csv = csv;
|
package/dist/sinks/csv.d.cts
DELETED
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
import { Cursor } from '@apibara/protocol';
|
|
2
|
-
import { Options, Stringifier } from 'csv-stringify';
|
|
3
|
-
import { S as Sink, a as SinkCursorParams, b as SinkData } from '../shared/indexer.b9c8f0d8.cjs';
|
|
4
|
-
|
|
5
|
-
type CsvArgs = {
|
|
6
|
-
/**
|
|
7
|
-
* csv-stringy options
|
|
8
|
-
* @reference https://csv.js.org/stringify/options/
|
|
9
|
-
*/
|
|
10
|
-
csvOptions?: Options;
|
|
11
|
-
/**
|
|
12
|
-
* filepath for your csv file
|
|
13
|
-
*/
|
|
14
|
-
filepath: string;
|
|
15
|
-
};
|
|
16
|
-
type CsvSinkOptions = {
|
|
17
|
-
/**
|
|
18
|
-
* An optional column name used to store the cursor value. If specified,
|
|
19
|
-
* the value of this column must match the `endCursor.orderKey` for each row.
|
|
20
|
-
*/
|
|
21
|
-
cursorColumn?: string;
|
|
22
|
-
};
|
|
23
|
-
type TxnParams = {
|
|
24
|
-
writer: {
|
|
25
|
-
insert: (data: SinkData[]) => void;
|
|
26
|
-
};
|
|
27
|
-
};
|
|
28
|
-
/**
|
|
29
|
-
* A sink that writes data to a CSV file.
|
|
30
|
-
*
|
|
31
|
-
* @example
|
|
32
|
-
*
|
|
33
|
-
* ```ts
|
|
34
|
-
* const sink = csv({
|
|
35
|
-
* filepath: "./data.csv",
|
|
36
|
-
* csvOptions: {
|
|
37
|
-
* header: true,
|
|
38
|
-
* },
|
|
39
|
-
* });
|
|
40
|
-
*
|
|
41
|
-
* ...
|
|
42
|
-
* async transform({context, endCursor}){
|
|
43
|
-
* const { writer } = useSink(context);
|
|
44
|
-
* const insertHelper = writer(endCursor);
|
|
45
|
-
*
|
|
46
|
-
* insertHelper.insert([
|
|
47
|
-
* { id: 1, name: "John" },
|
|
48
|
-
* { id: 2, name: "Jane" },
|
|
49
|
-
* ]);
|
|
50
|
-
* }
|
|
51
|
-
*
|
|
52
|
-
* ```
|
|
53
|
-
*/
|
|
54
|
-
declare class CsvSink extends Sink {
|
|
55
|
-
private _stringifier;
|
|
56
|
-
private _config;
|
|
57
|
-
constructor(_stringifier: Stringifier, _config: CsvSinkOptions);
|
|
58
|
-
private write;
|
|
59
|
-
transaction({ cursor, endCursor, finality }: SinkCursorParams, cb: (params: TxnParams) => Promise<void>): Promise<void>;
|
|
60
|
-
invalidate(cursor?: Cursor): Promise<void>;
|
|
61
|
-
private insertToCSV;
|
|
62
|
-
private processCursorColumn;
|
|
63
|
-
}
|
|
64
|
-
declare const csv: (args: CsvArgs & CsvSinkOptions) => CsvSink;
|
|
65
|
-
|
|
66
|
-
export { type CsvArgs, CsvSink, type CsvSinkOptions, csv };
|
package/dist/sinks/csv.d.mts
DELETED
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
import { Cursor } from '@apibara/protocol';
|
|
2
|
-
import { Options, Stringifier } from 'csv-stringify';
|
|
3
|
-
import { S as Sink, a as SinkCursorParams, b as SinkData } from '../shared/indexer.b9c8f0d8.mjs';
|
|
4
|
-
|
|
5
|
-
type CsvArgs = {
|
|
6
|
-
/**
|
|
7
|
-
* csv-stringy options
|
|
8
|
-
* @reference https://csv.js.org/stringify/options/
|
|
9
|
-
*/
|
|
10
|
-
csvOptions?: Options;
|
|
11
|
-
/**
|
|
12
|
-
* filepath for your csv file
|
|
13
|
-
*/
|
|
14
|
-
filepath: string;
|
|
15
|
-
};
|
|
16
|
-
type CsvSinkOptions = {
|
|
17
|
-
/**
|
|
18
|
-
* An optional column name used to store the cursor value. If specified,
|
|
19
|
-
* the value of this column must match the `endCursor.orderKey` for each row.
|
|
20
|
-
*/
|
|
21
|
-
cursorColumn?: string;
|
|
22
|
-
};
|
|
23
|
-
type TxnParams = {
|
|
24
|
-
writer: {
|
|
25
|
-
insert: (data: SinkData[]) => void;
|
|
26
|
-
};
|
|
27
|
-
};
|
|
28
|
-
/**
|
|
29
|
-
* A sink that writes data to a CSV file.
|
|
30
|
-
*
|
|
31
|
-
* @example
|
|
32
|
-
*
|
|
33
|
-
* ```ts
|
|
34
|
-
* const sink = csv({
|
|
35
|
-
* filepath: "./data.csv",
|
|
36
|
-
* csvOptions: {
|
|
37
|
-
* header: true,
|
|
38
|
-
* },
|
|
39
|
-
* });
|
|
40
|
-
*
|
|
41
|
-
* ...
|
|
42
|
-
* async transform({context, endCursor}){
|
|
43
|
-
* const { writer } = useSink(context);
|
|
44
|
-
* const insertHelper = writer(endCursor);
|
|
45
|
-
*
|
|
46
|
-
* insertHelper.insert([
|
|
47
|
-
* { id: 1, name: "John" },
|
|
48
|
-
* { id: 2, name: "Jane" },
|
|
49
|
-
* ]);
|
|
50
|
-
* }
|
|
51
|
-
*
|
|
52
|
-
* ```
|
|
53
|
-
*/
|
|
54
|
-
declare class CsvSink extends Sink {
|
|
55
|
-
private _stringifier;
|
|
56
|
-
private _config;
|
|
57
|
-
constructor(_stringifier: Stringifier, _config: CsvSinkOptions);
|
|
58
|
-
private write;
|
|
59
|
-
transaction({ cursor, endCursor, finality }: SinkCursorParams, cb: (params: TxnParams) => Promise<void>): Promise<void>;
|
|
60
|
-
invalidate(cursor?: Cursor): Promise<void>;
|
|
61
|
-
private insertToCSV;
|
|
62
|
-
private processCursorColumn;
|
|
63
|
-
}
|
|
64
|
-
declare const csv: (args: CsvArgs & CsvSinkOptions) => CsvSink;
|
|
65
|
-
|
|
66
|
-
export { type CsvArgs, CsvSink, type CsvSinkOptions, csv };
|
package/dist/sinks/csv.d.ts
DELETED
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
import { Cursor } from '@apibara/protocol';
|
|
2
|
-
import { Options, Stringifier } from 'csv-stringify';
|
|
3
|
-
import { S as Sink, a as SinkCursorParams, b as SinkData } from '../shared/indexer.b9c8f0d8.js';
|
|
4
|
-
|
|
5
|
-
type CsvArgs = {
|
|
6
|
-
/**
|
|
7
|
-
* csv-stringy options
|
|
8
|
-
* @reference https://csv.js.org/stringify/options/
|
|
9
|
-
*/
|
|
10
|
-
csvOptions?: Options;
|
|
11
|
-
/**
|
|
12
|
-
* filepath for your csv file
|
|
13
|
-
*/
|
|
14
|
-
filepath: string;
|
|
15
|
-
};
|
|
16
|
-
type CsvSinkOptions = {
|
|
17
|
-
/**
|
|
18
|
-
* An optional column name used to store the cursor value. If specified,
|
|
19
|
-
* the value of this column must match the `endCursor.orderKey` for each row.
|
|
20
|
-
*/
|
|
21
|
-
cursorColumn?: string;
|
|
22
|
-
};
|
|
23
|
-
type TxnParams = {
|
|
24
|
-
writer: {
|
|
25
|
-
insert: (data: SinkData[]) => void;
|
|
26
|
-
};
|
|
27
|
-
};
|
|
28
|
-
/**
|
|
29
|
-
* A sink that writes data to a CSV file.
|
|
30
|
-
*
|
|
31
|
-
* @example
|
|
32
|
-
*
|
|
33
|
-
* ```ts
|
|
34
|
-
* const sink = csv({
|
|
35
|
-
* filepath: "./data.csv",
|
|
36
|
-
* csvOptions: {
|
|
37
|
-
* header: true,
|
|
38
|
-
* },
|
|
39
|
-
* });
|
|
40
|
-
*
|
|
41
|
-
* ...
|
|
42
|
-
* async transform({context, endCursor}){
|
|
43
|
-
* const { writer } = useSink(context);
|
|
44
|
-
* const insertHelper = writer(endCursor);
|
|
45
|
-
*
|
|
46
|
-
* insertHelper.insert([
|
|
47
|
-
* { id: 1, name: "John" },
|
|
48
|
-
* { id: 2, name: "Jane" },
|
|
49
|
-
* ]);
|
|
50
|
-
* }
|
|
51
|
-
*
|
|
52
|
-
* ```
|
|
53
|
-
*/
|
|
54
|
-
declare class CsvSink extends Sink {
|
|
55
|
-
private _stringifier;
|
|
56
|
-
private _config;
|
|
57
|
-
constructor(_stringifier: Stringifier, _config: CsvSinkOptions);
|
|
58
|
-
private write;
|
|
59
|
-
transaction({ cursor, endCursor, finality }: SinkCursorParams, cb: (params: TxnParams) => Promise<void>): Promise<void>;
|
|
60
|
-
invalidate(cursor?: Cursor): Promise<void>;
|
|
61
|
-
private insertToCSV;
|
|
62
|
-
private processCursorColumn;
|
|
63
|
-
}
|
|
64
|
-
declare const csv: (args: CsvArgs & CsvSinkOptions) => CsvSink;
|
|
65
|
-
|
|
66
|
-
export { type CsvArgs, CsvSink, type CsvSinkOptions, csv };
|
package/dist/sinks/csv.mjs
DELETED
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
import fs from 'node:fs';
|
|
2
|
-
import { stringify } from 'csv-stringify';
|
|
3
|
-
import { S as Sink } from '../shared/indexer.93d6b2eb.mjs';
|
|
4
|
-
import 'consola';
|
|
5
|
-
|
|
6
|
-
const transactionHelper = (context) => {
|
|
7
|
-
return {
|
|
8
|
-
insert: (data) => {
|
|
9
|
-
context.buffer.push(...data);
|
|
10
|
-
}
|
|
11
|
-
};
|
|
12
|
-
};
|
|
13
|
-
class CsvSink extends Sink {
|
|
14
|
-
constructor(_stringifier, _config) {
|
|
15
|
-
super();
|
|
16
|
-
this._stringifier = _stringifier;
|
|
17
|
-
this._config = _config;
|
|
18
|
-
}
|
|
19
|
-
async write({
|
|
20
|
-
data,
|
|
21
|
-
endCursor
|
|
22
|
-
}) {
|
|
23
|
-
data = this.processCursorColumn(data, endCursor);
|
|
24
|
-
await this.insertToCSV(data);
|
|
25
|
-
}
|
|
26
|
-
async transaction({ cursor, endCursor, finality }, cb) {
|
|
27
|
-
const context = {
|
|
28
|
-
buffer: []
|
|
29
|
-
};
|
|
30
|
-
const writer = transactionHelper(context);
|
|
31
|
-
await cb({ writer });
|
|
32
|
-
await this.write({ data: context.buffer, endCursor });
|
|
33
|
-
}
|
|
34
|
-
async invalidate(cursor) {
|
|
35
|
-
throw new Error("Not implemented");
|
|
36
|
-
}
|
|
37
|
-
async insertToCSV(data) {
|
|
38
|
-
if (data.length === 0)
|
|
39
|
-
return;
|
|
40
|
-
return await new Promise((resolve, reject) => {
|
|
41
|
-
for (const row of data) {
|
|
42
|
-
this._stringifier.write(row, (err) => {
|
|
43
|
-
if (err)
|
|
44
|
-
throw new Error(err.message);
|
|
45
|
-
if (row === data[data.length - 1]) {
|
|
46
|
-
resolve();
|
|
47
|
-
}
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
|
-
});
|
|
51
|
-
}
|
|
52
|
-
processCursorColumn(data, endCursor) {
|
|
53
|
-
const { cursorColumn } = this._config;
|
|
54
|
-
if (cursorColumn && data.some(
|
|
55
|
-
(row) => Number(row[cursorColumn]) !== Number(endCursor?.orderKey)
|
|
56
|
-
)) {
|
|
57
|
-
throw new Error(
|
|
58
|
-
`Mismatch of ${cursorColumn} and Cursor ${Number(endCursor?.orderKey)}`
|
|
59
|
-
);
|
|
60
|
-
}
|
|
61
|
-
if (cursorColumn) {
|
|
62
|
-
return data;
|
|
63
|
-
}
|
|
64
|
-
return data.map((row) => ({
|
|
65
|
-
...row,
|
|
66
|
-
_cursor: Number(endCursor?.orderKey)
|
|
67
|
-
}));
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
const csv = (args) => {
|
|
71
|
-
const { csvOptions, filepath, ...sinkOptions } = args;
|
|
72
|
-
const stringifier = stringify({ ...csvOptions });
|
|
73
|
-
const writeStream = fs.createWriteStream(filepath, { flags: "a" });
|
|
74
|
-
stringifier.pipe(writeStream);
|
|
75
|
-
return new CsvSink(stringifier, sinkOptions);
|
|
76
|
-
};
|
|
77
|
-
|
|
78
|
-
export { CsvSink, csv };
|
|
@@ -1,212 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const drizzleOrm = require('drizzle-orm');
|
|
4
|
-
const sink = require('../../shared/indexer.a8b7ab1f.cjs');
|
|
5
|
-
const pgCore = require('drizzle-orm/pg-core');
|
|
6
|
-
const range = require('postgres-range');
|
|
7
|
-
require('consola');
|
|
8
|
-
|
|
9
|
-
function _interopDefaultCompat (e) { return e && typeof e === 'object' && 'default' in e ? e.default : e; }
|
|
10
|
-
|
|
11
|
-
const range__default = /*#__PURE__*/_interopDefaultCompat(range);
|
|
12
|
-
|
|
13
|
-
class DrizzleSinkDelete {
|
|
14
|
-
constructor(db, table, endCursor) {
|
|
15
|
-
this.db = db;
|
|
16
|
-
this.table = table;
|
|
17
|
-
this.endCursor = endCursor;
|
|
18
|
-
}
|
|
19
|
-
//@ts-ignore
|
|
20
|
-
where(where) {
|
|
21
|
-
return this.db.update(this.table).set({
|
|
22
|
-
// @ts-ignore
|
|
23
|
-
_cursor: drizzleOrm.sql`int8range(lower(_cursor), ${Number(this.endCursor?.orderKey)}, '[)')`
|
|
24
|
-
}).where(where);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
class Int8Range {
|
|
29
|
-
constructor(range) {
|
|
30
|
-
this.range = range;
|
|
31
|
-
}
|
|
32
|
-
get start() {
|
|
33
|
-
return this.range.lower != null ? {
|
|
34
|
-
value: this.range.lower,
|
|
35
|
-
inclusive: this.range.isLowerBoundClosed()
|
|
36
|
-
} : null;
|
|
37
|
-
}
|
|
38
|
-
get end() {
|
|
39
|
-
return this.range.upper != null ? {
|
|
40
|
-
value: this.range.upper,
|
|
41
|
-
inclusive: this.range.isUpperBoundClosed()
|
|
42
|
-
} : null;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
const int8range = pgCore.customType({
|
|
46
|
-
dataType: () => "int8range",
|
|
47
|
-
fromDriver: (value) => {
|
|
48
|
-
if (typeof value !== "string") {
|
|
49
|
-
throw new Error("Expected string");
|
|
50
|
-
}
|
|
51
|
-
const parsed = range.parse(value, (val) => Number.parseInt(val, 10));
|
|
52
|
-
return new Int8Range(parsed);
|
|
53
|
-
},
|
|
54
|
-
toDriver: (value) => range.serialize(value.range)
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
const pgTable = (name, columns, extraConfig) => {
|
|
58
|
-
return pgCore.pgTable(
|
|
59
|
-
name,
|
|
60
|
-
{
|
|
61
|
-
...columns,
|
|
62
|
-
_cursor: int8range("_cursor").notNull()
|
|
63
|
-
},
|
|
64
|
-
extraConfig
|
|
65
|
-
);
|
|
66
|
-
};
|
|
67
|
-
const getDrizzleCursor = (cursor_range) => {
|
|
68
|
-
const isArray = Array.isArray(cursor_range);
|
|
69
|
-
const [lower, upper] = isArray ? cursor_range : [cursor_range, void 0];
|
|
70
|
-
let isNoUpperBound = false;
|
|
71
|
-
if (!lower) {
|
|
72
|
-
throw new Error("Lower bound cursor is required");
|
|
73
|
-
}
|
|
74
|
-
if (!upper) {
|
|
75
|
-
isNoUpperBound = true;
|
|
76
|
-
}
|
|
77
|
-
return new Int8Range(
|
|
78
|
-
new range__default.Range(
|
|
79
|
-
Number(lower),
|
|
80
|
-
Number(upper),
|
|
81
|
-
range__default.RANGE_LB_INC | (isNoUpperBound ? range__default.RANGE_UB_INF : 0)
|
|
82
|
-
)
|
|
83
|
-
);
|
|
84
|
-
};
|
|
85
|
-
|
|
86
|
-
class DrizzleSinkInsert {
|
|
87
|
-
constructor(db, table, endCursor) {
|
|
88
|
-
this.db = db;
|
|
89
|
-
this.table = table;
|
|
90
|
-
this.endCursor = endCursor;
|
|
91
|
-
}
|
|
92
|
-
values(values) {
|
|
93
|
-
const originalInsert = this.db.insert(this.table);
|
|
94
|
-
const cursoredValues = (Array.isArray(values) ? values : [values]).map(
|
|
95
|
-
(v) => {
|
|
96
|
-
return {
|
|
97
|
-
...v,
|
|
98
|
-
_cursor: getDrizzleCursor(this.endCursor?.orderKey)
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
);
|
|
102
|
-
return originalInsert.values(
|
|
103
|
-
cursoredValues
|
|
104
|
-
);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
class DrizzleSinkSelect {
|
|
109
|
-
constructor(db, fields, endCursor) {
|
|
110
|
-
this.db = db;
|
|
111
|
-
this.fields = fields;
|
|
112
|
-
this.endCursor = endCursor;
|
|
113
|
-
}
|
|
114
|
-
from(source) {
|
|
115
|
-
if (this.fields) {
|
|
116
|
-
const originalFrom = this.db.select(this.fields).from(source);
|
|
117
|
-
return {
|
|
118
|
-
...originalFrom,
|
|
119
|
-
where: (where) => {
|
|
120
|
-
const combinedWhere = drizzleOrm.sql`${where ? drizzleOrm.sql`${where} AND ` : drizzleOrm.sql``}upper_inf(_cursor)`;
|
|
121
|
-
return originalFrom.where(combinedWhere);
|
|
122
|
-
}
|
|
123
|
-
};
|
|
124
|
-
}
|
|
125
|
-
return this.db.select().from(source).where(drizzleOrm.sql`upper_inf(_cursor)`);
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
class DrizzleSinkUpdate {
|
|
130
|
-
constructor(db, table, endCursor) {
|
|
131
|
-
this.db = db;
|
|
132
|
-
this.table = table;
|
|
133
|
-
this.endCursor = endCursor;
|
|
134
|
-
}
|
|
135
|
-
set(values) {
|
|
136
|
-
const originalUpdate = this.db.update(this.table);
|
|
137
|
-
const originalSet = originalUpdate.set(values);
|
|
138
|
-
return {
|
|
139
|
-
...originalSet,
|
|
140
|
-
where: async (where) => {
|
|
141
|
-
await this.db.update(this.table).set({
|
|
142
|
-
_cursor: drizzleOrm.sql`int8range(lower(_cursor), ${Number(this.endCursor?.orderKey)}, '[)')`
|
|
143
|
-
}).where(drizzleOrm.sql`${where ? drizzleOrm.sql`${where} AND ` : drizzleOrm.sql``}upper_inf(_cursor)`).execute();
|
|
144
|
-
return originalSet.where(where);
|
|
145
|
-
}
|
|
146
|
-
};
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
class DrizzleSinkTransaction {
|
|
151
|
-
constructor(db, endCursor) {
|
|
152
|
-
this.db = db;
|
|
153
|
-
this.endCursor = endCursor;
|
|
154
|
-
}
|
|
155
|
-
insert(table) {
|
|
156
|
-
return new DrizzleSinkInsert(this.db, table, this.endCursor);
|
|
157
|
-
}
|
|
158
|
-
update(table) {
|
|
159
|
-
return new DrizzleSinkUpdate(this.db, table, this.endCursor);
|
|
160
|
-
}
|
|
161
|
-
delete(table) {
|
|
162
|
-
return new DrizzleSinkDelete(this.db, table, this.endCursor);
|
|
163
|
-
}
|
|
164
|
-
select(fields) {
|
|
165
|
-
return new DrizzleSinkSelect(this.db, fields, this.endCursor);
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
var __defProp = Object.defineProperty;
|
|
170
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
171
|
-
var __publicField = (obj, key, value) => {
|
|
172
|
-
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
173
|
-
return value;
|
|
174
|
-
};
|
|
175
|
-
class DrizzleSink extends sink.Sink {
|
|
176
|
-
constructor(options) {
|
|
177
|
-
super();
|
|
178
|
-
__publicField(this, "_db");
|
|
179
|
-
__publicField(this, "_tables");
|
|
180
|
-
const { database, tables } = options;
|
|
181
|
-
this._db = database;
|
|
182
|
-
this._tables = tables;
|
|
183
|
-
}
|
|
184
|
-
async transaction({ cursor, endCursor, finality }, cb) {
|
|
185
|
-
await this._db.transaction(async (db) => {
|
|
186
|
-
await cb({ db: new DrizzleSinkTransaction(db, endCursor) });
|
|
187
|
-
});
|
|
188
|
-
}
|
|
189
|
-
async invalidate(cursor) {
|
|
190
|
-
await this._db.transaction(async (db) => {
|
|
191
|
-
for (const table of this._tables) {
|
|
192
|
-
await db.delete(table).where(drizzleOrm.gt(drizzleOrm.sql`lower(_cursor)`, drizzleOrm.sql`${Number(cursor?.orderKey)}`)).returning();
|
|
193
|
-
await db.update(table).set({
|
|
194
|
-
_cursor: drizzleOrm.sql`int8range(lower(_cursor), NULL, '[)')`
|
|
195
|
-
}).where(drizzleOrm.gt(drizzleOrm.sql`upper(_cursor)`, drizzleOrm.sql`${Number(cursor?.orderKey)}`));
|
|
196
|
-
}
|
|
197
|
-
});
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
const drizzle = (args) => {
|
|
201
|
-
return new DrizzleSink(args);
|
|
202
|
-
};
|
|
203
|
-
|
|
204
|
-
exports.DrizzleSink = DrizzleSink;
|
|
205
|
-
exports.DrizzleSinkDelete = DrizzleSinkDelete;
|
|
206
|
-
exports.DrizzleSinkTransaction = DrizzleSinkTransaction;
|
|
207
|
-
exports.DrizzleSinkUpdate = DrizzleSinkUpdate;
|
|
208
|
-
exports.Int8Range = Int8Range;
|
|
209
|
-
exports.drizzle = drizzle;
|
|
210
|
-
exports.getDrizzleCursor = getDrizzleCursor;
|
|
211
|
-
exports.int8range = int8range;
|
|
212
|
-
exports.pgTable = pgTable;
|