@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.
Files changed (65) hide show
  1. package/dist/codec.cjs +242 -0
  2. package/dist/codec.cjs.map +1 -0
  3. package/dist/codec.d.cts +81 -0
  4. package/dist/codec.d.mts +81 -0
  5. package/dist/codec.d.ts +81 -0
  6. package/dist/codec.mjs +224 -0
  7. package/dist/codec.mjs.map +1 -0
  8. package/dist/index.cjs +45 -30
  9. package/dist/index.cjs.map +1 -0
  10. package/dist/index.d.cts +5 -5
  11. package/dist/index.d.mts +5 -5
  12. package/dist/index.d.ts +5 -5
  13. package/dist/index.mjs +41 -22
  14. package/dist/index.mjs.map +1 -0
  15. package/dist/rpc/index.cjs +12 -0
  16. package/dist/rpc/index.cjs.map +1 -0
  17. package/dist/rpc/index.d.cts +6 -0
  18. package/dist/rpc/index.d.mts +6 -0
  19. package/dist/rpc/index.d.ts +6 -0
  20. package/dist/rpc/index.mjs +3 -0
  21. package/dist/rpc/index.mjs.map +1 -0
  22. package/dist/shared/{protocol.4b1cfe2c.d.cts → protocol.0e734e33.d.cts} +400 -247
  23. package/dist/shared/{protocol.4b1cfe2c.d.mts → protocol.21e66b9e.d.mts} +400 -247
  24. package/dist/shared/{protocol.e39e40d6.cjs → protocol.53f81a1e.cjs} +177 -177
  25. package/dist/shared/protocol.53f81a1e.cjs.map +1 -0
  26. package/dist/shared/protocol.54f17699.cjs +536 -0
  27. package/dist/shared/protocol.54f17699.cjs.map +1 -0
  28. package/dist/shared/{protocol.991ff9ad.mjs → protocol.68fdd897.mjs} +176 -171
  29. package/dist/shared/protocol.68fdd897.mjs.map +1 -0
  30. package/dist/shared/protocol.6ab8d6dd.d.mts +104 -0
  31. package/dist/shared/protocol.7aa4aab6.d.cts +104 -0
  32. package/dist/shared/protocol.8407f25e.d.ts +104 -0
  33. package/dist/shared/{protocol.4b1cfe2c.d.ts → protocol.8fb09325.d.ts} +400 -247
  34. package/dist/shared/protocol.bde61588.mjs +530 -0
  35. package/dist/shared/protocol.bde61588.mjs.map +1 -0
  36. package/dist/testing/index.cjs +26 -38
  37. package/dist/testing/index.cjs.map +1 -0
  38. package/dist/testing/index.d.cts +107 -54
  39. package/dist/testing/index.d.mts +107 -54
  40. package/dist/testing/index.d.ts +107 -54
  41. package/dist/testing/index.mjs +26 -38
  42. package/dist/testing/index.mjs.map +1 -0
  43. package/package.json +14 -3
  44. package/src/client.ts +39 -14
  45. package/src/codec.ts +662 -0
  46. package/src/common.ts +70 -53
  47. package/src/config.ts +4 -4
  48. package/src/index.ts +2 -0
  49. package/src/proto/google/protobuf/duration.ts +8 -6
  50. package/src/proto/stream.ts +38 -24
  51. package/src/rpc/chain-tracker.ts +327 -0
  52. package/src/rpc/client.ts +51 -0
  53. package/src/rpc/config.ts +88 -0
  54. package/src/rpc/data-stream.ts +366 -0
  55. package/src/rpc/helpers.ts +9 -0
  56. package/src/rpc/index.ts +13 -0
  57. package/src/status.ts +9 -16
  58. package/src/stream.ts +145 -144
  59. package/src/testing/mock.ts +36 -38
  60. package/src/common.test.ts +0 -67
  61. package/src/status.test.ts +0 -51
  62. package/src/stream.test-d.ts +0 -33
  63. package/src/stream.test.ts +0 -254
  64. package/src/testing/client.test.ts +0 -97
  65. package/src/testing/mock.test.ts +0 -35
@@ -1,7 +1,6 @@
1
- import { Schema } from '@effect/schema';
2
- import { M as MockFilter$1, u as MockBlock$1, r as StreamConfig, S as StreamDataResponse } from '../shared/protocol.991ff9ad.mjs';
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 = Schema.Struct({
43
- filter: Schema.optional(Schema.String)
41
+ const MockFilter = MessageCodec({
42
+ filter: OptionalCodec(StringCodec)
44
43
  });
45
- const MockFilterFromBytes = Schema.transform(
46
- Schema.Uint8ArrayFromSelf,
47
- MockFilter,
48
- {
49
- strict: false,
50
- decode(value) {
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 MockBlock = Schema.Struct({
59
- data: Schema.optional(Schema.String)
60
- });
61
- const MockBlockFromBytes = Schema.transform(
62
- Schema.Uint8ArrayFromSelf,
63
- Schema.NullOr(MockBlock),
64
- {
65
- strict: false,
66
- decode(value) {
67
- if (value.length === 0) {
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.5",
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
- "@effect/schema": "^0.67.15",
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 { Schema } from "@effect/schema";
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 assert from "node:assert";
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 = Schema.encodeSync(config.Request);
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
- statusRequestToProto(request ?? {}),
128
+ StatusRequest.encode(request ?? {}),
104
129
  options,
105
130
  );
106
- return statusResponseFromProto(response);
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: Schema.Schema<TBlock | null, Uint8Array, never>,
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 = Schema.decodeSync(schema);
150
+ const decoder = schema.decode;
126
151
  const { endingCursor, timeout = DEFAULT_TIMEOUT_MS } = this.options ?? {};
127
152
  let shouldStop = false;
128
153