Implementation.sol 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. // contracts/Implementation.sol
  2. // SPDX-License-Identifier: Apache 2
  3. pragma solidity ^0.8.0;
  4. pragma experimental ABIEncoderV2;
  5. import "./Governance.sol";
  6. import "@openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol";
  7. contract Implementation is Governance {
  8. event LogMessagePublished(address indexed sender, uint64 sequence, uint32 nonce, bytes payload, uint8 consistencyLevel);
  9. // Publish a message to be attested by the Wormhole network
  10. function publishMessage(
  11. uint32 nonce,
  12. bytes memory payload,
  13. uint8 consistencyLevel
  14. ) public payable returns (uint64 sequence) {
  15. // check fee
  16. require(msg.value == messageFee(), "invalid fee");
  17. sequence = useSequence(msg.sender);
  18. // emit log
  19. emit LogMessagePublished(msg.sender, sequence, nonce, payload, consistencyLevel);
  20. }
  21. function useSequence(address emitter) internal returns (uint64 sequence) {
  22. sequence = nextSequence(emitter);
  23. setNextSequence(emitter, sequence + 1);
  24. }
  25. function initialize(address[] memory initialGuardians, uint16 chainId, uint16 governanceChainId, bytes32 governanceContract) initializer public {
  26. require(initialGuardians.length > 0, "no guardians specified");
  27. Structs.GuardianSet memory initialGuardianSet = Structs.GuardianSet({
  28. keys : initialGuardians,
  29. expirationTime : 0
  30. });
  31. storeGuardianSet(initialGuardianSet, 0);
  32. // initial guardian set index is 0, which is the default value of the storage slot anyways
  33. setChainId(chainId);
  34. setGovernanceChainId(governanceChainId);
  35. setGovernanceContract(governanceContract);
  36. }
  37. modifier initializer() {
  38. address implementation = ERC1967Upgrade._getImplementation();
  39. require(
  40. !isInitialized(implementation),
  41. "already initialized"
  42. );
  43. setInitialized(implementation);
  44. _;
  45. }
  46. fallback() external payable {revert("unsupported");}
  47. receive() external payable {revert("the Wormhole contract does not accept assets");}
  48. }