Skip to content

Commit a83faaf

Browse files
committed
Merge branch 'main' into solana/re-deploy
2 parents c9be797 + f89a0b6 commit a83faaf

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

41 files changed

+1226
-1442
lines changed

LICENSE

+10-199
Original file line numberDiff line numberDiff line change
@@ -1,202 +1,13 @@
1+
Copyright 2024 Wormhole Project Contributors
12

2-
Apache License
3-
Version 2.0, January 2004
4-
http://www.apache.org/licenses/
3+
Licensed under the Apache License, Version 2.0 (the "License");
4+
you may not use this file except in compliance with the License.
5+
You may obtain a copy of the License at
56

6-
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
7+
http://www.apache.org/licenses/LICENSE-2.0
78

8-
1. Definitions.
9-
10-
"License" shall mean the terms and conditions for use, reproduction,
11-
and distribution as defined by Sections 1 through 9 of this document.
12-
13-
"Licensor" shall mean the copyright owner or entity authorized by
14-
the copyright owner that is granting the License.
15-
16-
"Legal Entity" shall mean the union of the acting entity and all
17-
other entities that control, are controlled by, or are under common
18-
control with that entity. For the purposes of this definition,
19-
"control" means (i) the power, direct or indirect, to cause the
20-
direction or management of such entity, whether by contract or
21-
otherwise, or (ii) ownership of fifty percent (50%) or more of the
22-
outstanding shares, or (iii) beneficial ownership of such entity.
23-
24-
"You" (or "Your") shall mean an individual or Legal Entity
25-
exercising permissions granted by this License.
26-
27-
"Source" form shall mean the preferred form for making modifications,
28-
including but not limited to software source code, documentation
29-
source, and configuration files.
30-
31-
"Object" form shall mean any form resulting from mechanical
32-
transformation or translation of a Source form, including but
33-
not limited to compiled object code, generated documentation,
34-
and conversions to other media types.
35-
36-
"Work" shall mean the work of authorship, whether in Source or
37-
Object form, made available under the License, as indicated by a
38-
copyright notice that is included in or attached to the work
39-
(an example is provided in the Appendix below).
40-
41-
"Derivative Works" shall mean any work, whether in Source or Object
42-
form, that is based on (or derived from) the Work and for which the
43-
editorial revisions, annotations, elaborations, or other modifications
44-
represent, as a whole, an original work of authorship. For the purposes
45-
of this License, Derivative Works shall not include works that remain
46-
separable from, or merely link (or bind by name) to the interfaces of,
47-
the Work and Derivative Works thereof.
48-
49-
"Contribution" shall mean any work of authorship, including
50-
the original version of the Work and any modifications or additions
51-
to that Work or Derivative Works thereof, that is intentionally
52-
submitted to Licensor for inclusion in the Work by the copyright owner
53-
or by an individual or Legal Entity authorized to submit on behalf of
54-
the copyright owner. For the purposes of this definition, "submitted"
55-
means any form of electronic, verbal, or written communication sent
56-
to the Licensor or its representatives, including but not limited to
57-
communication on electronic mailing lists, source code control systems,
58-
and issue tracking systems that are managed by, or on behalf of, the
59-
Licensor for the purpose of discussing and improving the Work, but
60-
excluding communication that is conspicuously marked or otherwise
61-
designated in writing by the copyright owner as "Not a Contribution."
62-
63-
"Contributor" shall mean Licensor and any individual or Legal Entity
64-
on behalf of whom a Contribution has been received by Licensor and
65-
subsequently incorporated within the Work.
66-
67-
2. Grant of Copyright License. Subject to the terms and conditions of
68-
this License, each Contributor hereby grants to You a perpetual,
69-
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
70-
copyright license to reproduce, prepare Derivative Works of,
71-
publicly display, publicly perform, sublicense, and distribute the
72-
Work and such Derivative Works in Source or Object form.
73-
74-
3. Grant of Patent License. Subject to the terms and conditions of
75-
this License, each Contributor hereby grants to You a perpetual,
76-
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
77-
(except as stated in this section) patent license to make, have made,
78-
use, offer to sell, sell, import, and otherwise transfer the Work,
79-
where such license applies only to those patent claims licensable
80-
by such Contributor that are necessarily infringed by their
81-
Contribution(s) alone or by combination of their Contribution(s)
82-
with the Work to which such Contribution(s) was submitted. If You
83-
institute patent litigation against any entity (including a
84-
cross-claim or counterclaim in a lawsuit) alleging that the Work
85-
or a Contribution incorporated within the Work constitutes direct
86-
or contributory patent infringement, then any patent licenses
87-
granted to You under this License for that Work shall terminate
88-
as of the date such litigation is filed.
89-
90-
4. Redistribution. You may reproduce and distribute copies of the
91-
Work or Derivative Works thereof in any medium, with or without
92-
modifications, and in Source or Object form, provided that You
93-
meet the following conditions:
94-
95-
(a) You must give any other recipients of the Work or
96-
Derivative Works a copy of this License; and
97-
98-
(b) You must cause any modified files to carry prominent notices
99-
stating that You changed the files; and
100-
101-
(c) You must retain, in the Source form of any Derivative Works
102-
that You distribute, all copyright, patent, trademark, and
103-
attribution notices from the Source form of the Work,
104-
excluding those notices that do not pertain to any part of
105-
the Derivative Works; and
106-
107-
(d) If the Work includes a "NOTICE" text file as part of its
108-
distribution, then any Derivative Works that You distribute must
109-
include a readable copy of the attribution notices contained
110-
within such NOTICE file, excluding those notices that do not
111-
pertain to any part of the Derivative Works, in at least one
112-
of the following places: within a NOTICE text file distributed
113-
as part of the Derivative Works; within the Source form or
114-
documentation, if provided along with the Derivative Works; or,
115-
within a display generated by the Derivative Works, if and
116-
wherever such third-party notices normally appear. The contents
117-
of the NOTICE file are for informational purposes only and
118-
do not modify the License. You may add Your own attribution
119-
notices within Derivative Works that You distribute, alongside
120-
or as an addendum to the NOTICE text from the Work, provided
121-
that such additional attribution notices cannot be construed
122-
as modifying the License.
123-
124-
You may add Your own copyright statement to Your modifications and
125-
may provide additional or different license terms and conditions
126-
for use, reproduction, or distribution of Your modifications, or
127-
for any such Derivative Works as a whole, provided Your use,
128-
reproduction, and distribution of the Work otherwise complies with
129-
the conditions stated in this License.
130-
131-
5. Submission of Contributions. Unless You explicitly state otherwise,
132-
any Contribution intentionally submitted for inclusion in the Work
133-
by You to the Licensor shall be under the terms and conditions of
134-
this License, without any additional terms or conditions.
135-
Notwithstanding the above, nothing herein shall supersede or modify
136-
the terms of any separate license agreement you may have executed
137-
with Licensor regarding such Contributions.
138-
139-
6. Trademarks. This License does not grant permission to use the trade
140-
names, trademarks, service marks, or product names of the Licensor,
141-
except as required for reasonable and customary use in describing the
142-
origin of the Work and reproducing the content of the NOTICE file.
143-
144-
7. Disclaimer of Warranty. Unless required by applicable law or
145-
agreed to in writing, Licensor provides the Work (and each
146-
Contributor provides its Contributions) on an "AS IS" BASIS,
147-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
148-
implied, including, without limitation, any warranties or conditions
149-
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
150-
PARTICULAR PURPOSE. You are solely responsible for determining the
151-
appropriateness of using or redistributing the Work and assume any
152-
risks associated with Your exercise of permissions under this License.
153-
154-
8. Limitation of Liability. In no event and under no legal theory,
155-
whether in tort (including negligence), contract, or otherwise,
156-
unless required by applicable law (such as deliberate and grossly
157-
negligent acts) or agreed to in writing, shall any Contributor be
158-
liable to You for damages, including any direct, indirect, special,
159-
incidental, or consequential damages of any character arising as a
160-
result of this License or out of the use or inability to use the
161-
Work (including but not limited to damages for loss of goodwill,
162-
work stoppage, computer failure or malfunction, or any and all
163-
other commercial damages or losses), even if such Contributor
164-
has been advised of the possibility of such damages.
165-
166-
9. Accepting Warranty or Additional Liability. While redistributing
167-
the Work or Derivative Works thereof, You may choose to offer,
168-
and charge a fee for, acceptance of support, warranty, indemnity,
169-
or other liability obligations and/or rights consistent with this
170-
License. However, in accepting such obligations, You may act only
171-
on Your own behalf and on Your sole responsibility, not on behalf
172-
of any other Contributor, and only if You agree to indemnify,
173-
defend, and hold each Contributor harmless for any liability
174-
incurred by, or claims asserted against, such Contributor by reason
175-
of your accepting any such warranty or additional liability.
176-
177-
END OF TERMS AND CONDITIONS
178-
179-
APPENDIX: How to apply the Apache License to your work.
180-
181-
To apply the Apache License to your work, attach the following
182-
boilerplate notice, with the fields enclosed by brackets "[]"
183-
replaced with your own identifying information. (Don't include
184-
the brackets!) The text should be enclosed in the appropriate
185-
comment syntax for the file format. We also recommend that a
186-
file or class name and description of purpose be included on the
187-
same "printed page" as the copyright notice for easier
188-
identification within third-party archives.
189-
190-
Copyright 2024 Wormhole Foundation
191-
192-
Licensed under the Apache License, Version 2.0 (the "License");
193-
you may not use this file except in compliance with the License.
194-
You may obtain a copy of the License at
195-
196-
http://www.apache.org/licenses/LICENSE-2.0
197-
198-
Unless required by applicable law or agreed to in writing, software
199-
distributed under the License is distributed on an "AS IS" BASIS,
200-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
201-
See the License for the specific language governing permissions and
202-
limitations under the License.
9+
Unless required by applicable law or agreed to in writing, software
10+
distributed under the License is distributed on an "AS IS" BASIS,
11+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12+
See the License for the specific language governing permissions and
13+
limitations under the License.
245 KB
Binary file not shown.
192 KB
Binary file not shown.
128 KB
Binary file not shown.
734 KB
Binary file not shown.

evm/script/DeployHubContractsBaseImpl.s.sol

+5-10
Original file line numberDiff line numberDiff line change
@@ -16,11 +16,6 @@ import {HubSolanaMessageDispatcher} from "src/HubSolanaMessageDispatcher.sol";
1616
import {HubSolanaSpokeVoteDecoder} from "src/HubSolanaSpokeVoteDecoder.sol";
1717

1818
abstract contract DeployHubContractsBaseImpl is Script {
19-
// This key should not be used for a production deploy. Instead, the `DEPLOYER_PRIVATE_KEY` environment variable
20-
// should be set.
21-
uint256 constant DEFAULT_DEPLOYER_PRIVATE_KEY =
22-
uint256(0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80);
23-
2419
struct DeploymentConfiguration {
2520
uint256 minDelay;
2621
string name;
@@ -55,12 +50,12 @@ abstract contract DeployHubContractsBaseImpl is Script {
5550

5651
function _getDeploymentConfiguration() internal virtual returns (DeploymentConfiguration memory);
5752

53+
/// @notice Creates a wallet for deployment using the private key from environment
54+
/// @dev Requires DEPLOYER_PRIVATE_KEY to be set in the environment
55+
/// @return wallet The wallet to be used for deployment
5856
function _deploymentWallet() internal virtual returns (Vm.Wallet memory) {
59-
uint256 deployerPrivateKey = vm.envOr("DEPLOYER_PRIVATE_KEY", DEFAULT_DEPLOYER_PRIVATE_KEY);
60-
61-
Vm.Wallet memory wallet = vm.createWallet(deployerPrivateKey);
62-
if (deployerPrivateKey == DEFAULT_DEPLOYER_PRIVATE_KEY) revert InvalidAddressConfiguration();
63-
return wallet;
57+
uint256 deployerPrivateKey = vm.envUint("DEPLOYER_PRIVATE_KEY");
58+
return vm.createWallet(deployerPrivateKey);
6459
}
6560

6661
function run() public virtual returns (DeployedContracts memory) {

evm/script/DeployHubContractsEthDevnet1.sol

+1-1
Original file line numberDiff line numberDiff line change
@@ -44,7 +44,7 @@ contract DeployHubContractsEthDevnet1 is DeployHubContractsBaseImpl {
4444
minimumExtensionTime: 1 minutes,
4545
consistencyLevel: 0,
4646
initialMaxQueryTimestampOffset: 10 minutes,
47-
solanaTokenDecimals: 8
47+
solanaTokenDecimals: 6
4848
});
4949
}
5050
}

evm/script/DeployHubContractsHolesky.sol

+1-1
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,7 @@ contract DeployHubContractsHolesky is DeployHubContractsBaseImpl {
2222
minimumExtensionTime: 1 minutes,
2323
consistencyLevel: 0,
2424
initialMaxQueryTimestampOffset: 10 minutes,
25-
solanaTokenDecimals: 8
25+
solanaTokenDecimals: 6
2626
});
2727
}
2828
}

evm/script/DeploySpokeContractsBaseImpl.sol

+5-10
Original file line numberDiff line numberDiff line change
@@ -12,10 +12,6 @@ import {SpokeMessageExecutor} from "src/SpokeMessageExecutor.sol";
1212
import {SpokeAirlock} from "src/SpokeAirlock.sol";
1313

1414
abstract contract DeploySpokeContractsBaseImpl is Script {
15-
// This should not be used for a production deploy the correct address will be set as an environment variable.
16-
uint256 constant DEFAULT_DEPLOYER_PRIVATE_KEY =
17-
uint256(0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80);
18-
1915
string constant DEFAULT_DEPLOY_VERSION = "v1";
2016

2117
struct DeploymentConfiguration {
@@ -39,13 +35,12 @@ abstract contract DeploySpokeContractsBaseImpl is Script {
3935

4036
function _getDeploymentConfiguration() internal virtual returns (DeploymentConfiguration memory);
4137

38+
/// @notice Creates a wallet for deployment using the private key from environment
39+
/// @dev Requires DEPLOYER_PRIVATE_KEY to be set in the environment
40+
/// @return wallet The wallet to be used for deployment
4241
function _deploymentWallet() internal virtual returns (Vm.Wallet memory) {
43-
uint256 deployerPrivateKey = vm.envOr("DEPLOYER_PRIVATE_KEY", DEFAULT_DEPLOYER_PRIVATE_KEY);
44-
45-
Vm.Wallet memory wallet = vm.createWallet(deployerPrivateKey);
46-
Vm.Wallet memory defaultWallet = vm.createWallet(DEFAULT_DEPLOYER_PRIVATE_KEY);
47-
if (defaultWallet.addr == wallet.addr) revert InvalidAddressConfiguration();
48-
return wallet;
42+
uint256 deployerPrivateKey = vm.envUint("DEPLOYER_PRIVATE_KEY");
43+
return vm.createWallet(deployerPrivateKey);
4944
}
5045

5146
function run() public returns (DeployedContracts memory) {

evm/script/RegisterSpokesOnHubTestnet.s.sol

+5-10
Original file line numberDiff line numberDiff line change
@@ -12,19 +12,14 @@ contract RegisterSpokesOnHubTestnet is Script {
1212
bytes32 SOLANA_SPOKE = bytes32(0xabd58849f17e52708082849880f862589c11f972cb372d73b0cd219722cd0f22);
1313
address TIMELOCK = 0x1054f49899Af83e0c55375d54D2F57488cFC8606; // TODO Timelock address
1414

15-
// This key should not be used for a production deploy. Instead, the `DEPLOYER_PRIVATE_KEY` environment variable
16-
// should be set.
17-
uint256 constant DEFAULT_DEPLOYER_PRIVATE_KEY =
18-
uint256(0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80);
19-
2015
error InvalidAddressConfiguration();
2116

17+
/// @notice Creates a wallet for deployment using the private key from environment
18+
/// @dev Requires DEPLOYER_PRIVATE_KEY to be set in the environment
19+
/// @return wallet The wallet to be used for deployment
2220
function _deploymentWallet() internal virtual returns (Vm.Wallet memory) {
23-
uint256 deployerPrivateKey = vm.envOr("DEPLOYER_PRIVATE_KEY", DEFAULT_DEPLOYER_PRIVATE_KEY);
24-
25-
Vm.Wallet memory wallet = vm.createWallet(deployerPrivateKey);
26-
if (deployerPrivateKey == DEFAULT_DEPLOYER_PRIVATE_KEY) revert InvalidAddressConfiguration();
27-
return wallet;
21+
uint256 deployerPrivateKey = vm.envUint("DEPLOYER_PRIVATE_KEY");
22+
return vm.createWallet(deployerPrivateKey);
2823
}
2924

3025
function run() public virtual {

evm/src/HubSolanaSpokeVoteDecoder.sol

+12-8
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,7 @@ import {BytesParsing} from "wormhole-sdk/libraries/BytesParsing.sol";
2121
/// @title HubSolanaSpokeVoteDecoder
2222
/// @author [ScopeLift](https://scopelift.co)
2323
/// @notice A contract that parses a specific wormhole query type from the Solana `SpokeVoteAggregator`.
24+
/// @dev This contract handles decimal scaling to match the hub chain's decimals when decoding votes from Solana.
2425
contract HubSolanaSpokeVoteDecoder is ISpokeVoteDecoder, QueryResponse, ERC165 {
2526
using BytesParsing for bytes;
2627

@@ -35,7 +36,8 @@ contract HubSolanaSpokeVoteDecoder is ISpokeVoteDecoder, QueryResponse, ERC165 {
3536
/// @notice The decimals of the token on the hub
3637
uint8 public immutable HUB_TOKEN_DECIMALS;
3738

38-
/// @notice The decimals of the token on solana
39+
/// @notice The decimals of the token on Solana (typically 6 for SPL tokens)
40+
/// @dev Used to scale vote amounts from Solana to match the hub chain's decimal precision
3941
uint8 public immutable SOLANA_TOKEN_DECIMALS;
4042

4143
error TooManySolanaPdaResults(uint256 resultsLength);
@@ -169,7 +171,7 @@ contract HubSolanaSpokeVoteDecoder is ISpokeVoteDecoder, QueryResponse, ERC165 {
169171
if (_fromDecimals == _toDecimals) return _amount;
170172

171173
if (_fromDecimals > _toDecimals) return _amount / (10 ** (_fromDecimals - _toDecimals));
172-
else return _amount * (10 ** (_toDecimals - _fromDecimals));
174+
return _amount * (10 ** (_toDecimals - _fromDecimals));
173175
}
174176

175177
/// @notice Reverse the endianness of the passed in integer.
@@ -179,12 +181,14 @@ contract HubSolanaSpokeVoteDecoder is ISpokeVoteDecoder, QueryResponse, ERC165 {
179181
/// https://github.com/wormholelabs-xyz/example-queries-solana-pda/blob/4a01a0a6018b36a1d38d326362bfb672c5061c5f/src/OwnerVerifier.sol#L52.
180182
function _reverse(uint64 _input) internal pure returns (uint64) {
181183
uint64 v = _input;
182-
// swap bytes
183-
v = ((v & 0xFF00FF00FF00FF00) >> 8) | ((v & 0x00FF00FF00FF00FF) << 8);
184-
// swap 2-byte long pairs
185-
v = ((v & 0xFFFF0000FFFF0000) >> 16) | ((v & 0x0000FFFF0000FFFF) << 16);
186-
// swap 4-byte long pairs
187-
v = (v >> 32) | (v << 32);
184+
unchecked {
185+
// swap bytes
186+
v = ((v & 0xFF00FF00FF00FF00) >> 8) | ((v & 0x00FF00FF00FF00FF) << 8);
187+
// swap 2-byte long pairs
188+
v = ((v & 0xFFFF0000FFFF0000) >> 16) | ((v & 0x0000FFFF0000FFFF) << 16);
189+
// swap 4-byte long pairs
190+
v = (v >> 32) | (v << 32);
191+
}
188192
return v;
189193
}
190194
}

solana/app/deploy/03_create_airlock.ts

-6
Original file line numberDiff line numberDiff line change
@@ -28,18 +28,12 @@ async function main() {
2828
program.programId,
2929
)[0];
3030

31-
const airlockSelfCallPDA: PublicKey = PublicKey.findProgramAddressSync(
32-
[Buffer.from("airlock_self_call")],
33-
program.programId,
34-
)[0];
35-
3631
await program.methods
3732
.initializeSpokeAirlock()
3833
.accounts({
3934
payer: DEPLOYER_AUTHORITY_KEYPAIR.publicKey,
4035
// @ts-ignore
4136
airlock: airlockPDA,
42-
airlockSelfCall: airlockSelfCallPDA,
4337
systemProgram: SystemProgram.programId,
4438
})
4539
.rpc({ skipPreflight: DEBUG });

0 commit comments

Comments
 (0)