@sentio/sdk 2.39.7-rc.3 → 2.39.7-rc.5
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/lib/store/cursor.d.ts +14 -0
- package/lib/store/cursor.d.ts.map +1 -0
- package/lib/store/cursor.js +22 -0
- package/lib/store/cursor.js.map +1 -0
- package/lib/store/index.d.ts +1 -0
- package/lib/store/index.d.ts.map +1 -1
- package/lib/store/index.js +1 -0
- package/lib/store/index.js.map +1 -1
- package/lib/store/store.d.ts +4 -4
- package/lib/store/store.d.ts.map +1 -1
- package/lib/store/store.js +33 -13
- package/lib/store/store.js.map +1 -1
- package/package.json +3 -3
- package/src/store/cursor.ts +29 -0
- package/src/store/index.ts +1 -0
- package/src/store/store.ts +43 -18
@@ -0,0 +1,14 @@
|
|
1
|
+
export interface CursorOptions {
|
2
|
+
initCursor?: string;
|
3
|
+
pageSize?: number;
|
4
|
+
}
|
5
|
+
export declare class Cursor {
|
6
|
+
_cursor?: string;
|
7
|
+
private _done;
|
8
|
+
readonly pageSize?: number;
|
9
|
+
constructor(options?: CursorOptions);
|
10
|
+
get cursor(): string | undefined;
|
11
|
+
set cursor(cursor: string | undefined);
|
12
|
+
get hasNext(): boolean;
|
13
|
+
}
|
14
|
+
//# sourceMappingURL=cursor.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"cursor.d.ts","sourceRoot":"","sources":["../../src/store/cursor.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB;AAED,qBAAa,MAAM;IACjB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,KAAK,CAAQ;IACrB,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;gBACd,OAAO,CAAC,EAAE,aAAa;IAKnC,IAAI,MAAM,IAAI,MAAM,GAAG,SAAS,CAE/B;IAED,IAAI,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,EAKpC;IAED,IAAI,OAAO,IAAI,OAAO,CAErB;CACF"}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
export class Cursor {
|
2
|
+
_cursor;
|
3
|
+
_done = false;
|
4
|
+
pageSize;
|
5
|
+
constructor(options) {
|
6
|
+
this._cursor = options?.initCursor;
|
7
|
+
this.pageSize = options?.pageSize;
|
8
|
+
}
|
9
|
+
get cursor() {
|
10
|
+
return this._cursor;
|
11
|
+
}
|
12
|
+
set cursor(cursor) {
|
13
|
+
if (!cursor) {
|
14
|
+
this._done = true;
|
15
|
+
}
|
16
|
+
this._cursor = cursor;
|
17
|
+
}
|
18
|
+
get hasNext() {
|
19
|
+
return !this._done;
|
20
|
+
}
|
21
|
+
}
|
22
|
+
//# sourceMappingURL=cursor.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"cursor.js","sourceRoot":"","sources":["../../src/store/cursor.ts"],"names":[],"mappings":"AAKA,MAAM,OAAO,MAAM;IACjB,OAAO,CAAS;IACR,KAAK,GAAG,KAAK,CAAA;IACZ,QAAQ,CAAS;IAC1B,YAAY,OAAuB;QACjC,IAAI,CAAC,OAAO,GAAG,OAAO,EAAE,UAAU,CAAA;QAClC,IAAI,CAAC,QAAQ,GAAG,OAAO,EAAE,QAAQ,CAAA;IACnC,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAA;IACrB,CAAC;IAED,IAAI,MAAM,CAAC,MAA0B;QACnC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;QACnB,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;IACvB,CAAC;IAED,IAAI,OAAO;QACT,OAAO,CAAC,IAAI,CAAC,KAAK,CAAA;IACpB,CAAC;CACF"}
|
package/lib/store/index.d.ts
CHANGED
package/lib/store/index.d.ts.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/store/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,YAAY,CAAA;AAC1B,cAAc,YAAY,CAAA;AAC1B,cAAc,cAAc,CAAA;AAC5B,cAAc,cAAc,CAAA"}
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/store/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,YAAY,CAAA;AAC1B,cAAc,YAAY,CAAA;AAC1B,cAAc,cAAc,CAAA;AAC5B,cAAc,cAAc,CAAA;AAC5B,cAAc,aAAa,CAAA"}
|
package/lib/store/index.js
CHANGED
package/lib/store/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/store/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,YAAY,CAAA;AAC1B,cAAc,YAAY,CAAA;AAC1B,cAAc,cAAc,CAAA;AAC5B,cAAc,cAAc,CAAA"}
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/store/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,YAAY,CAAA;AAC1B,cAAc,YAAY,CAAA;AAC1B,cAAc,cAAc,CAAA;AAC5B,cAAc,cAAc,CAAA;AAC5B,cAAc,aAAa,CAAA"}
|
package/lib/store/store.d.ts
CHANGED
@@ -1,6 +1,7 @@
|
|
1
1
|
import { StoreContext } from './context.js';
|
2
2
|
import { BigDecimal } from '@sentio/bigdecimal';
|
3
3
|
import { Bytes, Float, ID, Int, Timestamp } from './types.js';
|
4
|
+
import { Cursor } from './cursor.js';
|
4
5
|
type Value = ID | string | Int | Float | boolean | Timestamp | Bytes | BigDecimal | bigint;
|
5
6
|
interface Entity {
|
6
7
|
id: ID;
|
@@ -15,7 +16,9 @@ export declare class Store {
|
|
15
16
|
delete<T extends Entity>(entity: EntityClass<T> | T | T[], id?: string | string[]): Promise<void>;
|
16
17
|
upsert<T extends Entity>(entity: T | T[]): Promise<void>;
|
17
18
|
listIterator<T extends Entity>(entity: EntityClass<T>, filters?: ListFilter<T>[]): AsyncGenerator<T, void, unknown>;
|
18
|
-
|
19
|
+
listBatched<T extends Entity>(entity: EntityClass<T>, filters?: ListFilter<T>[], batchSize?: number): AsyncGenerator<T[], void, unknown>;
|
20
|
+
private listRequest;
|
21
|
+
list<T extends Entity>(entity: EntityClass<T>, filters?: ListFilter<T>[], cursor?: Cursor): Promise<T[]>;
|
19
22
|
private fromAsync;
|
20
23
|
private newEntity;
|
21
24
|
}
|
@@ -25,9 +28,6 @@ export interface ListFilter<T extends Entity> {
|
|
25
28
|
op: Operators;
|
26
29
|
value: Value | Value[] | null;
|
27
30
|
}
|
28
|
-
export interface ListOptions<T extends Entity> {
|
29
|
-
cursor: string;
|
30
|
-
}
|
31
31
|
export declare function getStore(): Store | undefined;
|
32
32
|
export {};
|
33
33
|
//# sourceMappingURL=store.d.ts.map
|
package/lib/store/store.d.ts.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../src/store/store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAE3C,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAC/C,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,YAAY,CAAA;
|
1
|
+
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../src/store/store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAE3C,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAC/C,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,YAAY,CAAA;AAK7D,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AAEpC,KAAK,KAAK,GAAG,EAAE,GAAG,MAAM,GAAG,GAAG,GAAG,KAAK,GAAG,OAAO,GAAG,SAAS,GAAG,KAAK,GAAG,UAAU,GAAG,MAAM,CAAA;AAE1F,UAAU,MAAM;IACd,EAAE,EAAE,EAAE,CAAA;CACP;AAED,MAAM,WAAW,WAAW,CAAC,CAAC;IAC5B,KAAK,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAA;CAC1B;AAkBD,qBAAa,KAAK;IACJ,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAAP,OAAO,EAAE,YAAY;IAE5C,GAAG,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,MAAM,EAAE,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC;IAiBtF,MAAM,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IA4BjG,MAAM,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAcvD,YAAY,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE;IAehF,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE,SAAS,SAAM;YAczF,WAAW;IAqBnB,IAAI,CAAC,CAAC,SAAS,MAAM,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE,MAAM,CAAC,EAAE,MAAM;YAUjF,SAAS;IAQvB,OAAO,CAAC,SAAS;CAiBlB;AAED,MAAM,MAAM,SAAS,GAAG,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,IAAI,GAAG,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,QAAQ,CAAA;AAE9E,MAAM,WAAW,UAAU,CAAC,CAAC,SAAS,MAAM;IAC1C,KAAK,EAAE,MAAM,CAAC,CAAA;IACd,EAAE,EAAE,SAAS,CAAA;IACb,KAAK,EAAE,KAAK,GAAG,KAAK,EAAE,GAAG,IAAI,CAAA;CAC9B;AA+DD,wBAAgB,QAAQ,sBAMvB"}
|
package/lib/store/store.js
CHANGED
@@ -80,18 +80,7 @@ export class Store {
|
|
80
80
|
async *listIterator(entity, filters) {
|
81
81
|
let cursor = undefined;
|
82
82
|
while (true) {
|
83
|
-
const
|
84
|
-
list: {
|
85
|
-
entity: getEntityName(entity),
|
86
|
-
cursor,
|
87
|
-
filters: filters?.map((f) => ({
|
88
|
-
field: f.field,
|
89
|
-
op: ops[f.op],
|
90
|
-
value: { values: Array.isArray(f.value) ? f.value.map((v) => serialize(v)) : [serialize(f.value)] }
|
91
|
-
})) || []
|
92
|
-
}
|
93
|
-
});
|
94
|
-
const response = (await promise);
|
83
|
+
const response = await this.listRequest(entity, filters || [], cursor);
|
95
84
|
for (const data of response.entityList?.entities || []) {
|
96
85
|
yield this.newEntity(entity, data);
|
97
86
|
}
|
@@ -101,7 +90,38 @@ export class Store {
|
|
101
90
|
cursor = response.nextCursor;
|
102
91
|
}
|
103
92
|
}
|
104
|
-
async
|
93
|
+
async *listBatched(entity, filters, batchSize = 100) {
|
94
|
+
let cursor = undefined;
|
95
|
+
while (true) {
|
96
|
+
const response = await this.listRequest(entity, filters || [], cursor, batchSize);
|
97
|
+
const entities = (response.entityList?.entities || []).map((data) => this.newEntity(entity, data));
|
98
|
+
yield entities;
|
99
|
+
if (!response.nextCursor) {
|
100
|
+
break;
|
101
|
+
}
|
102
|
+
cursor = response.nextCursor;
|
103
|
+
}
|
104
|
+
}
|
105
|
+
async listRequest(entity, filters, cursor, pageSize) {
|
106
|
+
return (await this.context.sendRequest({
|
107
|
+
list: {
|
108
|
+
entity: getEntityName(entity),
|
109
|
+
cursor,
|
110
|
+
pageSize,
|
111
|
+
filters: filters?.map((f) => ({
|
112
|
+
field: f.field,
|
113
|
+
op: ops[f.op],
|
114
|
+
value: { values: Array.isArray(f.value) ? f.value.map((v) => serialize(v)) : [serialize(f.value)] }
|
115
|
+
})) || []
|
116
|
+
}
|
117
|
+
}));
|
118
|
+
}
|
119
|
+
async list(entity, filters, cursor) {
|
120
|
+
if (cursor) {
|
121
|
+
const response = await this.listRequest(entity, filters || [], cursor.cursor, cursor.pageSize);
|
122
|
+
cursor.cursor = response.nextCursor;
|
123
|
+
return response.entityList?.entities.map((data) => this.newEntity(entity, data)) || [];
|
124
|
+
}
|
105
125
|
// TODO Array.fromAsync when upgrade to node 22
|
106
126
|
return this.fromAsync(this.listIterator(entity, filters));
|
107
127
|
}
|
package/lib/store/store.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/store/store.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAG/C,OAAO,EAAE,oBAAoB,EAAc,MAAM,gBAAgB,CAAA;AACjE,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/store/store.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@sentio/sdk",
|
3
|
-
"version": "2.39.7-rc.
|
3
|
+
"version": "2.39.7-rc.5",
|
4
4
|
"license": "Apache-2.0",
|
5
5
|
"type": "module",
|
6
6
|
"exports": {
|
@@ -83,8 +83,8 @@
|
|
83
83
|
"typedoc": "^0.26.0",
|
84
84
|
"utility-types": "^3.11.0",
|
85
85
|
"yaml": "^2.3.4",
|
86
|
-
"@sentio/protos": "2.39.7-rc.
|
87
|
-
"@sentio/runtime": "^2.39.7-rc.
|
86
|
+
"@sentio/protos": "2.39.7-rc.5",
|
87
|
+
"@sentio/runtime": "^2.39.7-rc.5"
|
88
88
|
},
|
89
89
|
"peerDependencies": {
|
90
90
|
"tsup": "npm:@sentio/tsup@^6.7.2"
|
@@ -0,0 +1,29 @@
|
|
1
|
+
export interface CursorOptions {
|
2
|
+
initCursor?: string
|
3
|
+
pageSize?: number
|
4
|
+
}
|
5
|
+
|
6
|
+
export class Cursor {
|
7
|
+
_cursor?: string
|
8
|
+
private _done = false
|
9
|
+
readonly pageSize?: number
|
10
|
+
constructor(options?: CursorOptions) {
|
11
|
+
this._cursor = options?.initCursor
|
12
|
+
this.pageSize = options?.pageSize
|
13
|
+
}
|
14
|
+
|
15
|
+
get cursor(): string | undefined {
|
16
|
+
return this._cursor
|
17
|
+
}
|
18
|
+
|
19
|
+
set cursor(cursor: string | undefined) {
|
20
|
+
if (!cursor) {
|
21
|
+
this._done = true
|
22
|
+
}
|
23
|
+
this._cursor = cursor
|
24
|
+
}
|
25
|
+
|
26
|
+
get hasNext(): boolean {
|
27
|
+
return !this._done
|
28
|
+
}
|
29
|
+
}
|
package/src/store/index.ts
CHANGED
package/src/store/store.ts
CHANGED
@@ -6,6 +6,7 @@ import type { Entity as EntityStruct, RichValue } from '@sentio/protos'
|
|
6
6
|
import { DBRequest_DBOperator, DBResponse } from '@sentio/protos'
|
7
7
|
import { toBigInteger } from './convert.js'
|
8
8
|
import { PluginManager } from '@sentio/runtime'
|
9
|
+
import { Cursor } from './cursor.js'
|
9
10
|
|
10
11
|
type Value = ID | string | Int | Float | boolean | Timestamp | Bytes | BigDecimal | bigint
|
11
12
|
|
@@ -99,19 +100,7 @@ export class Store {
|
|
99
100
|
let cursor: string | undefined = undefined
|
100
101
|
|
101
102
|
while (true) {
|
102
|
-
const
|
103
|
-
list: {
|
104
|
-
entity: getEntityName(entity),
|
105
|
-
cursor,
|
106
|
-
filters:
|
107
|
-
filters?.map((f) => ({
|
108
|
-
field: f.field as string,
|
109
|
-
op: ops[f.op],
|
110
|
-
value: { values: Array.isArray(f.value) ? f.value.map((v) => serialize(v)) : [serialize(f.value)] }
|
111
|
-
})) || []
|
112
|
-
}
|
113
|
-
})
|
114
|
-
const response = (await promise) as DBResponse
|
103
|
+
const response: DBResponse = await this.listRequest(entity, filters || [], cursor)
|
115
104
|
for (const data of response.entityList?.entities || []) {
|
116
105
|
yield this.newEntity(entity, data)
|
117
106
|
}
|
@@ -122,7 +111,47 @@ export class Store {
|
|
122
111
|
}
|
123
112
|
}
|
124
113
|
|
125
|
-
async
|
114
|
+
async *listBatched<T extends Entity>(entity: EntityClass<T>, filters?: ListFilter<T>[], batchSize = 100) {
|
115
|
+
let cursor: string | undefined = undefined
|
116
|
+
|
117
|
+
while (true) {
|
118
|
+
const response: DBResponse = await this.listRequest(entity, filters || [], cursor, batchSize)
|
119
|
+
const entities = (response.entityList?.entities || []).map((data) => this.newEntity(entity, data))
|
120
|
+
yield entities
|
121
|
+
if (!response.nextCursor) {
|
122
|
+
break
|
123
|
+
}
|
124
|
+
cursor = response.nextCursor
|
125
|
+
}
|
126
|
+
}
|
127
|
+
|
128
|
+
private async listRequest<T extends Entity>(
|
129
|
+
entity: EntityClass<T>,
|
130
|
+
filters: ListFilter<T>[],
|
131
|
+
cursor: string | undefined,
|
132
|
+
pageSize?: number
|
133
|
+
): Promise<DBResponse> {
|
134
|
+
return (await this.context.sendRequest({
|
135
|
+
list: {
|
136
|
+
entity: getEntityName(entity),
|
137
|
+
cursor,
|
138
|
+
pageSize,
|
139
|
+
filters:
|
140
|
+
filters?.map((f) => ({
|
141
|
+
field: f.field as string,
|
142
|
+
op: ops[f.op],
|
143
|
+
value: { values: Array.isArray(f.value) ? f.value.map((v) => serialize(v)) : [serialize(f.value)] }
|
144
|
+
})) || []
|
145
|
+
}
|
146
|
+
})) as DBResponse
|
147
|
+
}
|
148
|
+
|
149
|
+
async list<T extends Entity>(entity: EntityClass<T>, filters?: ListFilter<T>[], cursor?: Cursor) {
|
150
|
+
if (cursor) {
|
151
|
+
const response = await this.listRequest(entity, filters || [], cursor.cursor, cursor.pageSize)
|
152
|
+
cursor.cursor = response.nextCursor
|
153
|
+
return response.entityList?.entities.map((data) => this.newEntity(entity, data)) || []
|
154
|
+
}
|
126
155
|
// TODO Array.fromAsync when upgrade to node 22
|
127
156
|
return this.fromAsync(this.listIterator(entity, filters))
|
128
157
|
}
|
@@ -162,10 +191,6 @@ export interface ListFilter<T extends Entity> {
|
|
162
191
|
value: Value | Value[] | null
|
163
192
|
}
|
164
193
|
|
165
|
-
export interface ListOptions<T extends Entity> {
|
166
|
-
cursor: string
|
167
|
-
}
|
168
|
-
|
169
194
|
const ops: Record<Operators, DBRequest_DBOperator> = {
|
170
195
|
'=': DBRequest_DBOperator.EQ,
|
171
196
|
'!=': DBRequest_DBOperator.NE,
|