| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- // contracts/Implementation.sol
- // SPDX-License-Identifier: Apache 2
- pragma solidity ^0.8.0;
- pragma experimental ABIEncoderV2;
- import "./Governance.sol";
- import "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol";
- contract Implementation is Governance {
- event LogMessagePublished(address indexed sender, uint64 sequence, uint32 nonce, bytes payload, uint8 consistencyLevel);
- // Publish a message to be attested by the Wormhole network
- function publishMessage(
- uint32 nonce,
- bytes memory payload,
- uint8 consistencyLevel
- ) public payable returns (uint64 sequence) {
- // check fee
- require(msg.value == messageFee(), "invalid fee");
- sequence = useSequence(msg.sender);
- // emit log
- emit LogMessagePublished(msg.sender, sequence, nonce, payload, consistencyLevel);
- }
- function useSequence(address emitter) internal returns (uint64 sequence) {
- sequence = nextSequence(emitter);
- setNextSequence(emitter, sequence + 1);
- }
- function initialize(address[] memory initialGuardians, uint16 chainId, uint16 governanceChainId, bytes32 governanceContract) initializer public {
- require(initialGuardians.length > 0, "no guardians specified");
- Structs.GuardianSet memory initialGuardianSet = Structs.GuardianSet({
- keys : initialGuardians,
- expirationTime : 0
- });
- storeGuardianSet(initialGuardianSet, 0);
- // initial guardian set index is 0, which is the default value of the storage slot anyways
- setChainId(chainId);
- setGovernanceChainId(governanceChainId);
- setGovernanceContract(governanceContract);
- }
- modifier initializer() {
- address implementation = ERC1967Upgrade._getImplementation();
- require(
- !isInitialized(implementation),
- "already initialized"
- );
- setInitialized(implementation);
- _;
- }
- fallback() external payable {revert("unsupported");}
- receive() external payable {revert("the Wormhole contract does not accept assets");}
- }
|