@typeberry/lib 0.5.3-fb6e98a → 0.5.4-9233977
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/package.json +1 -1
- package/packages/core/networking/certificate.d.ts.map +1 -1
- package/packages/core/networking/certificate.js +1 -0
- package/packages/core/networking/package.json +1 -1
- package/packages/core/networking/setup.d.ts.map +1 -1
- package/packages/core/networking/setup.js +16 -12
- package/packages/core/telemetry/package.json +1 -1
- package/packages/extensions/ipc/jamnp/handler.d.ts +5 -4
- package/packages/extensions/ipc/jamnp/handler.d.ts.map +1 -1
- package/packages/extensions/ipc/jamnp/handler.js +59 -34
- package/packages/extensions/ipc/jamnp/stream.d.ts +6 -4
- package/packages/extensions/ipc/jamnp/stream.d.ts.map +1 -1
- package/packages/jam/block/work-package.d.ts +3 -1
- package/packages/jam/block/work-package.d.ts.map +1 -1
- package/packages/jam/block/work-package.js +6 -2
- package/packages/jam/block-json/block.d.ts +125 -0
- package/packages/jam/block-json/block.d.ts.map +1 -1
- package/packages/jam/block-json/block.js +9 -2
- package/packages/jam/fuzz-proto/v1/handler.d.ts +1 -1
- package/packages/jam/fuzz-proto/v1/handler.d.ts.map +1 -1
- package/packages/jam/fuzz-proto/v1/handler.js +43 -19
- package/packages/jam/jamnp-s/peers.d.ts.map +1 -1
- package/packages/jam/jamnp-s/peers.js +10 -0
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.d.ts +1 -1
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-128-block-request.js +10 -8
- package/packages/jam/jamnp-s/protocol/ce-129-state-request.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-129-state-request.js +11 -9
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.d.ts +3 -3
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-131-ce-132-safrole-ticket-distribution.js +2 -2
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.d.ts +2 -2
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-133-work-package-submission.js +2 -2
- package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-134-work-package-sharing.js +8 -6
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.d.ts +3 -3
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/ce-135-work-report-distribution.js +2 -2
- package/packages/jam/jamnp-s/protocol/stream.d.ts +13 -7
- package/packages/jam/jamnp-s/protocol/stream.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/stream.js +5 -4
- package/packages/jam/jamnp-s/protocol/test-utils.d.ts +1 -1
- package/packages/jam/jamnp-s/protocol/test-utils.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/test-utils.js +9 -12
- package/packages/jam/jamnp-s/protocol/up-0-block-announcement.d.ts +1 -1
- package/packages/jam/jamnp-s/protocol/up-0-block-announcement.d.ts.map +1 -1
- package/packages/jam/jamnp-s/protocol/up-0-block-announcement.js +1 -1
- package/packages/jam/jamnp-s/stream-manager.d.ts.map +1 -1
- package/packages/jam/jamnp-s/stream-manager.js +7 -5
- package/packages/jam/jamnp-s/stream-manager.test.js +8 -5
- package/packages/jam/jamnp-s/tasks/sync.js +1 -1
- package/packages/jam/node/jam-config.d.ts +4 -1
- package/packages/jam/node/jam-config.d.ts.map +1 -1
- package/packages/jam/node/jam-config.js +6 -2
- package/packages/jam/node/main.d.ts.map +1 -1
- package/packages/jam/node/main.js +5 -4
- package/packages/jam/node/package.json +1 -1
- package/packages/jam/state-vectors/index.d.ts +377 -5
- package/packages/jam/state-vectors/index.d.ts.map +1 -1
- package/packages/jam/state-vectors/index.js +3 -3
- package/packages/jam/transition/reports/error.d.ts +3 -1
- package/packages/jam/transition/reports/error.d.ts.map +1 -1
- package/packages/jam/transition/reports/error.js +2 -0
- package/packages/jam/transition/reports/verify-basic.d.ts.map +1 -1
- package/packages/jam/transition/reports/verify-basic.js +10 -0
- package/packages/jam/transition/reports/verify-basic.test.js +29 -0
- package/packages/workers/block-authorship/main.d.ts.map +1 -1
- package/packages/workers/block-authorship/main.js +23 -4
- package/packages/workers/block-authorship/package.json +1 -1
- package/packages/workers/block-authorship/protocol.d.ts +3 -1
- package/packages/workers/block-authorship/protocol.d.ts.map +1 -1
- package/packages/workers/block-authorship/protocol.js +6 -3
- package/packages/workers/importer/importer.d.ts.map +1 -1
- package/packages/workers/importer/importer.js +0 -1
- package/packages/workers/importer/package.json +1 -1
package/package.json
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"certificate.d.ts","sourceRoot":"","sources":["../../../../../packages/core/networking/certificate.ts"],"names":[],"mappings":"AAAA,OAAe,EAAE,KAAK,UAAU,EAAE,MAAM,aAAa,CAAC;AAGtD,OAAO,KAAK,IAAI,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAS,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAqB,KAAK,UAAU,EAAE,KAAK,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAErF,OAAO,EAAgB,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAExD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAezC,oBAAY,eAAe;IACzB,aAAa,IAAI;IACjB,UAAU,IAAI;IACd,qBAAqB,IAAI;IACzB,eAAe,IAAI;IACnB,kBAAkB,IAAI;CACvB;AAED,MAAM,MAAM,QAAQ,GAAG;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,GAAG,EAAE,UAAU,CAAC;CACjB,CAAC;AAEF,wBAAsB,iBAAiB,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"certificate.d.ts","sourceRoot":"","sources":["../../../../../packages/core/networking/certificate.ts"],"names":[],"mappings":"AAAA,OAAe,EAAE,KAAK,UAAU,EAAE,MAAM,aAAa,CAAC;AAGtD,OAAO,KAAK,IAAI,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAS,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAqB,KAAK,UAAU,EAAE,KAAK,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAErF,OAAO,EAAgB,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAExD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,YAAY,CAAC;AAezC,oBAAY,eAAe;IACzB,aAAa,IAAI;IACjB,UAAU,IAAI;IACd,qBAAqB,IAAI;IACzB,eAAe,IAAI;IACnB,kBAAkB,IAAI;CACvB;AAED,MAAM,MAAM,QAAQ,GAAG;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,GAAG,EAAE,UAAU,CAAC;CACjB,CAAC;AAEF,wBAAsB,iBAAiB,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC,CAyDvG;AAED,wBAAsB,sBAAsB,IAAI,OAAO,CAAC;IACtD,SAAS,EAAE,UAAU,CAAC;IACtB,UAAU,EAAE,UAAU,CAAC;CACxB,CAAC,CAcD;AAED,wBAAsB,eAAe,CAAC,OAAO,EAAE,cAAc,mBAQ5D;AAED,wFAAwF;AACxF,wBAAsB,mBAAmB,CAAC,EACxC,MAAM,EACN,cAAc,EACd,aAAa,EACb,iBAAsB,EACtB,gBAAqB,EACrB,GAAgB,GACjB,EAAE;IACD,MAAM,EAAE,SAAS,CAAC;IAClB,cAAc,EAAE,cAAc,CAAC;IAC/B,aAAa,EAAE,cAAc,CAAC;IAC9B,iBAAiB,CAAC,EAAE,KAAK,CAAC;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;KAAE,CAAC,CAAC;IACvD,gBAAgB,CAAC,EAAE,KAAK,CAAC;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;KAAE,CAAC,CAAC;IACtD,GAAG,CAAC,EAAE,IAAI,CAAC;CACZ,GAAG,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,CA6EhC;AAED,wBAAgB,UAAU,CAAC,aAAa,EAAE,SAAS,UAElD;AACD,wBAAgB,UAAU,CAAC,aAAa,EAAE,UAAU,UAGnD;AA4BD,wBAAgB,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,eAAe,UAEnD;AAED,MAAM,MAAM,cAAc,GAAG;IAC3B,SAAS,EAAE,UAAU,CAAC;IACtB,UAAU,EAAE,UAAU,CAAC;CACxB,CAAC;AAEF,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,OAAO,CAAC,WAAW,GAAG,cAAc,CAkBpF"}
|
|
@@ -54,6 +54,7 @@ export async function verifyCertificate(certs) {
|
|
|
54
54
|
}
|
|
55
55
|
const key = Buffer.from(jwk.x ?? "", "base64url");
|
|
56
56
|
if (!xc.verify(xc.publicKey)) {
|
|
57
|
+
logger.log `Certificate validation failed: incorrect signature`;
|
|
57
58
|
return Result.error(VerifyCertError.IncorrectSignature, () => "Certificate validation failed: incorrect signature");
|
|
58
59
|
}
|
|
59
60
|
const publicKey = Bytes.fromBlob(new Uint8Array(key), ED25519_KEY_BYTES);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../../../../../packages/core/networking/setup.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;
|
|
1
|
+
{"version":3,"file":"setup.d.ts","sourceRoot":"","sources":["../../../../../packages/core/networking/setup.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAiBhE,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAMhD,sCAAsC;AACtC,MAAM,MAAM,OAAO,GAAG;IACpB,yBAAyB;IACzB,GAAG,EAAE,WAAW,CAAC;IACjB,kCAAkC;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,6CAA6C;IAC7C,IAAI,EAAE,MAAM,CAAC;IACb,iFAAiF;IACjF,SAAS,EAAE,MAAM,EAAE,CAAC;CACrB,CAAC;AAQF,qBAAa,IAAI;IACf,6DAA6D;WAChD,KAAK,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,GAAG,EAAE,EAAE,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC;CAsKlF"}
|
|
@@ -3,7 +3,7 @@ import { events, QUICClient, QUICServer, QUICSocket } from "@matrixai/quic";
|
|
|
3
3
|
import { BytesBlob } from "#@typeberry/bytes";
|
|
4
4
|
import { Level, Logger } from "#@typeberry/logger";
|
|
5
5
|
import { now } from "#@typeberry/utils";
|
|
6
|
-
import { altNameRaw, certToPEM, ed25519AsJsonWebKeyPair, generateCertificate, privateKeyToPEM, } from "./certificate.js";
|
|
6
|
+
import { altNameRaw, certToPEM, ed25519AsJsonWebKeyPair, generateCertificate, privateKeyToPEM, verifyCertificate, } from "./certificate.js";
|
|
7
7
|
import { getQuicClientCrypto, getQuicServerCrypto } from "./crypto.js";
|
|
8
8
|
import * as metrics from "./metrics.js";
|
|
9
9
|
import { peerVerification } from "./peer-verification.js";
|
|
@@ -34,7 +34,6 @@ export class Quic {
|
|
|
34
34
|
subjectKeyPair: keyPair,
|
|
35
35
|
issuerKeyPair: keyPair,
|
|
36
36
|
});
|
|
37
|
-
const lastConnectedPeer = peerVerification();
|
|
38
37
|
// QUICConfig
|
|
39
38
|
const config = {
|
|
40
39
|
keepAliveIntervalTime: 3000,
|
|
@@ -43,7 +42,9 @@ export class Quic {
|
|
|
43
42
|
cert: certToPEM(cert),
|
|
44
43
|
key: privKeyPEM,
|
|
45
44
|
verifyPeer: true,
|
|
46
|
-
|
|
45
|
+
// Server accepts TLS and verifies the certificate in the connection handler
|
|
46
|
+
// (EventQUICServerConnection). Client overrides this with peerVerification() per dial.
|
|
47
|
+
verifyCallback: async () => undefined,
|
|
47
48
|
};
|
|
48
49
|
logger.info `🆔 Peer id: ** ${altNameRaw(key.pubKey)}@${host}:${port} ** (pubkey: ${key.pubKey})`;
|
|
49
50
|
// Shared injected UDP socket
|
|
@@ -67,27 +68,30 @@ export class Quic {
|
|
|
67
68
|
const conn = ev.detail;
|
|
68
69
|
const peerAddress = `${conn.remoteHost}:${conn.remotePort}`;
|
|
69
70
|
networkMetrics.recordConnectingIn(peerAddress);
|
|
70
|
-
|
|
71
|
-
|
|
71
|
+
// Verify the peer's certificate and extract peer info.
|
|
72
|
+
const remoteCerts = conn.getRemoteCertsChain();
|
|
73
|
+
const verification = await verifyCertificate(remoteCerts);
|
|
74
|
+
if (verification.isError) {
|
|
75
|
+
networkMetrics.recordConnectInFailed("cert_verification_failed");
|
|
72
76
|
await conn.stop();
|
|
73
77
|
return;
|
|
74
78
|
}
|
|
75
|
-
|
|
79
|
+
const peerInfo = verification.ok;
|
|
80
|
+
if (peerInfo.key.isEqualTo(key.pubKey)) {
|
|
76
81
|
logger.log `🛜 Rejecting connection from ourself from ${conn.remoteHost}:${conn.remotePort}`;
|
|
77
82
|
networkMetrics.recordConnectionRefused(peerAddress);
|
|
78
83
|
await conn.stop({ isApp: true, errorCode: CloseReason.ConnectionFromOurself });
|
|
79
84
|
return;
|
|
80
85
|
}
|
|
81
|
-
if (peers.isConnected(
|
|
82
|
-
logger.log `🛜 Rejecting duplicate connection with peer ${
|
|
86
|
+
if (peers.isConnected(peerInfo.id)) {
|
|
87
|
+
logger.log `🛜 Rejecting duplicate connection with peer ${peerInfo.id} from ${conn.remoteHost}:${conn.remotePort}`;
|
|
83
88
|
networkMetrics.recordConnectionRefused(peerAddress);
|
|
84
|
-
await conn.stop({ isApp: true, errorCode: CloseReason.DuplicateConnection });
|
|
89
|
+
await conn.stop({ isApp: true, errorCode: CloseReason.DuplicateConnection, force: false });
|
|
85
90
|
return;
|
|
86
91
|
}
|
|
87
92
|
logger.log `🛜 Server handshake with ${conn.remoteHost}:${conn.remotePort}`;
|
|
88
|
-
newPeer(conn,
|
|
89
|
-
networkMetrics.recordConnectedIn(
|
|
90
|
-
lastConnectedPeer.info = null;
|
|
93
|
+
newPeer(conn, peerInfo, "in");
|
|
94
|
+
networkMetrics.recordConnectedIn(peerInfo.id);
|
|
91
95
|
await conn.start();
|
|
92
96
|
});
|
|
93
97
|
// connecting to a peer
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { BytesBlob } from "#@typeberry/bytes";
|
|
2
2
|
import type { IpcHandler } from "#@typeberry/fuzz-proto";
|
|
3
|
-
import type
|
|
3
|
+
import { type StreamHandler, type StreamId, type StreamKindOf, type StreamMessageSender } from "#@typeberry/jamnp-s";
|
|
4
4
|
import type { IpcSender } from "../server.js";
|
|
5
|
-
import { NewStream } from "./stream.js";
|
|
5
|
+
import { type IpcStreamId, NewStream } from "./stream.js";
|
|
6
6
|
export type ResponseHandler = (err: Error | null, response?: BytesBlob) => void;
|
|
7
7
|
export declare class JamnpIpcHandler implements IpcHandler {
|
|
8
8
|
private readonly sender;
|
|
@@ -31,9 +31,10 @@ export declare class JamnpIpcHandler implements IpcHandler {
|
|
|
31
31
|
waitForEnd(): Promise<void>;
|
|
32
32
|
}
|
|
33
33
|
declare class EnvelopeSender implements StreamMessageSender {
|
|
34
|
-
readonly
|
|
34
|
+
private readonly ipcStreamId;
|
|
35
35
|
private readonly sender;
|
|
36
|
-
|
|
36
|
+
readonly streamId: StreamId;
|
|
37
|
+
constructor(ipcStreamId: IpcStreamId, sender: IpcSender);
|
|
37
38
|
open(newStream: NewStream): void;
|
|
38
39
|
bufferAndSend(msg: BytesBlob): boolean;
|
|
39
40
|
close(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../../../../../packages/extensions/ipc/jamnp/handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../../../../../packages/extensions/ipc/jamnp/handler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EACL,KAAK,aAAa,EAClB,KAAK,QAAQ,EAEb,KAAK,YAAY,EACjB,KAAK,mBAAmB,EAEzB,MAAM,oBAAoB,CAAC;AAI5B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,KAAK,WAAW,EAAE,SAAS,EAAsC,MAAM,aAAa,CAAC;AAS9F,MAAM,MAAM,eAAe,GAAG,CAAC,GAAG,EAAE,KAAK,GAAG,IAAI,EAAE,QAAQ,CAAC,EAAE,SAAS,KAAK,IAAI,CAAC;AAWhF,qBAAa,eAAgB,YAAW,UAAU;IAUpC,OAAO,CAAC,QAAQ,CAAC,MAAM;IATnC,gCAAgC;IAChC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA8C;IACtE,yDAAyD;IACzD,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAwC;IACvE,0DAA0D;IAC1D,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA6C;IAC5E,sCAAsC;IACtC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAQ;gBAED,MAAM,EAAE,SAAS;IAe9C,gCAAgC;IAChC,sBAAsB,CAAC,GAAG,QAAQ,EAAE,aAAa,EAAE;IAMnD,0DAA0D;IAC1D,gBAAgB,CAAC,QAAQ,SAAS,aAAa,EAC7C,UAAU,EAAE,YAAY,CAAC,QAAQ,CAAC,EAClC,IAAI,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,cAAc,KAAK,IAAI,GACxD,IAAI;IAWP,uCAAuC;IACvC,aAAa,CAAC,QAAQ,SAAS,aAAa,EAC1C,IAAI,EAAE,YAAY,CAAC,QAAQ,CAAC,EAC5B,IAAI,EAAE,CAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,cAAc,KAAK,IAAI,GACxD,IAAI;IA2BP,8CAA8C;IACxC,eAAe,CAAC,GAAG,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IAmErD,yDAAyD;IACzD,OAAO,CAAC,EAAE,KAAK,EAAE,EAAE;QAAE,KAAK,CAAC,EAAE,KAAK,CAAA;KAAE;IAkBpC,qEAAqE;IACrE,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;CAI5B;AAED,cAAM,cAAe,YAAW,mBAAmB;IAI/C,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM;IAJzB,SAAgB,QAAQ,EAAE,QAAQ,CAAC;gBAGhB,WAAW,EAAE,WAAW,EACxB,MAAM,EAAE,SAAS;IAKpC,IAAI,CAAC,SAAS,EAAE,SAAS;IAUzB,aAAa,CAAC,GAAG,EAAE,SAAS,GAAG,OAAO;IAWtC,KAAK,IAAI,IAAI;CAYd"}
|
|
@@ -1,7 +1,14 @@
|
|
|
1
1
|
import { BytesBlob } from "#@typeberry/bytes";
|
|
2
2
|
import { Decoder, Encoder } from "#@typeberry/codec";
|
|
3
|
+
import { tryAsStreamId, } from "#@typeberry/jamnp-s";
|
|
3
4
|
import { Logger } from "#@typeberry/logger";
|
|
5
|
+
import { assertNever } from "#@typeberry/utils";
|
|
4
6
|
import { NewStream, StreamEnvelope, StreamEnvelopeType } from "./stream.js";
|
|
7
|
+
const IPC_PEER_ID = "ipc-peer";
|
|
8
|
+
/** Construct a protocol-level StreamId from an IPC-level numeric stream ID. */
|
|
9
|
+
function toStreamId(ipcStreamId) {
|
|
10
|
+
return tryAsStreamId(`${IPC_PEER_ID}:${ipcStreamId}`);
|
|
11
|
+
}
|
|
5
12
|
const logger = Logger.new(import.meta.filename, "ext-ipc-jamnp");
|
|
6
13
|
export class JamnpIpcHandler {
|
|
7
14
|
sender;
|
|
@@ -37,9 +44,9 @@ export class JamnpIpcHandler {
|
|
|
37
44
|
/** Re-use an existing stream of given kind if present. */
|
|
38
45
|
withStreamOfKind(streamKind, work) {
|
|
39
46
|
// find first stream id with given kind
|
|
40
|
-
for (const [
|
|
47
|
+
for (const [ipcStreamId, handler] of this.streams.entries()) {
|
|
41
48
|
if (handler.kind === streamKind) {
|
|
42
|
-
work(handler, new EnvelopeSender(
|
|
49
|
+
work(handler, new EnvelopeSender(ipcStreamId, this.sender));
|
|
43
50
|
return;
|
|
44
51
|
}
|
|
45
52
|
}
|
|
@@ -52,19 +59,19 @@ export class JamnpIpcHandler {
|
|
|
52
59
|
throw new Error(`Stream with unregistered handler of kind: ${kind} was requested to be opened.`);
|
|
53
60
|
}
|
|
54
61
|
// pick a stream id
|
|
55
|
-
const
|
|
62
|
+
const getRandomIpcStreamId = () => Math.floor(Math.random() * 2 ** 32);
|
|
56
63
|
const streams = this.streams;
|
|
57
|
-
const
|
|
58
|
-
const s =
|
|
64
|
+
const ipcStreamId = (function findStreamId() {
|
|
65
|
+
const s = getRandomIpcStreamId();
|
|
59
66
|
if (!streams.has(s)) {
|
|
60
67
|
return s;
|
|
61
68
|
}
|
|
62
69
|
return findStreamId();
|
|
63
70
|
})();
|
|
64
71
|
// register the stream
|
|
65
|
-
this.streams.set(
|
|
66
|
-
this.pendingStreams.set(
|
|
67
|
-
const sender = new EnvelopeSender(
|
|
72
|
+
this.streams.set(ipcStreamId, handler);
|
|
73
|
+
this.pendingStreams.set(ipcStreamId, true);
|
|
74
|
+
const sender = new EnvelopeSender(ipcStreamId, this.sender);
|
|
68
75
|
sender.open(NewStream.create({ streamByte: kind }));
|
|
69
76
|
work(handler, sender);
|
|
70
77
|
}
|
|
@@ -72,24 +79,24 @@ export class JamnpIpcHandler {
|
|
|
72
79
|
async onSocketMessage(msg) {
|
|
73
80
|
// decode the message as `StreamEnvelope`
|
|
74
81
|
const envelope = Decoder.decodeObject(StreamEnvelope.Codec, msg);
|
|
75
|
-
const
|
|
76
|
-
logger.log `[${
|
|
82
|
+
const ipcStreamId = envelope.streamId;
|
|
83
|
+
logger.log `[${ipcStreamId}] incoming message: ${envelope.type} ${envelope.data}`;
|
|
77
84
|
// check if this is a already known stream id
|
|
78
|
-
const streamHandler = this.streams.get(
|
|
79
|
-
const streamSender = new EnvelopeSender(
|
|
85
|
+
const streamHandler = this.streams.get(ipcStreamId);
|
|
86
|
+
const streamSender = new EnvelopeSender(ipcStreamId, this.sender);
|
|
80
87
|
// we don't know that stream yet, so it has to be a new one
|
|
81
88
|
if (streamHandler === undefined) {
|
|
82
89
|
// closing or message of unknown stream - ignore.
|
|
83
90
|
if (envelope.type !== StreamEnvelopeType.Open) {
|
|
84
|
-
logger.warn `[${
|
|
91
|
+
logger.warn `[${ipcStreamId}] (unknown) got invalid type ${envelope.type}.`;
|
|
85
92
|
return;
|
|
86
93
|
}
|
|
87
94
|
const newStream = Decoder.decodeObject(NewStream.Codec, envelope.data);
|
|
88
95
|
const handler = this.streamHandlers.get(newStream.streamByte);
|
|
89
96
|
if (handler !== undefined) {
|
|
90
|
-
logger.log `[${
|
|
97
|
+
logger.log `[${ipcStreamId}] new stream for ${handler.kind}`;
|
|
91
98
|
// insert the stream
|
|
92
|
-
this.streams.set(
|
|
99
|
+
this.streams.set(ipcStreamId, handler);
|
|
93
100
|
// Just send back the same stream byte.
|
|
94
101
|
streamSender.open(newStream);
|
|
95
102
|
return;
|
|
@@ -98,31 +105,47 @@ export class JamnpIpcHandler {
|
|
|
98
105
|
streamSender.close();
|
|
99
106
|
return;
|
|
100
107
|
}
|
|
101
|
-
|
|
102
|
-
if (envelope.type === StreamEnvelopeType.Close) {
|
|
103
|
-
const handler = this.streams.get(streamId);
|
|
104
|
-
handler?.onClose(streamId, false);
|
|
105
|
-
this.streams.delete(streamId);
|
|
106
|
-
return;
|
|
107
|
-
}
|
|
108
|
-
if (envelope.type !== StreamEnvelopeType.Msg) {
|
|
108
|
+
if (envelope.type === StreamEnvelopeType.Open) {
|
|
109
109
|
// display a warning but only if the stream was not pending for confirmation.
|
|
110
|
-
if (!this.pendingStreams.delete(
|
|
111
|
-
logger.warn `[${
|
|
110
|
+
if (!this.pendingStreams.delete(ipcStreamId)) {
|
|
111
|
+
logger.warn `[${ipcStreamId}] got invalid type ${envelope.type}.`;
|
|
112
112
|
}
|
|
113
113
|
return;
|
|
114
114
|
}
|
|
115
|
+
// reject stream messages without open ack first.
|
|
116
|
+
if (this.pendingStreams.has(ipcStreamId)) {
|
|
117
|
+
logger.warn `[${ipcStreamId}] got invalid type ${envelope.type}. Expected Open.`;
|
|
118
|
+
// closing the connection and removing the stream from pending.
|
|
119
|
+
this.pendingStreams.delete(ipcStreamId);
|
|
120
|
+
// the stream should not be in the collection yet, but we remove it just for safety.
|
|
121
|
+
this.streams.delete(ipcStreamId);
|
|
122
|
+
streamSender.close();
|
|
123
|
+
return;
|
|
124
|
+
}
|
|
115
125
|
// this is a known stream, so just dispatch the message.
|
|
116
|
-
|
|
126
|
+
if (envelope.type === StreamEnvelopeType.Msg) {
|
|
127
|
+
streamHandler.onStreamMessage(streamSender, envelope.data);
|
|
128
|
+
return;
|
|
129
|
+
}
|
|
130
|
+
// close the stream
|
|
131
|
+
if (envelope.type === StreamEnvelopeType.Close) {
|
|
132
|
+
streamHandler.onClose(toStreamId(ipcStreamId), false);
|
|
133
|
+
this.streams.delete(ipcStreamId);
|
|
134
|
+
// not really needed, but just for sure.
|
|
135
|
+
this.pendingStreams.delete(ipcStreamId);
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
assertNever(envelope.type);
|
|
117
139
|
}
|
|
118
140
|
/** Notify about termination of the underlying socket. */
|
|
119
141
|
onClose({ error }) {
|
|
120
142
|
logger.log `Closing the handler. Reason: ${error !== undefined ? error.message : "close"}.`;
|
|
121
143
|
// Socket closed - we should probably clear everything.
|
|
122
|
-
for (const [
|
|
123
|
-
handler.onClose(
|
|
144
|
+
for (const [ipcStreamId, handler] of this.streams.entries()) {
|
|
145
|
+
handler.onClose(toStreamId(ipcStreamId), error !== undefined);
|
|
124
146
|
}
|
|
125
147
|
this.streams.clear();
|
|
148
|
+
this.pendingStreams.clear();
|
|
126
149
|
// finish the handler.
|
|
127
150
|
this.onEnd.finished = true;
|
|
128
151
|
if (error !== undefined) {
|
|
@@ -139,24 +162,26 @@ export class JamnpIpcHandler {
|
|
|
139
162
|
}
|
|
140
163
|
}
|
|
141
164
|
class EnvelopeSender {
|
|
142
|
-
|
|
165
|
+
ipcStreamId;
|
|
143
166
|
sender;
|
|
144
|
-
|
|
145
|
-
|
|
167
|
+
streamId;
|
|
168
|
+
constructor(ipcStreamId, sender) {
|
|
169
|
+
this.ipcStreamId = ipcStreamId;
|
|
146
170
|
this.sender = sender;
|
|
171
|
+
this.streamId = toStreamId(ipcStreamId);
|
|
147
172
|
}
|
|
148
173
|
open(newStream) {
|
|
149
174
|
const msg = Encoder.encodeObject(NewStream.Codec, newStream);
|
|
150
|
-
this.sender.send(Encoder.encodeObject(StreamEnvelope.Codec, StreamEnvelope.create({ streamId: this.
|
|
175
|
+
this.sender.send(Encoder.encodeObject(StreamEnvelope.Codec, StreamEnvelope.create({ streamId: this.ipcStreamId, type: StreamEnvelopeType.Open, data: msg })));
|
|
151
176
|
}
|
|
152
177
|
bufferAndSend(msg) {
|
|
153
|
-
this.sender.send(Encoder.encodeObject(StreamEnvelope.Codec, StreamEnvelope.create({ streamId: this.
|
|
178
|
+
this.sender.send(Encoder.encodeObject(StreamEnvelope.Codec, StreamEnvelope.create({ streamId: this.ipcStreamId, type: StreamEnvelopeType.Msg, data: msg })));
|
|
154
179
|
// we are buffering until we run OOM
|
|
155
180
|
return true;
|
|
156
181
|
}
|
|
157
182
|
close() {
|
|
158
183
|
this.sender.send(Encoder.encodeObject(StreamEnvelope.Codec, StreamEnvelope.create({
|
|
159
|
-
streamId: this.
|
|
184
|
+
streamId: this.ipcStreamId,
|
|
160
185
|
type: StreamEnvelopeType.Close,
|
|
161
186
|
data: BytesBlob.blobFromNumbers([]),
|
|
162
187
|
})));
|
|
@@ -1,18 +1,20 @@
|
|
|
1
1
|
import type { BytesBlob } from "#@typeberry/bytes";
|
|
2
2
|
import { type CodecRecord } from "#@typeberry/codec";
|
|
3
|
-
import type {
|
|
4
|
-
import { type U8 } from "#@typeberry/numbers";
|
|
3
|
+
import type { StreamKind } from "#@typeberry/jamnp-s";
|
|
4
|
+
import { type U8, type U32 } from "#@typeberry/numbers";
|
|
5
|
+
/** IPC-level stream identifier (u32), used for multiplexing streams over a single socket. */
|
|
6
|
+
export type IpcStreamId = U32;
|
|
5
7
|
export declare enum StreamEnvelopeType {
|
|
6
8
|
Msg = 0,
|
|
7
9
|
Open = 1,
|
|
8
10
|
Close = 2
|
|
9
11
|
}
|
|
10
12
|
export declare class StreamEnvelope {
|
|
11
|
-
readonly streamId:
|
|
13
|
+
readonly streamId: IpcStreamId;
|
|
12
14
|
readonly type: StreamEnvelopeType;
|
|
13
15
|
readonly data: BytesBlob;
|
|
14
16
|
static Codec: import("@typeberry/codec").Descriptor<StreamEnvelope, import("@typeberry/codec").ViewOf<StreamEnvelope, {
|
|
15
|
-
streamId: import("@typeberry/codec").Descriptor<
|
|
17
|
+
streamId: import("@typeberry/codec").Descriptor<U32, import("@typeberry/bytes").Bytes<4>>;
|
|
16
18
|
type: import("@typeberry/codec").Descriptor<StreamEnvelopeType, U8>;
|
|
17
19
|
data: import("@typeberry/codec").Descriptor<BytesBlob, BytesBlob>;
|
|
18
20
|
}>>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stream.d.ts","sourceRoot":"","sources":["../../../../../../packages/extensions/ipc/jamnp/stream.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAAS,MAAM,kBAAkB,CAAC;AAC3D,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"stream.d.ts","sourceRoot":"","sources":["../../../../../../packages/extensions/ipc/jamnp/stream.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAAS,MAAM,kBAAkB,CAAC;AAC3D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAW,KAAK,EAAE,EAAE,KAAK,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAEhE,6FAA6F;AAC7F,MAAM,MAAM,WAAW,GAAG,GAAG,CAAC;AAE9B,oBAAY,kBAAkB;IAC5B,GAAG,IAAI;IACP,IAAI,IAAI;IACR,KAAK,IAAI;CACV;AAED,qBAAa,cAAc;aA0BP,QAAQ,EAAE,WAAW;aACrB,IAAI,EAAE,kBAAkB;aACxB,IAAI,EAAE,SAAS;IA3BjC,MAAM,CAAC,KAAK;;;;QAkBT;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,WAAW,CAAC,cAAc,CAAC;IAInE,OAAO;CAKR;AAED,qBAAa,SAAS;aASgB,UAAU,EAAE,UAAU;IAR1D,MAAM,CAAC,KAAK;;QAET;IAEH,MAAM,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,EAAE,WAAW,CAAC,SAAS,CAAC;IAIpD,OAAO;CACR"}
|
|
@@ -10,8 +10,10 @@ import { WorkItem } from "./work-item.js";
|
|
|
10
10
|
/** Possible number of work items in the package or results in the report. */
|
|
11
11
|
/** Constrained by I=16 https://graypaper.fluffylabs.dev/#/68eaa1f/417a00417a00?v=0.6.4 */
|
|
12
12
|
export type WorkItemsCount = U8;
|
|
13
|
-
/**
|
|
13
|
+
/** Convert the value to `WorkItemsCount` bounds. */
|
|
14
14
|
export declare function tryAsWorkItemsCount(len: number): WorkItemsCount;
|
|
15
|
+
/** Verify the value is within the `WorkItemsCount` bounds. */
|
|
16
|
+
export declare function isWorkItemsCount(len: number): len is WorkItemsCount;
|
|
15
17
|
/** Minimal number of work items in the work package or results in work report. */
|
|
16
18
|
export declare const MIN_NUMBER_OF_WORK_ITEMS = 1;
|
|
17
19
|
/** `I`: Maximal number of work items in the work package or results in work report. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"work-package.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/block/work-package.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAAS,KAAK,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC7E,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAExD,OAAO,EAAW,KAAK,EAAE,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAS,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C,6EAA6E;AAC7E,0FAA0F;AAC1F,MAAM,MAAM,cAAc,GAAG,EAAE,CAAC;AAEhC,
|
|
1
|
+
{"version":3,"file":"work-package.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/block/work-package.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,KAAK,WAAW,EAAS,KAAK,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC7E,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAExD,OAAO,EAAW,KAAK,EAAE,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAS,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C,6EAA6E;AAC7E,0FAA0F;AAC1F,MAAM,MAAM,cAAc,GAAG,EAAE,CAAC;AAEhC,oDAAoD;AACpD,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,MAAM,GAAG,cAAc,CAM/D;AAED,8DAA8D;AAC9D,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,IAAI,cAAc,CAEnE;AAED,kFAAkF;AAClF,eAAO,MAAM,wBAAwB,IAAI,CAAC;AAC1C,uFAAuF;AACvF,eAAO,MAAM,wBAAwB,KAAK,CAAC;AAE3C;;;;;;GAMG;AACH,qBAAa,WAAY,SAAQ,SAAS;IAyBtC,wDAAwD;aACxC,aAAa,EAAE,SAAS;IACxC,kEAAkE;aAClD,YAAY,EAAE,SAAS;IACvC,mCAAmC;aACnB,YAAY,EAAE,QAAQ;IACtC,8CAA8C;aAC9B,eAAe,EAAE,SAAS;IAC1C,2DAA2D;aAC3C,OAAO,EAAE,aAAa;IACtC;;;;;OAKG;aACa,KAAK,EAAE,cAAc,CAAC,QAAQ,EAAE,cAAc,CAAC;IAxCjE,MAAM,CAAC,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QAUT;IAEH,MAAM,CAAC,MAAM,CAAC,EACZ,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,eAAe,EACf,OAAO,EACP,KAAK,GACN,EAAE,WAAW,CAAC,WAAW,CAAC;IAI3B,OAAO;CAqBR;AAED,MAAM,MAAM,eAAe,GAAG,WAAW,CAAC,OAAO,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC"}
|
|
@@ -5,14 +5,18 @@ import { tryAsU8 } from "#@typeberry/numbers";
|
|
|
5
5
|
import { check, WithDebug } from "#@typeberry/utils";
|
|
6
6
|
import { RefineContext } from "./refine-context.js";
|
|
7
7
|
import { WorkItem } from "./work-item.js";
|
|
8
|
-
/**
|
|
8
|
+
/** Convert the value to `WorkItemsCount` bounds. */
|
|
9
9
|
export function tryAsWorkItemsCount(len) {
|
|
10
10
|
check `
|
|
11
|
-
${len
|
|
11
|
+
${isWorkItemsCount(len)}
|
|
12
12
|
WorkItemsCount: Expected '${MIN_NUMBER_OF_WORK_ITEMS} <= count <= ${MAX_NUMBER_OF_WORK_ITEMS}' got ${len}
|
|
13
13
|
`;
|
|
14
14
|
return tryAsU8(len);
|
|
15
15
|
}
|
|
16
|
+
/** Verify the value is within the `WorkItemsCount` bounds. */
|
|
17
|
+
export function isWorkItemsCount(len) {
|
|
18
|
+
return len >= MIN_NUMBER_OF_WORK_ITEMS && len <= MAX_NUMBER_OF_WORK_ITEMS;
|
|
19
|
+
}
|
|
16
20
|
/** Minimal number of work items in the work package or results in work report. */
|
|
17
21
|
export const MIN_NUMBER_OF_WORK_ITEMS = 1;
|
|
18
22
|
/** `I`: Maximal number of work items in the work package or results in work report. */
|
|
@@ -1,4 +1,129 @@
|
|
|
1
1
|
import { Block } from "#@typeberry/block";
|
|
2
2
|
import type { ChainSpec } from "#@typeberry/config";
|
|
3
3
|
export declare const blockFromJson: (spec: ChainSpec) => import("@typeberry/json-parser").FromJsonWithParser<unknown, Block>;
|
|
4
|
+
export declare const blockViewFromJson: (spec: ChainSpec) => import("@typeberry/json-parser").FromJsonWithParser<unknown, import("@typeberry/codec").ViewOf<Block, {
|
|
5
|
+
header: import("@typeberry/codec").Descriptor<import("@typeberry/block").Header & import("@typeberry/codec").CodecRecord<import("@typeberry/block").Header>, import("@typeberry/codec").ViewOf<import("@typeberry/block").Header & import("@typeberry/codec").CodecRecord<import("@typeberry/block").Header>, {
|
|
6
|
+
parentHeaderHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"HeaderHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
7
|
+
priorStateRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"StateRootHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
8
|
+
extrinsicHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"ExtrinsicHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
9
|
+
timeSlotIndex: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"TimeSlot[u32]">, import("@typeberry/bytes").Bytes<4>>;
|
|
10
|
+
epochMarker: import("@typeberry/codec").Descriptor<import("@typeberry/block").EpochMarker | null, import("@typeberry/codec").ViewOf<import("@typeberry/block").EpochMarker, {
|
|
11
|
+
entropy: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"EntropyHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
12
|
+
ticketsEntropy: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"EntropyHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
13
|
+
validators: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block").ValidatorKeys[] & import("@typeberry/utils").WithOpaque<"ValidatorsCount">, import("@typeberry/codec").SequenceView<import("@typeberry/block").ValidatorKeys, import("@typeberry/codec").ViewOf<import("@typeberry/block").ValidatorKeys, {
|
|
14
|
+
bandersnatch: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"BandersnatchKey">, import("@typeberry/bytes").Bytes<32>>;
|
|
15
|
+
ed25519: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"Ed25519Key">, import("@typeberry/bytes").Bytes<32>>;
|
|
16
|
+
}>>>;
|
|
17
|
+
}> | null>;
|
|
18
|
+
ticketsMarker: import("@typeberry/codec").Descriptor<import("@typeberry/block").TicketsMarker | null, import("@typeberry/codec").ViewOf<import("@typeberry/block").TicketsMarker, {
|
|
19
|
+
tickets: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block/tickets.js").Ticket[] & import("@typeberry/utils").WithOpaque<"EpochLength">, import("@typeberry/codec").SequenceView<import("@typeberry/block/tickets.js").Ticket, import("@typeberry/codec").ViewOf<import("@typeberry/block/tickets.js").Ticket, {
|
|
20
|
+
id: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32>, import("@typeberry/bytes").Bytes<32>>;
|
|
21
|
+
attempt: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<1> & import("@typeberry/utils").WithOpaque<"TicketAttempt[0|1|2]">, import("@typeberry/numbers").U8>;
|
|
22
|
+
}>>>;
|
|
23
|
+
}> | null>;
|
|
24
|
+
bandersnatchBlockAuthorIndex: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<2> & import("@typeberry/utils").WithOpaque<"ValidatorIndex[u16]">, import("@typeberry/bytes").Bytes<2>>;
|
|
25
|
+
entropySource: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<96> & import("@typeberry/utils").WithOpaque<"BandersnatchVrfSignature">, import("@typeberry/bytes").Bytes<96>>;
|
|
26
|
+
offendersMarker: import("@typeberry/codec").Descriptor<(import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"Ed25519Key">)[], import("@typeberry/codec").SequenceView<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"Ed25519Key">, import("@typeberry/bytes").Bytes<32>>>;
|
|
27
|
+
seal: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<96> & import("@typeberry/utils").WithOpaque<"BandersnatchVrfSignature">, import("@typeberry/bytes").Bytes<96>>;
|
|
28
|
+
}>>;
|
|
29
|
+
extrinsic: import("@typeberry/codec").Descriptor<import("@typeberry/block").Extrinsic, import("@typeberry/codec").ViewOf<import("@typeberry/block").Extrinsic, {
|
|
30
|
+
tickets: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block/tickets.js").SignedTicket[] & import("@typeberry/utils").WithOpaque<"Size: [0..chainSpec.maxTicketsPerExtrinsic)">, import("@typeberry/codec").SequenceView<import("@typeberry/block/tickets.js").SignedTicket, import("@typeberry/codec").ViewOf<import("@typeberry/block/tickets.js").SignedTicket, {
|
|
31
|
+
attempt: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<1> & import("@typeberry/utils").WithOpaque<"TicketAttempt[0|1|2]">, import("@typeberry/numbers").U8>;
|
|
32
|
+
signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<784> & import("@typeberry/utils").WithOpaque<"BandersnatchRingSignature">, import("@typeberry/bytes").Bytes<784>>;
|
|
33
|
+
}>>>;
|
|
34
|
+
preimages: import("@typeberry/codec").Descriptor<import("@typeberry/block/preimage.js").Preimage[], import("@typeberry/codec").SequenceView<import("@typeberry/block/preimage.js").Preimage, import("@typeberry/codec").ViewOf<import("@typeberry/block/preimage.js").Preimage, {
|
|
35
|
+
requester: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">, import("@typeberry/bytes").Bytes<4>>;
|
|
36
|
+
blob: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").BytesBlob, import("@typeberry/bytes").BytesBlob>;
|
|
37
|
+
}>>>;
|
|
38
|
+
guarantees: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block/guarantees.js").ReportGuarantee[] & import("@typeberry/utils").WithOpaque<"[0..CoresCount)">, import("@typeberry/codec").SequenceView<import("@typeberry/block/guarantees.js").ReportGuarantee, import("@typeberry/codec").ViewOf<import("@typeberry/block/guarantees.js").ReportGuarantee, {
|
|
39
|
+
report: import("@typeberry/codec").Descriptor<import("@typeberry/block/work-report.js").WorkReport, import("@typeberry/codec").ViewOf<import("@typeberry/block/work-report.js").WorkReport, {
|
|
40
|
+
workPackageSpec: import("@typeberry/codec").Descriptor<import("@typeberry/block/work-report.js").WorkPackageSpec, import("@typeberry/codec").ViewOf<import("@typeberry/block/work-report.js").WorkPackageSpec, {
|
|
41
|
+
hash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkPackageHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
42
|
+
length: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U32, import("@typeberry/bytes").Bytes<4>>;
|
|
43
|
+
erasureRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32>, import("@typeberry/bytes").Bytes<32>>;
|
|
44
|
+
exportsRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"ExportsRootHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
45
|
+
exportsCount: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U16, import("@typeberry/bytes").Bytes<2>>;
|
|
46
|
+
}>>;
|
|
47
|
+
context: import("@typeberry/codec").Descriptor<import("@typeberry/block/refine-context.js").RefineContext, import("@typeberry/codec").ViewOf<import("@typeberry/block/refine-context.js").RefineContext, {
|
|
48
|
+
anchor: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"HeaderHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
49
|
+
stateRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"StateRootHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
50
|
+
beefyRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"BeefyHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
51
|
+
lookupAnchor: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"HeaderHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
52
|
+
lookupAnchorSlot: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"TimeSlot[u32]">, import("@typeberry/bytes").Bytes<4>>;
|
|
53
|
+
prerequisites: import("@typeberry/codec").Descriptor<(import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkPackageHash">)[], import("@typeberry/codec").SequenceView<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkPackageHash">, import("@typeberry/bytes").Bytes<32>>>;
|
|
54
|
+
}>>;
|
|
55
|
+
coreIndex: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<2> & import("@typeberry/utils").WithOpaque<"CoreIndex[u16]">, import("@typeberry/numbers").U32>;
|
|
56
|
+
authorizerHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"AuthorizerHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
57
|
+
authorizationGasUsed: import("@typeberry/codec").Descriptor<bigint & import("@typeberry/numbers").WithBytesRepresentation<8> & import("@typeberry/utils").WithOpaque<"ServiceGas[u64]">, import("@typeberry/numbers").U64>;
|
|
58
|
+
authorizationOutput: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").BytesBlob, import("@typeberry/bytes").BytesBlob>;
|
|
59
|
+
segmentRootLookup: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block/refine-context.js").WorkPackageInfo[], import("@typeberry/codec").SequenceView<import("@typeberry/block/refine-context.js").WorkPackageInfo, import("@typeberry/codec").ViewOf<import("@typeberry/block/refine-context.js").WorkPackageInfo, {
|
|
60
|
+
workPackageHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkPackageHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
61
|
+
segmentTreeRoot: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"ExportsRootHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
62
|
+
}>>>;
|
|
63
|
+
results: import("@typeberry/codec").Descriptor<import("@typeberry/collections").FixedSizeArray<import("@typeberry/block/work-result.js").WorkResult, import("@typeberry/numbers").U8>, import("@typeberry/codec").SequenceView<import("@typeberry/block/work-result.js").WorkResult, import("@typeberry/codec").ViewOf<import("@typeberry/block/work-result.js").WorkResult, {
|
|
64
|
+
serviceId: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"ServiceId[u32]">, import("@typeberry/bytes").Bytes<4>>;
|
|
65
|
+
codeHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"CodeHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
66
|
+
payloadHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32>, import("@typeberry/bytes").Bytes<32>>;
|
|
67
|
+
gas: import("@typeberry/codec").Descriptor<bigint & import("@typeberry/numbers").WithBytesRepresentation<8> & import("@typeberry/utils").WithOpaque<"ServiceGas[u64]">, import("@typeberry/bytes").Bytes<8>>;
|
|
68
|
+
result: import("@typeberry/codec").Descriptor<import("@typeberry/block/work-result.js").WorkExecResult, {
|
|
69
|
+
kind: import("@typeberry/block/work-result.js").WorkExecResultKind.ok;
|
|
70
|
+
okBlob: import("@typeberry/bytes").BytesBlob;
|
|
71
|
+
} | {
|
|
72
|
+
kind: import("@typeberry/block/work-result.js").WorkExecResultKind.outOfGas;
|
|
73
|
+
} | {
|
|
74
|
+
kind: import("@typeberry/block/work-result.js").WorkExecResultKind.panic;
|
|
75
|
+
} | {
|
|
76
|
+
kind: import("@typeberry/block/work-result.js").WorkExecResultKind.incorrectNumberOfExports;
|
|
77
|
+
} | {
|
|
78
|
+
kind: import("@typeberry/block/work-result.js").WorkExecResultKind.digestTooBig;
|
|
79
|
+
} | {
|
|
80
|
+
kind: import("@typeberry/block/work-result.js").WorkExecResultKind.badCode;
|
|
81
|
+
} | {
|
|
82
|
+
kind: import("@typeberry/block/work-result.js").WorkExecResultKind.codeOversize;
|
|
83
|
+
}>;
|
|
84
|
+
load: import("@typeberry/codec").Descriptor<import("@typeberry/block/work-result.js").WorkRefineLoad, import("@typeberry/codec").ViewOf<import("@typeberry/block/work-result.js").WorkRefineLoad, {
|
|
85
|
+
gasUsed: import("@typeberry/codec").Descriptor<bigint & import("@typeberry/numbers").WithBytesRepresentation<8> & import("@typeberry/utils").WithOpaque<"ServiceGas[u64]">, import("@typeberry/numbers").U64>;
|
|
86
|
+
importedSegments: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U32, import("@typeberry/numbers").U32>;
|
|
87
|
+
extrinsicCount: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U32, import("@typeberry/numbers").U32>;
|
|
88
|
+
extrinsicSize: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U32, import("@typeberry/numbers").U32>;
|
|
89
|
+
exportedSegments: import("@typeberry/codec").Descriptor<import("@typeberry/numbers").U32, import("@typeberry/numbers").U32>;
|
|
90
|
+
}>>;
|
|
91
|
+
}>>>;
|
|
92
|
+
}>>;
|
|
93
|
+
slot: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"TimeSlot[u32]">, import("@typeberry/bytes").Bytes<4>>;
|
|
94
|
+
credentials: import("@typeberry/codec").Descriptor<(readonly import("@typeberry/block/guarantees.js").Credential[] & import("@typeberry/utils").WithOpaque<"2">) | (readonly import("@typeberry/block/guarantees.js").Credential[] & import("@typeberry/utils").WithOpaque<"3">), import("@typeberry/codec").SequenceView<import("@typeberry/block/guarantees.js").Credential, import("@typeberry/codec").ViewOf<import("@typeberry/block/guarantees.js").Credential, {
|
|
95
|
+
validatorIndex: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<2> & import("@typeberry/utils").WithOpaque<"ValidatorIndex[u16]">, import("@typeberry/bytes").Bytes<2>>;
|
|
96
|
+
signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<64> & import("@typeberry/utils").WithOpaque<"Ed25519Signature">, import("@typeberry/bytes").Bytes<64>>;
|
|
97
|
+
}>>>;
|
|
98
|
+
}>>>;
|
|
99
|
+
assurances: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block/assurances.js").AvailabilityAssurance[] & import("@typeberry/utils").WithOpaque<"[0 .. ValidatorsCount)">, import("@typeberry/codec").SequenceView<import("@typeberry/block/assurances.js").AvailabilityAssurance, import("@typeberry/codec").ViewOf<import("@typeberry/block/assurances.js").AvailabilityAssurance, {
|
|
100
|
+
anchor: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"HeaderHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
101
|
+
bitfield: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").BitVec, import("@typeberry/bytes").BitVec>;
|
|
102
|
+
validatorIndex: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<2> & import("@typeberry/utils").WithOpaque<"ValidatorIndex[u16]">, import("@typeberry/bytes").Bytes<2>>;
|
|
103
|
+
signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<64> & import("@typeberry/utils").WithOpaque<"Ed25519Signature">, import("@typeberry/bytes").Bytes<64>>;
|
|
104
|
+
}>>>;
|
|
105
|
+
disputes: import("@typeberry/codec").Descriptor<import("@typeberry/block/disputes.js").DisputesExtrinsic, import("@typeberry/codec").ViewOf<import("@typeberry/block/disputes.js").DisputesExtrinsic, {
|
|
106
|
+
verdicts: import("@typeberry/codec").Descriptor<import("@typeberry/block/disputes.js").Verdict[], import("@typeberry/codec").SequenceView<import("@typeberry/block/disputes.js").Verdict, import("@typeberry/codec").ViewOf<import("@typeberry/block/disputes.js").Verdict, {
|
|
107
|
+
workReportHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkReportHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
108
|
+
votesEpoch: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<4> & import("@typeberry/utils").WithOpaque<"Epoch">, import("@typeberry/bytes").Bytes<4>>;
|
|
109
|
+
votes: import("@typeberry/codec").Descriptor<readonly import("@typeberry/block/disputes.js").Judgement[] & import("@typeberry/utils").WithOpaque<"Validators super majority">, import("@typeberry/codec").SequenceView<import("@typeberry/block/disputes.js").Judgement, import("@typeberry/codec").ViewOf<import("@typeberry/block/disputes.js").Judgement, {
|
|
110
|
+
isWorkReportValid: import("@typeberry/codec").Descriptor<boolean, boolean>;
|
|
111
|
+
index: import("@typeberry/codec").Descriptor<number & import("@typeberry/numbers").WithBytesRepresentation<2> & import("@typeberry/utils").WithOpaque<"ValidatorIndex[u16]">, import("@typeberry/bytes").Bytes<2>>;
|
|
112
|
+
signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<64> & import("@typeberry/utils").WithOpaque<"Ed25519Signature">, import("@typeberry/bytes").Bytes<64>>;
|
|
113
|
+
}>>>;
|
|
114
|
+
}>>>;
|
|
115
|
+
culprits: import("@typeberry/codec").Descriptor<import("@typeberry/block/disputes.js").Culprit[], import("@typeberry/codec").SequenceView<import("@typeberry/block/disputes.js").Culprit, import("@typeberry/codec").ViewOf<import("@typeberry/block/disputes.js").Culprit, {
|
|
116
|
+
workReportHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkReportHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
117
|
+
key: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"Ed25519Key">, import("@typeberry/bytes").Bytes<32>>;
|
|
118
|
+
signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<64> & import("@typeberry/utils").WithOpaque<"Ed25519Signature">, import("@typeberry/bytes").Bytes<64>>;
|
|
119
|
+
}>>>;
|
|
120
|
+
faults: import("@typeberry/codec").Descriptor<import("@typeberry/block/disputes.js").Fault[], import("@typeberry/codec").SequenceView<import("@typeberry/block/disputes.js").Fault, import("@typeberry/codec").ViewOf<import("@typeberry/block/disputes.js").Fault, {
|
|
121
|
+
workReportHash: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"WorkReportHash">, import("@typeberry/bytes").Bytes<32>>;
|
|
122
|
+
wasConsideredValid: import("@typeberry/codec").Descriptor<boolean, boolean>;
|
|
123
|
+
key: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<32> & import("@typeberry/utils").WithOpaque<"Ed25519Key">, import("@typeberry/bytes").Bytes<32>>;
|
|
124
|
+
signature: import("@typeberry/codec").Descriptor<import("@typeberry/bytes").Bytes<64> & import("@typeberry/utils").WithOpaque<"Ed25519Signature">, import("@typeberry/bytes").Bytes<64>>;
|
|
125
|
+
}>>>;
|
|
126
|
+
}>>;
|
|
127
|
+
}>>;
|
|
128
|
+
}>>;
|
|
4
129
|
//# sourceMappingURL=block.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"block.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/block-json/block.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,
|
|
1
|
+
{"version":3,"file":"block.d.ts","sourceRoot":"","sources":["../../../../../packages/jam/block-json/block.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAkB,MAAM,kBAAkB,CAAC;AACzD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAKnD,eAAO,MAAM,aAAa,GAAI,MAAM,SAAS,wEAO1C,CAAC;AAEJ,eAAO,MAAM,iBAAiB,GAAI,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAMhD,CAAC"}
|
|
@@ -1,8 +1,15 @@
|
|
|
1
|
-
import { Block } from "#@typeberry/block";
|
|
2
|
-
import { json } from "#@typeberry/json-parser";
|
|
1
|
+
import { Block, reencodeAsView } from "#@typeberry/block";
|
|
2
|
+
import { json, parseFromJson } from "#@typeberry/json-parser";
|
|
3
3
|
import { getExtrinsicFromJson } from "./extrinsic.js";
|
|
4
4
|
import { headerFromJson } from "./header.js";
|
|
5
5
|
export const blockFromJson = (spec) => json.object({
|
|
6
6
|
header: headerFromJson,
|
|
7
7
|
extrinsic: getExtrinsicFromJson(spec),
|
|
8
8
|
}, ({ header, extrinsic }) => Block.create({ header, extrinsic }));
|
|
9
|
+
export const blockViewFromJson = (spec) => {
|
|
10
|
+
const parseBlock = blockFromJson(spec);
|
|
11
|
+
return json.fromAny((p) => {
|
|
12
|
+
const block = parseFromJson(p, parseBlock);
|
|
13
|
+
return reencodeAsView(Block.Codec, block, spec);
|
|
14
|
+
});
|
|
15
|
+
};
|
|
@@ -2,7 +2,7 @@ import type { BlockView, HeaderHash, StateRootHash } from "#@typeberry/block";
|
|
|
2
2
|
import type { ChainSpec } from "#@typeberry/config";
|
|
3
3
|
import { type Result } from "#@typeberry/utils";
|
|
4
4
|
import type { IpcHandler, IpcSender } from "../server.js";
|
|
5
|
-
import {
|
|
5
|
+
import { ErrorMessage, type Initialize, type KeyValue, type PeerInfo } from "./types.js";
|
|
6
6
|
/**
|
|
7
7
|
* Handler interface for v1 fuzzer protocol messages.
|
|
8
8
|
* https://github.com/davxy/jam-conformance/blob/main/fuzz-proto/fuzz-v1.asn
|