@hyperlane-xyz/sealevel-sdk 27.0.0 → 27.1.0
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/clients/protocol.d.ts.map +1 -1
- package/dist/clients/protocol.js +4 -4
- package/dist/clients/protocol.js.map +1 -1
- package/dist/hook/hook-artifact-manager.d.ts +2 -2
- package/dist/hook/hook-artifact-manager.d.ts.map +1 -1
- package/dist/hook/hook-artifact-manager.js +1 -0
- package/dist/hook/hook-artifact-manager.js.map +1 -1
- package/dist/tests/protocol.unit-test.d.ts +2 -0
- package/dist/tests/protocol.unit-test.d.ts.map +1 -0
- package/dist/tests/protocol.unit-test.js +57 -0
- package/dist/tests/protocol.unit-test.js.map +1 -0
- package/package.json +6 -6
- package/dist/generated/core-addresses.d.ts +0 -14
- package/dist/generated/core-addresses.d.ts.map +0 -1
- package/dist/generated/core-addresses.js +0 -55
- package/dist/generated/core-addresses.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"protocol.d.ts","sourceRoot":"","sources":["../../src/clients/protocol.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,KAAK,EACL,qBAAqB,EACrB,qBAAqB,EACrB,0BAA0B,EAC1B,gBAAgB,EAChB,YAAY,EACZ,0BAA0B,EAC3B,MAAM,6BAA6B,CAAC;AACrC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;AAChF,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAC9E,OAAO,KAAK,EACV,WAAW,EACX,SAAS,EACV,MAAM,oCAAoC,CAAC;AAC5C,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;
|
|
1
|
+
{"version":3,"file":"protocol.d.ts","sourceRoot":"","sources":["../../src/clients/protocol.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,KAAK,EACL,qBAAqB,EACrB,qBAAqB,EACrB,0BAA0B,EAC1B,gBAAgB,EAChB,YAAY,EACZ,0BAA0B,EAC3B,MAAM,6BAA6B,CAAC;AACrC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;AAChF,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAC9E,OAAO,KAAK,EACV,WAAW,EACX,SAAS,EACV,MAAM,oCAAoC,CAAC;AAC5C,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;AAWhF,qBAAa,mBAAoB,YAAW,gBAAgB;IAC1D,cAAc,CAAC,aAAa,EAAE,qBAAqB,GAAG,OAAO,CAAC,SAAS,CAAC;IAKlE,YAAY,CAChB,aAAa,EAAE,qBAAqB,EACpC,MAAM,EAAE,YAAY,GACnB,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IAKjD,eAAe,CAAC,OAAO,SAAS,0BAA0B,EACxD,cAAc,EAAE,qBAAqB,EACrC,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,qBAAqB,CAAC;IAIjC,wBAAwB,CACtB,aAAa,EAAE,qBAAqB,GACnC,sBAAsB;IAKzB,yBAAyB,CACvB,aAAa,EAAE,qBAAqB,EACpC,OAAO,CAAC,EAAE;QAAE,OAAO,CAAC,EAAE,MAAM,CAAA;KAAE,GAC7B,uBAAuB;IAQ1B,yBAAyB,CACvB,aAAa,EAAE,qBAAqB,EACpC,QAAQ,CAAC,EAAE;QAAE,OAAO,CAAC,EAAE,MAAM,CAAA;KAAE,GAC9B,uBAAuB;IAK1B,SAAS,IAAI,0BAA0B;IAWvC,OAAO,CAAC,UAAU;CAOnB"}
|
package/dist/clients/protocol.js
CHANGED
|
@@ -3,7 +3,6 @@ import { address as parseAddress } from '@solana/kit';
|
|
|
3
3
|
import { SvmHookArtifactManager } from '../hook/hook-artifact-manager.js';
|
|
4
4
|
import { SvmIsmArtifactManager } from '../ism/ism-artifact-manager.js';
|
|
5
5
|
import { createRpc } from '../rpc.js';
|
|
6
|
-
import { SVM_CORE_ADDRESSES } from '../generated/core-addresses.js';
|
|
7
6
|
import { SvmWarpArtifactManager } from '../warp/warp-artifact-manager.js';
|
|
8
7
|
import { SvmProvider } from './provider.js';
|
|
9
8
|
import { SvmSigner } from './signer.js';
|
|
@@ -24,10 +23,11 @@ export class SvmProtocolProvider {
|
|
|
24
23
|
return new SvmIsmArtifactManager(rpc);
|
|
25
24
|
}
|
|
26
25
|
createHookArtifactManager(chainMetadata, context) {
|
|
27
|
-
const mailbox = context?.mailbox ?? SVM_CORE_ADDRESSES[chainMetadata.name]?.mailbox;
|
|
28
|
-
assert(mailbox, 'Mailbox address is required for SVM hook artifact manager');
|
|
29
26
|
const rpc = createRpc(this.getRpcUrls(chainMetadata)[0]);
|
|
30
|
-
|
|
27
|
+
const mailbox = context?.mailbox
|
|
28
|
+
? parseAddress(context.mailbox)
|
|
29
|
+
: undefined;
|
|
30
|
+
return new SvmHookArtifactManager(rpc, mailbox);
|
|
31
31
|
}
|
|
32
32
|
createWarpArtifactManager(chainMetadata, _context) {
|
|
33
33
|
const rpc = createRpc(this.getRpcUrls(chainMetadata)[0]);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"protocol.js","sourceRoot":"","sources":["../../src/clients/protocol.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,aAAa,CAAC;AAEtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AACvE,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"protocol.js","sourceRoot":"","sources":["../../src/clients/protocol.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,aAAa,CAAC;AAEtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AACvE,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AACtC,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAC1E,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,MAAM,OAAO,mBAAmB;IAC9B,cAAc,CAAC,aAAoC;QACjD,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;QAC/C,OAAO,WAAW,CAAC,OAAO,CAAC,OAAO,EAAE,aAAa,CAAC,OAAO,CAAC,CAAC;IAC7D,CAAC;IAED,KAAK,CAAC,YAAY,CAChB,aAAoC,EACpC,MAAoB;QAEpB,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;QAC/C,OAAO,SAAS,CAAC,iBAAiB,CAAC,OAAO,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;IACjE,CAAC;IAED,eAAe,CACb,cAAqC,EACrC,OAAgB;QAEhB,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;IAC5E,CAAC;IAED,wBAAwB,CACtB,aAAoC;QAEpC,MAAM,GAAG,GAAG,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzD,OAAO,IAAI,qBAAqB,CAAC,GAAG,CAAC,CAAC;IACxC,CAAC;IAED,yBAAyB,CACvB,aAAoC,EACpC,OAA8B;QAE9B,MAAM,GAAG,GAAG,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzD,MAAM,OAAO,GAAG,OAAO,EAAE,OAAO;YAC9B,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC;YAC/B,CAAC,CAAC,SAAS,CAAC;QACd,OAAO,IAAI,sBAAsB,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IAClD,CAAC;IAED,yBAAyB,CACvB,aAAoC,EACpC,QAA+B;QAE/B,MAAM,GAAG,GAAG,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzD,OAAO,IAAI,sBAAsB,CAAC,GAAG,CAAC,CAAC;IACzC,CAAC;IAED,SAAS;QACP,OAAO;YACL,eAAe,EAAE,EAAE;YACnB,4EAA4E;YAC5E,eAAe,EAAE,WAAc;YAC/B,aAAa,EAAE,EAAE;YACjB,OAAO,EAAE,EAAE;YACX,cAAc,EAAE,EAAE;SACnB,CAAC;IACJ,CAAC;IAEO,UAAU,CAAC,aAAoC;QACrD,MAAM,CACJ,aAAa,CAAC,OAAO,IAAI,aAAa,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EACzD,kCAAkC,CACnC,CAAC;QACF,OAAO,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAClD,CAAC;CACF"}
|
|
@@ -6,9 +6,9 @@ import type { SvmDeployedHook, SvmDeployedIgpHook } from '../types.js';
|
|
|
6
6
|
export type HookAccountDecoder = 'igpProgramData' | 'igp' | 'overheadIgp';
|
|
7
7
|
export declare class SvmHookArtifactManager implements IRawHookArtifactManager {
|
|
8
8
|
private readonly rpc;
|
|
9
|
-
private readonly mailboxAddress
|
|
9
|
+
private readonly mailboxAddress?;
|
|
10
10
|
private readonly salt;
|
|
11
|
-
constructor(rpc: Rpc<SolanaRpcApi>, mailboxAddress
|
|
11
|
+
constructor(rpc: Rpc<SolanaRpcApi>, mailboxAddress?: Address | undefined, salt?: Uint8Array);
|
|
12
12
|
readHook(address: string): Promise<DeployedHookArtifact>;
|
|
13
13
|
createReader<T extends keyof RawHookArtifactConfigs>(type: T): ArtifactReader<RawHookArtifactConfigs[T], SvmDeployedHook | SvmDeployedIgpHook>;
|
|
14
14
|
createWriter<T extends keyof RawHookArtifactConfigs>(type: T, signer: SvmSigner): ArtifactWriter<RawHookArtifactConfigs[T], SvmDeployedHook | SvmDeployedIgpHook>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hook-artifact-manager.d.ts","sourceRoot":"","sources":["../../src/hook/hook-artifact-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,OAAO,EACZ,KAAK,GAAG,EACR,KAAK,YAAY,EAClB,MAAM,aAAa,CAAC;AAGrB,OAAO,KAAK,EACV,cAAc,EACd,cAAc,EACf,MAAM,sCAAsC,CAAC;AAC9C,OAAO,KAAK,EACV,oBAAoB,EACpB,uBAAuB,EACvB,sBAAsB,EACvB,MAAM,kCAAkC,CAAC;AAG1C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,KAAK,EAAE,eAAe,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAavE,MAAM,MAAM,kBAAkB,GAAG,gBAAgB,GAAG,KAAK,GAAG,aAAa,CAAC;AAE1E,qBAAa,sBAAuB,YAAW,uBAAuB;IAElE,OAAO,CAAC,QAAQ,CAAC,GAAG;IACpB,OAAO,CAAC,QAAQ,CAAC,cAAc;
|
|
1
|
+
{"version":3,"file":"hook-artifact-manager.d.ts","sourceRoot":"","sources":["../../src/hook/hook-artifact-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,OAAO,EACZ,KAAK,GAAG,EACR,KAAK,YAAY,EAClB,MAAM,aAAa,CAAC;AAGrB,OAAO,KAAK,EACV,cAAc,EACd,cAAc,EACf,MAAM,sCAAsC,CAAC;AAC9C,OAAO,KAAK,EACV,oBAAoB,EACpB,uBAAuB,EACvB,sBAAsB,EACvB,MAAM,kCAAkC,CAAC;AAG1C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,KAAK,EAAE,eAAe,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAavE,MAAM,MAAM,kBAAkB,GAAG,gBAAgB,GAAG,KAAK,GAAG,aAAa,CAAC;AAE1E,qBAAa,sBAAuB,YAAW,uBAAuB;IAElE,OAAO,CAAC,QAAQ,CAAC,GAAG;IACpB,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAFJ,GAAG,EAAE,GAAG,CAAC,YAAY,CAAC,EACtB,cAAc,CAAC,EAAE,OAAO,YAAA,EACxB,IAAI,GAAE,UAA6B;IAGhD,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAqB9D,YAAY,CAAC,CAAC,SAAS,MAAM,sBAAsB,EACjD,IAAI,EAAE,CAAC,GACN,cAAc,CACf,sBAAsB,CAAC,CAAC,CAAC,EACzB,eAAe,GAAG,kBAAkB,CACrC;IAeD,YAAY,CAAC,CAAC,SAAS,MAAM,sBAAsB,EACjD,IAAI,EAAE,CAAC,EACP,MAAM,EAAE,SAAS,GAChB,cAAc,CACf,sBAAsB,CAAC,CAAC,CAAC,EACzB,eAAe,GAAG,kBAAkB,CACrC;IAgBD,OAAO,CAAC,cAAc;CAUvB"}
|
|
@@ -21,6 +21,7 @@ export class SvmHookArtifactManager {
|
|
|
21
21
|
}
|
|
22
22
|
// The only other supported hook on SVM is the merkle tree hook, which IS
|
|
23
23
|
// the mailbox program. Validate the address matches before assuming.
|
|
24
|
+
assert(this.mailboxAddress, 'Mailbox address is required to detect merkle tree hooks on SVM');
|
|
24
25
|
assert(addr === this.mailboxAddress, `Unknown hook address ${address}: not an IGP program; expected the configured mailbox (${this.mailboxAddress}) for Merkle detection`);
|
|
25
26
|
return this.createReader('merkleTreeHook').read(address);
|
|
26
27
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"hook-artifact-manager.js","sourceRoot":"","sources":["../../src/hook/hook-artifact-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,IAAI,YAAY,GAIxB,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAC;AAU7D,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAK9C,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EACL,gBAAgB,EAChB,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,uBAAuB,EACvB,uBAAuB,GACxB,MAAM,uBAAuB,CAAC;AAI/B,MAAM,OAAO,sBAAsB;IAEd;IACA;IACA;IAHnB,YACmB,GAAsB,EACtB,
|
|
1
|
+
{"version":3,"file":"hook-artifact-manager.js","sourceRoot":"","sources":["../../src/hook/hook-artifact-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protocol.unit-test.d.ts","sourceRoot":"","sources":["../../src/tests/protocol.unit-test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { expect } from 'chai';
|
|
2
|
+
import { describe, it } from 'mocha';
|
|
3
|
+
import { ProtocolType } from '@hyperlane-xyz/provider-sdk';
|
|
4
|
+
import { SvmHookArtifactManager } from '../hook/hook-artifact-manager.js';
|
|
5
|
+
import { SvmIsmArtifactManager } from '../ism/ism-artifact-manager.js';
|
|
6
|
+
import { SvmWarpArtifactManager } from '../warp/warp-artifact-manager.js';
|
|
7
|
+
import { SvmProtocolProvider } from '../clients/protocol.js';
|
|
8
|
+
const FAKE_METADATA = {
|
|
9
|
+
name: 'solanamainnet',
|
|
10
|
+
protocol: ProtocolType.Sealevel,
|
|
11
|
+
domainId: 1399811149,
|
|
12
|
+
chainId: '1399811149',
|
|
13
|
+
rpcUrls: [{ http: 'http://localhost:8899' }],
|
|
14
|
+
};
|
|
15
|
+
const FAKE_MAILBOX = 'E588QtVUvresuXq2KoNEwAmoifCzYGpRBdHByN9KQMbi';
|
|
16
|
+
describe('SvmProtocolProvider', () => {
|
|
17
|
+
const provider = new SvmProtocolProvider();
|
|
18
|
+
describe('createHookArtifactManager', () => {
|
|
19
|
+
it('returns SvmHookArtifactManager with mailbox from context', () => {
|
|
20
|
+
const manager = provider.createHookArtifactManager(FAKE_METADATA, {
|
|
21
|
+
mailbox: FAKE_MAILBOX,
|
|
22
|
+
});
|
|
23
|
+
expect(manager).to.be.instanceOf(SvmHookArtifactManager);
|
|
24
|
+
});
|
|
25
|
+
it('returns SvmHookArtifactManager without mailbox when no context', () => {
|
|
26
|
+
const manager = provider.createHookArtifactManager(FAKE_METADATA);
|
|
27
|
+
expect(manager).to.be.instanceOf(SvmHookArtifactManager);
|
|
28
|
+
});
|
|
29
|
+
it('returns SvmHookArtifactManager when context has no mailbox', () => {
|
|
30
|
+
const manager = provider.createHookArtifactManager(FAKE_METADATA, {});
|
|
31
|
+
expect(manager).to.be.instanceOf(SvmHookArtifactManager);
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
describe('createIsmArtifactManager', () => {
|
|
35
|
+
it('returns SvmIsmArtifactManager', () => {
|
|
36
|
+
const manager = provider.createIsmArtifactManager(FAKE_METADATA);
|
|
37
|
+
expect(manager).to.be.instanceOf(SvmIsmArtifactManager);
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
describe('createWarpArtifactManager', () => {
|
|
41
|
+
it('returns SvmWarpArtifactManager', () => {
|
|
42
|
+
const manager = provider.createWarpArtifactManager(FAKE_METADATA);
|
|
43
|
+
expect(manager).to.be.instanceOf(SvmWarpArtifactManager);
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
describe('getRpcUrls validation', () => {
|
|
47
|
+
it('throws when no rpcUrls', () => {
|
|
48
|
+
const noRpc = { ...FAKE_METADATA, rpcUrls: [] };
|
|
49
|
+
expect(() => provider.createIsmArtifactManager(noRpc)).to.throw('At least one RPC URL is required');
|
|
50
|
+
});
|
|
51
|
+
it('throws when rpcUrls is undefined', () => {
|
|
52
|
+
const noRpc = { ...FAKE_METADATA, rpcUrls: undefined };
|
|
53
|
+
expect(() => provider.createIsmArtifactManager(noRpc)).to.throw('At least one RPC URL is required');
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
//# sourceMappingURL=protocol.unit-test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"protocol.unit-test.js","sourceRoot":"","sources":["../../src/tests/protocol.unit-test.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hyperlane-xyz/sealevel-sdk",
|
|
3
|
-
"version": "27.
|
|
3
|
+
"version": "27.1.0",
|
|
4
4
|
"description": "Hand-crafted Solana/SVM client for Hyperlane Sealevel programs",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"hyperlane",
|
|
@@ -31,8 +31,8 @@
|
|
|
31
31
|
"@solana-program/loader-v3": "^0.3.0",
|
|
32
32
|
"@solana-program/system": "^0.12.0",
|
|
33
33
|
"@solana/kit": "^6.1.0",
|
|
34
|
-
"@hyperlane-xyz/provider-sdk": "3.0
|
|
35
|
-
"@hyperlane-xyz/utils": "27.
|
|
34
|
+
"@hyperlane-xyz/provider-sdk": "3.1.0",
|
|
35
|
+
"@hyperlane-xyz/utils": "27.1.0"
|
|
36
36
|
},
|
|
37
37
|
"devDependencies": {
|
|
38
38
|
"@eslint/js": "^9.39.2",
|
|
@@ -52,11 +52,11 @@
|
|
|
52
52
|
"tsx": "^4.19.1",
|
|
53
53
|
"typescript": "5.8.3",
|
|
54
54
|
"typescript-eslint": "^8.54.0",
|
|
55
|
-
"@hyperlane-xyz/eslint-config": "^27.
|
|
56
|
-
"@hyperlane-xyz/tsconfig": "^27.
|
|
55
|
+
"@hyperlane-xyz/eslint-config": "^27.1.0",
|
|
56
|
+
"@hyperlane-xyz/tsconfig": "^27.1.0"
|
|
57
57
|
},
|
|
58
58
|
"scripts": {
|
|
59
|
-
"build": "
|
|
59
|
+
"build": "rm -rf ./dist && tsc",
|
|
60
60
|
"program:build": "(cd ../../rust/sealevel/programs && bash build-programs.sh)",
|
|
61
61
|
"program:generate": "node scripts/generate-program-bytes.mjs",
|
|
62
62
|
"program:check": "node scripts/check-program-bytes-hash.mjs",
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Auto-generated SVM core deployment addresses from rust/sealevel/environments/mainnet3.
|
|
3
|
-
* DO NOT EDIT — regenerate with: node scripts/generate-core-addresses.mjs
|
|
4
|
-
*/
|
|
5
|
-
export interface SvmCoreAddresses {
|
|
6
|
-
mailbox: string;
|
|
7
|
-
validatorAnnounce: string;
|
|
8
|
-
multisigIsmMessageId: string;
|
|
9
|
-
igpProgramId: string;
|
|
10
|
-
overheadIgpAccount: string;
|
|
11
|
-
igpAccount: string;
|
|
12
|
-
}
|
|
13
|
-
export declare const SVM_CORE_ADDRESSES: Record<string, SvmCoreAddresses>;
|
|
14
|
-
//# sourceMappingURL=core-addresses.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"core-addresses.d.ts","sourceRoot":"","sources":["../../src/generated/core-addresses.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,MAAM,CAAC;IAChB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,YAAY,EAAE,MAAM,CAAC;IACrB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,eAAO,MAAM,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAiD/D,CAAC"}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Auto-generated SVM core deployment addresses from rust/sealevel/environments/mainnet3.
|
|
3
|
-
* DO NOT EDIT — regenerate with: node scripts/generate-core-addresses.mjs
|
|
4
|
-
*/
|
|
5
|
-
export const SVM_CORE_ADDRESSES = {
|
|
6
|
-
eclipsemainnet: {
|
|
7
|
-
mailbox: 'EitxJuv2iBjsg2d7jVy2LDC1e2zBrx4GB5Y9h2Ko3A9Y',
|
|
8
|
-
validatorAnnounce: 'Hqnn593pqDZWLy6bKZ4NbY767wFhUNBShDrLktuQa3Q2',
|
|
9
|
-
multisigIsmMessageId: 'ByNa6hu4Wuc3ytqnZdnoyacUuZGDiZpT2CujdjE2Hpth',
|
|
10
|
-
igpProgramId: 'Hs7KVBU67nBnWhDPZkEFwWqrFMUfJbmY2DQ4gmCZfaZp',
|
|
11
|
-
overheadIgpAccount: '3Wp4qKkgf4tjXz1soGyTSndCgBPLZFSrZkiDZ8Qp9EEj',
|
|
12
|
-
igpAccount: 'ABb3i11z7wKoGCfeRQNQbVYWjAm7jG7HzZnDLV4RKRbK',
|
|
13
|
-
},
|
|
14
|
-
solanamainnet: {
|
|
15
|
-
mailbox: 'E588QtVUvresuXq2KoNEwAmoifCzYGpRBdHByN9KQMbi',
|
|
16
|
-
validatorAnnounce: 'pRgs5vN4Pj7WvFbxf6QDHizo2njq2uksqEUbaSghVA8',
|
|
17
|
-
multisigIsmMessageId: 'LwNfVYMDzAe5dCJgA5CipTZcT34Eyf74zLr81K91jxk',
|
|
18
|
-
igpProgramId: 'BhNcatUDC2D5JTyeaqrdSukiVFsEHK7e3hVmKMztwefv',
|
|
19
|
-
overheadIgpAccount: 'AkeHBbE5JkwVppujCQQ6WuxsVsJtruBAjUo6fDCFp6fF',
|
|
20
|
-
igpAccount: 'JAvHW21tYXE9dtdG83DReqU2b4LUexFuCbtJT5tF8X6M',
|
|
21
|
-
},
|
|
22
|
-
solaxy: {
|
|
23
|
-
mailbox: '6VdnmP8MfYkPNMwyU2ZY9S3ickYyewF58LPC38y9FAVU',
|
|
24
|
-
validatorAnnounce: '28S9ToSehVxdE7rTGEAA3vAX3AchHJh1MXcq9AeM1rL8',
|
|
25
|
-
multisigIsmMessageId: 'BMyTd7BBTw6ewENKkvzQsmPXPBHsTDW4oLHSYkv78spP',
|
|
26
|
-
igpProgramId: 'VG7YDF5Am2hrgyydE2ufdusdtw5DjgzXJLFxn9p8ehU',
|
|
27
|
-
overheadIgpAccount: '7z1QjgLLxowA9RA9QBuiC72Tc6aC1XjtA5zdH9LJHm1a',
|
|
28
|
-
igpAccount: '3SDcBbfZUF9ykR3yudYN198ja3KJSq17Q3rKw7JKfJR6',
|
|
29
|
-
},
|
|
30
|
-
sonicsvm: {
|
|
31
|
-
mailbox: '4MaM9GQZ753NhUcXH1pPsQwof1Mf3ZnjeNF4yx6S3p3N',
|
|
32
|
-
validatorAnnounce: '4LxdrQjqUzueko4MEn3cYCniEtcAZ6AxuHot2Fp3jskH',
|
|
33
|
-
multisigIsmMessageId: '2sCw3FozxoNinZV923Q6XNvaMjRsmPSFAKnNYYnWsqD3',
|
|
34
|
-
igpProgramId: '3kd3K1yymsfYoqzNnktLwpKXKeB9Y2PRf9rfb31k4o13',
|
|
35
|
-
overheadIgpAccount: '7VResHbw6jRVUa8qfD6e1cbzGmErcLGwgx4o7mLhZief',
|
|
36
|
-
igpAccount: 'Bxof4ZpgLtoHoxBq6AGDCJUtVxUoE9LXkx8iizkDGQPz',
|
|
37
|
-
},
|
|
38
|
-
soon: {
|
|
39
|
-
mailbox: 'Mj7GE6LZiJUZFTgabmNkFoY2o6JCEwCMKopSUUC3kqj',
|
|
40
|
-
validatorAnnounce: 'GFqF38mSacfvbJRKkhmjJvSkzTEKemSNVoWi4Q94ZPvz',
|
|
41
|
-
multisigIsmMessageId: '4fPoa26ayqY1cwY3AcqUPvdLLNHpjJGdDQevtnTLAAnH',
|
|
42
|
-
igpProgramId: '5AAMBemjUrAprKJzi22Si9pyYhK8vTr7Jpti7LEXo6d8',
|
|
43
|
-
overheadIgpAccount: 'GctmRsKQM5VLPrUPpsQ7Kc7RaVKNC2Fev31n1KtLkj8A',
|
|
44
|
-
igpAccount: 'Dsem8R6mkrpNoNb6CRUEjEZRP2hKRC24thyCkVr8cNYZ',
|
|
45
|
-
},
|
|
46
|
-
svmbnb: {
|
|
47
|
-
mailbox: 'GzwNZJ2EXUWQCEoV6zoBGLxkdsnjkLvm6zHReMEC2JSA',
|
|
48
|
-
validatorAnnounce: 'Gh4LUk91bj4QGYWsBY4QyDGhs68n8Maf8oeTRZoQZAEf',
|
|
49
|
-
multisigIsmMessageId: '3aD11eiNt2ZjmgiQayNRyZfp7hXBRS9hbeyPbk7cmTyv',
|
|
50
|
-
igpProgramId: 'ALUFQNqrKA9FgxvzkDvp2K5M94P3bvJYzPvrB8LSe6Ee',
|
|
51
|
-
overheadIgpAccount: 'FcXbqeqf23ToXfFXKJisQvCnRu3GjCEunNtkqvxAcNWF',
|
|
52
|
-
igpAccount: '76JNRGvHbER5CL7X4Mw6qpzvvKDW3syyfZ5LNXfY53sC',
|
|
53
|
-
},
|
|
54
|
-
};
|
|
55
|
-
//# sourceMappingURL=core-addresses.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"core-addresses.js","sourceRoot":"","sources":["../../src/generated/core-addresses.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAWH,MAAM,CAAC,MAAM,kBAAkB,GAAqC;IAClE,cAAc,EAAE;QACd,OAAO,EAAE,8CAA8C;QACvD,iBAAiB,EAAE,8CAA8C;QACjE,oBAAoB,EAAE,8CAA8C;QACpE,YAAY,EAAE,8CAA8C;QAC5D,kBAAkB,EAAE,8CAA8C;QAClE,UAAU,EAAE,8CAA8C;KAC3D;IACD,aAAa,EAAE;QACb,OAAO,EAAE,8CAA8C;QACvD,iBAAiB,EAAE,6CAA6C;QAChE,oBAAoB,EAAE,6CAA6C;QACnE,YAAY,EAAE,8CAA8C;QAC5D,kBAAkB,EAAE,8CAA8C;QAClE,UAAU,EAAE,8CAA8C;KAC3D;IACD,MAAM,EAAE;QACN,OAAO,EAAE,8CAA8C;QACvD,iBAAiB,EAAE,8CAA8C;QACjE,oBAAoB,EAAE,8CAA8C;QACpE,YAAY,EAAE,6CAA6C;QAC3D,kBAAkB,EAAE,8CAA8C;QAClE,UAAU,EAAE,8CAA8C;KAC3D;IACD,QAAQ,EAAE;QACR,OAAO,EAAE,8CAA8C;QACvD,iBAAiB,EAAE,8CAA8C;QACjE,oBAAoB,EAAE,8CAA8C;QACpE,YAAY,EAAE,8CAA8C;QAC5D,kBAAkB,EAAE,8CAA8C;QAClE,UAAU,EAAE,8CAA8C;KAC3D;IACD,IAAI,EAAE;QACJ,OAAO,EAAE,6CAA6C;QACtD,iBAAiB,EAAE,8CAA8C;QACjE,oBAAoB,EAAE,8CAA8C;QACpE,YAAY,EAAE,8CAA8C;QAC5D,kBAAkB,EAAE,8CAA8C;QAClE,UAAU,EAAE,8CAA8C;KAC3D;IACD,MAAM,EAAE;QACN,OAAO,EAAE,8CAA8C;QACvD,iBAAiB,EAAE,8CAA8C;QACjE,oBAAoB,EAAE,8CAA8C;QACpE,YAAY,EAAE,8CAA8C;QAC5D,kBAAkB,EAAE,8CAA8C;QAClE,UAAU,EAAE,8CAA8C;KAC3D;CACF,CAAC"}
|