@apibara/protocol 2.1.0-beta.3 → 2.1.0-beta.31
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/codec.cjs +242 -0
- package/dist/codec.cjs.map +1 -0
- package/dist/codec.d.cts +81 -0
- package/dist/codec.d.mts +81 -0
- package/dist/codec.d.ts +81 -0
- package/dist/codec.mjs +224 -0
- package/dist/codec.mjs.map +1 -0
- package/dist/index.cjs +18 -29
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +4 -5
- package/dist/index.d.mts +4 -5
- package/dist/index.d.ts +4 -5
- package/dist/index.mjs +16 -20
- package/dist/index.mjs.map +1 -0
- package/dist/shared/{protocol.4b1cfe2c.d.cts → protocol.21b07506.d.mts} +399 -247
- package/dist/shared/{protocol.4b1cfe2c.d.mts → protocol.526c6532.d.ts} +399 -247
- package/dist/shared/{protocol.e39e40d6.cjs → protocol.53f81a1e.cjs} +177 -177
- package/dist/shared/protocol.53f81a1e.cjs.map +1 -0
- package/dist/shared/{protocol.991ff9ad.mjs → protocol.68fdd897.mjs} +176 -171
- package/dist/shared/protocol.68fdd897.mjs.map +1 -0
- package/dist/shared/{protocol.4b1cfe2c.d.ts → protocol.a5762a90.d.cts} +399 -247
- package/dist/testing/index.cjs +26 -38
- package/dist/testing/index.cjs.map +1 -0
- package/dist/testing/index.d.cts +107 -54
- package/dist/testing/index.d.mts +107 -54
- package/dist/testing/index.d.ts +107 -54
- package/dist/testing/index.mjs +26 -38
- package/dist/testing/index.mjs.map +1 -0
- package/package.json +7 -3
- package/src/client.ts +8 -13
- package/src/codec.ts +662 -0
- package/src/common.ts +70 -53
- package/src/config.ts +4 -4
- package/src/proto/google/protobuf/duration.ts +8 -6
- package/src/proto/stream.ts +38 -24
- package/src/status.ts +9 -16
- package/src/stream.ts +145 -144
- package/src/testing/mock.ts +36 -38
- package/src/common.test.ts +0 -67
- package/src/status.test.ts +0 -51
- package/src/stream.test-d.ts +0 -33
- package/src/stream.test.ts +0 -254
- package/src/testing/client.test.ts +0 -97
- package/src/testing/mock.test.ts +0 -35
package/dist/testing/index.mjs
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { MessageCodec, OptionalCodec, StringCodec } from '../codec.mjs';
|
|
2
|
+
import { l as StreamConfig, M as MockFilter$1, m as MockBlock, S as StreamDataResponse } from '../shared/protocol.68fdd897.mjs';
|
|
3
3
|
import 'protobufjs/minimal.js';
|
|
4
|
-
import 'effect';
|
|
5
4
|
import 'viem';
|
|
6
5
|
import 'long';
|
|
7
6
|
|
|
@@ -39,44 +38,31 @@ class StreamDataIterable {
|
|
|
39
38
|
}
|
|
40
39
|
}
|
|
41
40
|
|
|
42
|
-
const MockFilter =
|
|
43
|
-
filter:
|
|
41
|
+
const MockFilter = MessageCodec({
|
|
42
|
+
filter: OptionalCodec(StringCodec)
|
|
44
43
|
});
|
|
45
|
-
const MockFilterFromBytes =
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
return MockFilter$1.decode(value);
|
|
52
|
-
},
|
|
53
|
-
encode(value) {
|
|
54
|
-
return MockFilter$1.encode(value).finish();
|
|
55
|
-
}
|
|
44
|
+
const MockFilterFromBytes = {
|
|
45
|
+
decode(value) {
|
|
46
|
+
return MockFilter$1.decode(value);
|
|
47
|
+
},
|
|
48
|
+
encode(value) {
|
|
49
|
+
return MockFilter$1.encode(value).finish();
|
|
56
50
|
}
|
|
57
|
-
|
|
58
|
-
const
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
return null;
|
|
69
|
-
}
|
|
70
|
-
return MockBlock$1.decode(value);
|
|
71
|
-
},
|
|
72
|
-
encode(value) {
|
|
73
|
-
if (value === null) {
|
|
74
|
-
return new Uint8Array();
|
|
75
|
-
}
|
|
76
|
-
return MockBlock$1.encode(value).finish();
|
|
51
|
+
};
|
|
52
|
+
const MockBlockFromBytes = {
|
|
53
|
+
decode(value) {
|
|
54
|
+
if (value.length === 0) {
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
return MockBlock.decode(value);
|
|
58
|
+
},
|
|
59
|
+
encode(value) {
|
|
60
|
+
if (value === null) {
|
|
61
|
+
return new Uint8Array();
|
|
77
62
|
}
|
|
63
|
+
return MockBlock.encode(value).finish();
|
|
78
64
|
}
|
|
79
|
-
|
|
65
|
+
};
|
|
80
66
|
function mergeMockFilter(a, b) {
|
|
81
67
|
let filter = "";
|
|
82
68
|
if (a.filter) {
|
|
@@ -90,8 +76,10 @@ function mergeMockFilter(a, b) {
|
|
|
90
76
|
const MockStream = new StreamConfig(
|
|
91
77
|
MockFilterFromBytes,
|
|
92
78
|
MockBlockFromBytes,
|
|
93
|
-
mergeMockFilter
|
|
79
|
+
mergeMockFilter,
|
|
80
|
+
"mock"
|
|
94
81
|
);
|
|
95
82
|
const MockStreamResponse = StreamDataResponse(MockBlockFromBytes);
|
|
96
83
|
|
|
97
84
|
export { MockBlockFromBytes, MockClient, MockFilter, MockFilterFromBytes, MockStream, MockStreamResponse, StreamDataIterable };
|
|
85
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../src/testing/client.ts","../../src/testing/mock.ts"],"sourcesContent":["import type { Client, ClientCallOptions, StreamDataOptions } from \"../client\";\nimport type { StatusRequest, StatusResponse } from \"../status\";\nimport type { StreamDataRequest, StreamDataResponse } from \"../stream\";\n\nexport class MockClient<TFilter, TBlock> implements Client<TFilter, TBlock> {\n constructor(\n private messageFactory: (\n request: StreamDataRequest<TFilter>,\n options?: StreamDataOptions,\n ) => (StreamDataResponse<TBlock> | Error)[],\n ) {}\n\n async status(\n request?: StatusRequest,\n options?: ClientCallOptions,\n ): Promise<StatusResponse> {\n throw new Error(\"Client.status is not implemented for VcrClient\");\n }\n\n streamData(request: StreamDataRequest<TFilter>, options?: StreamDataOptions) {\n const messages = this.messageFactory(request, options);\n\n return new StreamDataIterable(messages);\n }\n}\n\nexport class StreamDataIterable<TBlock> {\n constructor(private messages: (StreamDataResponse<TBlock> | Error)[]) {}\n\n [Symbol.asyncIterator](): AsyncIterator<StreamDataResponse<TBlock>> {\n let index = 0;\n const messages = this.messages;\n\n return {\n async next() {\n if (index >= messages.length) {\n return { done: true, value: undefined };\n }\n\n const message = messages[index++];\n if (message instanceof Error) {\n throw message;\n }\n\n return { done: false, value: message };\n },\n };\n }\n}\n","import {\n type Codec,\n type CodecType,\n MessageCodec,\n OptionalCodec,\n StringCodec,\n} from \"../codec\";\nimport { StreamConfig } from \"../config\";\nimport * as proto from \"../proto\";\nimport { StreamDataResponse } from \"../stream\";\n\nexport const MockFilter = MessageCodec({\n filter: OptionalCodec(StringCodec),\n});\n\nexport type MockFilter = CodecType<typeof MockFilter>;\n\nexport const MockFilterFromBytes: Codec<MockFilter, Uint8Array> = {\n decode(value) {\n return proto.testing.MockFilter.decode(value);\n },\n encode(value) {\n return proto.testing.MockFilter.encode(value).finish();\n },\n};\n\nconst MockBlock = MessageCodec({\n data: OptionalCodec(StringCodec),\n});\n\nexport type MockBlock = CodecType<typeof MockBlock>;\n\nexport const MockBlockFromBytes: Codec<MockBlock | null, Uint8Array> = {\n decode(value) {\n if (value.length === 0) {\n return null;\n }\n return proto.testing.MockBlock.decode(value);\n },\n encode(value) {\n if (value === null) {\n return new Uint8Array();\n }\n return proto.testing.MockBlock.encode(value).finish();\n },\n};\n\n/** For testing, simply concatenate the values of `.filter` */\nfunction mergeMockFilter(a: MockFilter, b: MockFilter): MockFilter {\n let filter = \"\";\n if (a.filter) {\n filter += a.filter;\n }\n if (b.filter) {\n filter += b.filter;\n }\n return { filter };\n}\n\nexport const MockStream = new StreamConfig(\n MockFilterFromBytes,\n MockBlockFromBytes,\n mergeMockFilter,\n \"mock\",\n);\n\nexport const MockStreamResponse = StreamDataResponse(MockBlockFromBytes);\n\nexport type MockStreamResponse = CodecType<typeof MockStreamResponse>;\n"],"names":["proto.testing.MockFilter","proto.testing.MockBlock"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@apibara/protocol",
|
|
3
|
-
"version": "2.1.0-beta.
|
|
3
|
+
"version": "2.1.0-beta.31",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"files": [
|
|
6
6
|
"dist",
|
|
@@ -21,6 +21,12 @@
|
|
|
21
21
|
"import": "./dist/testing/index.mjs",
|
|
22
22
|
"require": "./dist/testing/index.cjs",
|
|
23
23
|
"default": "./dist/testing/index.mjs"
|
|
24
|
+
},
|
|
25
|
+
"./codec": {
|
|
26
|
+
"types": "./dist/codec.d.ts",
|
|
27
|
+
"import": "./dist/codec.mjs",
|
|
28
|
+
"require": "./dist/codec.cjs",
|
|
29
|
+
"default": "./dist/codec.mjs"
|
|
24
30
|
}
|
|
25
31
|
},
|
|
26
32
|
"scripts": {
|
|
@@ -41,8 +47,6 @@
|
|
|
41
47
|
"vitest": "^1.6.0"
|
|
42
48
|
},
|
|
43
49
|
"dependencies": {
|
|
44
|
-
"@effect/schema": "^0.67.15",
|
|
45
|
-
"effect": "^3.2.6",
|
|
46
50
|
"long": "^5.2.3",
|
|
47
51
|
"nice-grpc": "^2.1.8",
|
|
48
52
|
"nice-grpc-common": "^2.0.2",
|
package/src/client.ts
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { Schema } from "@effect/schema";
|
|
2
1
|
import {
|
|
3
2
|
type ChannelCredentials,
|
|
4
3
|
type ChannelOptions,
|
|
@@ -11,17 +10,13 @@ import {
|
|
|
11
10
|
import * as proto from "./proto";
|
|
12
11
|
|
|
13
12
|
import assert from "node:assert";
|
|
13
|
+
import type { Codec } from "./codec";
|
|
14
14
|
import type { Cursor } from "./common";
|
|
15
15
|
import type { StreamConfig } from "./config";
|
|
16
|
-
import {
|
|
17
|
-
type StatusRequest,
|
|
18
|
-
type StatusResponse,
|
|
19
|
-
statusRequestToProto,
|
|
20
|
-
statusResponseFromProto,
|
|
21
|
-
} from "./status";
|
|
16
|
+
import { StatusRequest, StatusResponse } from "./status";
|
|
22
17
|
import { type StreamDataRequest, StreamDataResponse } from "./stream";
|
|
23
18
|
|
|
24
|
-
export { ClientError, Status } from "nice-grpc";
|
|
19
|
+
export { ClientError, ServerError, Status, Metadata } from "nice-grpc";
|
|
25
20
|
|
|
26
21
|
const DEFAULT_TIMEOUT_MS = 45_000;
|
|
27
22
|
|
|
@@ -95,15 +90,15 @@ export class GrpcClient<TFilter, TBlock> implements Client<TFilter, TBlock> {
|
|
|
95
90
|
private config: StreamConfig<TFilter, TBlock>,
|
|
96
91
|
private client: proto.stream.DnaStreamClient,
|
|
97
92
|
) {
|
|
98
|
-
this.encodeRequest =
|
|
93
|
+
this.encodeRequest = config.Request.encode;
|
|
99
94
|
}
|
|
100
95
|
|
|
101
96
|
async status(request?: StatusRequest, options?: ClientCallOptions) {
|
|
102
97
|
const response = await this.client.status(
|
|
103
|
-
|
|
98
|
+
StatusRequest.encode(request ?? {}),
|
|
104
99
|
options,
|
|
105
100
|
);
|
|
106
|
-
return
|
|
101
|
+
return StatusResponse.decode(response);
|
|
107
102
|
}
|
|
108
103
|
|
|
109
104
|
streamData(request: StreamDataRequest<TFilter>, options?: StreamDataOptions) {
|
|
@@ -115,14 +110,14 @@ export class GrpcClient<TFilter, TBlock> implements Client<TFilter, TBlock> {
|
|
|
115
110
|
export class StreamDataIterable<TBlock> {
|
|
116
111
|
constructor(
|
|
117
112
|
private it: AsyncIterable<proto.stream.StreamDataResponse>,
|
|
118
|
-
private schema:
|
|
113
|
+
private schema: Codec<TBlock, Uint8Array>,
|
|
119
114
|
private options?: StreamDataOptions,
|
|
120
115
|
) {}
|
|
121
116
|
|
|
122
117
|
[Symbol.asyncIterator](): AsyncIterator<StreamDataResponse<TBlock>> {
|
|
123
118
|
const inner = this.it[Symbol.asyncIterator]();
|
|
124
119
|
const schema = StreamDataResponse(this.schema);
|
|
125
|
-
const decoder =
|
|
120
|
+
const decoder = schema.decode;
|
|
126
121
|
const { endingCursor, timeout = DEFAULT_TIMEOUT_MS } = this.options ?? {};
|
|
127
122
|
let shouldStop = false;
|
|
128
123
|
|