@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.
Files changed (44) 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 +18 -29
  9. package/dist/index.cjs.map +1 -0
  10. package/dist/index.d.cts +4 -5
  11. package/dist/index.d.mts +4 -5
  12. package/dist/index.d.ts +4 -5
  13. package/dist/index.mjs +16 -20
  14. package/dist/index.mjs.map +1 -0
  15. package/dist/shared/{protocol.4b1cfe2c.d.cts → protocol.21b07506.d.mts} +399 -247
  16. package/dist/shared/{protocol.4b1cfe2c.d.mts → protocol.526c6532.d.ts} +399 -247
  17. package/dist/shared/{protocol.e39e40d6.cjs → protocol.53f81a1e.cjs} +177 -177
  18. package/dist/shared/protocol.53f81a1e.cjs.map +1 -0
  19. package/dist/shared/{protocol.991ff9ad.mjs → protocol.68fdd897.mjs} +176 -171
  20. package/dist/shared/protocol.68fdd897.mjs.map +1 -0
  21. package/dist/shared/{protocol.4b1cfe2c.d.ts → protocol.a5762a90.d.cts} +399 -247
  22. package/dist/testing/index.cjs +26 -38
  23. package/dist/testing/index.cjs.map +1 -0
  24. package/dist/testing/index.d.cts +107 -54
  25. package/dist/testing/index.d.mts +107 -54
  26. package/dist/testing/index.d.ts +107 -54
  27. package/dist/testing/index.mjs +26 -38
  28. package/dist/testing/index.mjs.map +1 -0
  29. package/package.json +7 -3
  30. package/src/client.ts +8 -13
  31. package/src/codec.ts +662 -0
  32. package/src/common.ts +70 -53
  33. package/src/config.ts +4 -4
  34. package/src/proto/google/protobuf/duration.ts +8 -6
  35. package/src/proto/stream.ts +38 -24
  36. package/src/status.ts +9 -16
  37. package/src/stream.ts +145 -144
  38. package/src/testing/mock.ts +36 -38
  39. package/src/common.test.ts +0 -67
  40. package/src/status.test.ts +0 -51
  41. package/src/stream.test-d.ts +0 -33
  42. package/src/stream.test.ts +0 -254
  43. package/src/testing/client.test.ts +0 -97
  44. 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.3",
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 = Schema.encodeSync(config.Request);
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
- statusRequestToProto(request ?? {}),
98
+ StatusRequest.encode(request ?? {}),
104
99
  options,
105
100
  );
106
- return statusResponseFromProto(response);
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: Schema.Schema<TBlock | null, Uint8Array, never>,
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 = Schema.decodeSync(schema);
120
+ const decoder = schema.decode;
126
121
  const { endingCursor, timeout = DEFAULT_TIMEOUT_MS } = this.options ?? {};
127
122
  let shouldStop = false;
128
123