@apibara/protocol 2.1.0-beta.5 → 2.1.0-beta.50
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 +45 -30
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +5 -5
- package/dist/index.d.mts +5 -5
- package/dist/index.d.ts +5 -5
- package/dist/index.mjs +41 -22
- package/dist/index.mjs.map +1 -0
- package/dist/rpc/index.cjs +12 -0
- package/dist/rpc/index.cjs.map +1 -0
- package/dist/rpc/index.d.cts +6 -0
- package/dist/rpc/index.d.mts +6 -0
- package/dist/rpc/index.d.ts +6 -0
- package/dist/rpc/index.mjs +3 -0
- package/dist/rpc/index.mjs.map +1 -0
- package/dist/shared/{protocol.4b1cfe2c.d.cts → protocol.0e734e33.d.cts} +400 -247
- package/dist/shared/{protocol.4b1cfe2c.d.mts → protocol.21e66b9e.d.mts} +400 -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.54f17699.cjs +536 -0
- package/dist/shared/protocol.54f17699.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.6ab8d6dd.d.mts +104 -0
- package/dist/shared/protocol.7aa4aab6.d.cts +104 -0
- package/dist/shared/protocol.8407f25e.d.ts +104 -0
- package/dist/shared/{protocol.4b1cfe2c.d.ts → protocol.8fb09325.d.ts} +400 -247
- package/dist/shared/protocol.bde61588.mjs +530 -0
- package/dist/shared/protocol.bde61588.mjs.map +1 -0
- 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 +14 -3
- package/src/client.ts +39 -14
- package/src/codec.ts +662 -0
- package/src/common.ts +70 -53
- package/src/config.ts +4 -4
- package/src/index.ts +2 -0
- package/src/proto/google/protobuf/duration.ts +8 -6
- package/src/proto/stream.ts +38 -24
- package/src/rpc/chain-tracker.ts +327 -0
- package/src/rpc/client.ts +51 -0
- package/src/rpc/config.ts +88 -0
- package/src/rpc/data-stream.ts +366 -0
- package/src/rpc/helpers.ts +9 -0
- package/src/rpc/index.ts +13 -0
- 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.50",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"files": [
|
|
6
6
|
"dist",
|
|
@@ -21,6 +21,18 @@
|
|
|
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"
|
|
30
|
+
},
|
|
31
|
+
"./rpc": {
|
|
32
|
+
"types": "./dist/rpc/index.d.ts",
|
|
33
|
+
"import": "./dist/rpc/index.mjs",
|
|
34
|
+
"require": "./dist/rpc/index.cjs",
|
|
35
|
+
"default": "./dist/rpc/index.mjs"
|
|
24
36
|
}
|
|
25
37
|
},
|
|
26
38
|
"scripts": {
|
|
@@ -41,8 +53,7 @@
|
|
|
41
53
|
"vitest": "^1.6.0"
|
|
42
54
|
},
|
|
43
55
|
"dependencies": {
|
|
44
|
-
"
|
|
45
|
-
"effect": "^3.2.6",
|
|
56
|
+
"consola": "^3.4.2",
|
|
46
57
|
"long": "^5.2.3",
|
|
47
58
|
"nice-grpc": "^2.1.8",
|
|
48
59
|
"nice-grpc-common": "^2.0.2",
|
package/src/client.ts
CHANGED
|
@@ -1,8 +1,11 @@
|
|
|
1
|
-
import
|
|
1
|
+
import assert from "node:assert";
|
|
2
|
+
|
|
3
|
+
import consola from "consola";
|
|
2
4
|
import {
|
|
3
5
|
type ChannelCredentials,
|
|
4
6
|
type ChannelOptions,
|
|
5
7
|
type DefaultCallOptions,
|
|
8
|
+
Metadata,
|
|
6
9
|
type NormalizedServiceDefinition,
|
|
7
10
|
createChannel,
|
|
8
11
|
createClient as grpcCreateClient,
|
|
@@ -10,18 +13,13 @@ import {
|
|
|
10
13
|
|
|
11
14
|
import * as proto from "./proto";
|
|
12
15
|
|
|
13
|
-
import
|
|
16
|
+
import type { Codec } from "./codec";
|
|
14
17
|
import type { Cursor } from "./common";
|
|
15
18
|
import type { StreamConfig } from "./config";
|
|
16
|
-
import {
|
|
17
|
-
type StatusRequest,
|
|
18
|
-
type StatusResponse,
|
|
19
|
-
statusRequestToProto,
|
|
20
|
-
statusResponseFromProto,
|
|
21
|
-
} from "./status";
|
|
19
|
+
import { StatusRequest, StatusResponse } from "./status";
|
|
22
20
|
import { type StreamDataRequest, StreamDataResponse } from "./stream";
|
|
23
21
|
|
|
24
|
-
export { ClientError, Status } from "nice-grpc";
|
|
22
|
+
export { ClientError, ServerError, Status, Metadata } from "nice-grpc";
|
|
25
23
|
|
|
26
24
|
const DEFAULT_TIMEOUT_MS = 45_000;
|
|
27
25
|
|
|
@@ -88,6 +86,33 @@ export function createClient<TFilter, TBlock>(
|
|
|
88
86
|
return new GrpcClient(config, client);
|
|
89
87
|
}
|
|
90
88
|
|
|
89
|
+
export function createAuthenticatedClient<TFilter, TBlock>(
|
|
90
|
+
config: StreamConfig<TFilter, TBlock>,
|
|
91
|
+
streamUrl: string,
|
|
92
|
+
options?: CreateClientOptions,
|
|
93
|
+
) {
|
|
94
|
+
const dnaToken = process.env.DNA_TOKEN;
|
|
95
|
+
if (!dnaToken) {
|
|
96
|
+
consola.warn(
|
|
97
|
+
"DNA_TOKEN environment variable is not set. Trying to connect without authentication.",
|
|
98
|
+
);
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
return createClient(config, streamUrl, {
|
|
102
|
+
...options,
|
|
103
|
+
defaultCallOptions: {
|
|
104
|
+
...(options?.defaultCallOptions ?? {}),
|
|
105
|
+
"*": {
|
|
106
|
+
metadata: Metadata({
|
|
107
|
+
Authorization: `Bearer ${dnaToken}`,
|
|
108
|
+
}),
|
|
109
|
+
// metadata cant be overrided with spread as its a class so we override it fully if user provided it.
|
|
110
|
+
...(options?.defaultCallOptions?.["*"] ?? {}),
|
|
111
|
+
},
|
|
112
|
+
},
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
|
|
91
116
|
export class GrpcClient<TFilter, TBlock> implements Client<TFilter, TBlock> {
|
|
92
117
|
private encodeRequest;
|
|
93
118
|
|
|
@@ -95,15 +120,15 @@ export class GrpcClient<TFilter, TBlock> implements Client<TFilter, TBlock> {
|
|
|
95
120
|
private config: StreamConfig<TFilter, TBlock>,
|
|
96
121
|
private client: proto.stream.DnaStreamClient,
|
|
97
122
|
) {
|
|
98
|
-
this.encodeRequest =
|
|
123
|
+
this.encodeRequest = config.Request.encode;
|
|
99
124
|
}
|
|
100
125
|
|
|
101
126
|
async status(request?: StatusRequest, options?: ClientCallOptions) {
|
|
102
127
|
const response = await this.client.status(
|
|
103
|
-
|
|
128
|
+
StatusRequest.encode(request ?? {}),
|
|
104
129
|
options,
|
|
105
130
|
);
|
|
106
|
-
return
|
|
131
|
+
return StatusResponse.decode(response);
|
|
107
132
|
}
|
|
108
133
|
|
|
109
134
|
streamData(request: StreamDataRequest<TFilter>, options?: StreamDataOptions) {
|
|
@@ -115,14 +140,14 @@ export class GrpcClient<TFilter, TBlock> implements Client<TFilter, TBlock> {
|
|
|
115
140
|
export class StreamDataIterable<TBlock> {
|
|
116
141
|
constructor(
|
|
117
142
|
private it: AsyncIterable<proto.stream.StreamDataResponse>,
|
|
118
|
-
private schema:
|
|
143
|
+
private schema: Codec<TBlock, Uint8Array>,
|
|
119
144
|
private options?: StreamDataOptions,
|
|
120
145
|
) {}
|
|
121
146
|
|
|
122
147
|
[Symbol.asyncIterator](): AsyncIterator<StreamDataResponse<TBlock>> {
|
|
123
148
|
const inner = this.it[Symbol.asyncIterator]();
|
|
124
149
|
const schema = StreamDataResponse(this.schema);
|
|
125
|
-
const decoder =
|
|
150
|
+
const decoder = schema.decode;
|
|
126
151
|
const { endingCursor, timeout = DEFAULT_TIMEOUT_MS } = this.options ?? {};
|
|
127
152
|
let shouldStop = false;
|
|
128
153
|
|