- Introduced Aggregator.sol for Chainlink-compatible oracle functionality, including round-based updates and access control. - Added OracleWithCCIP.sol to extend Aggregator with CCIP cross-chain messaging capabilities. - Created .gitmodules to include OpenZeppelin contracts as a submodule. - Developed a comprehensive deployment guide in NEXT_STEPS_COMPLETE_GUIDE.md for Phase 2 and smart contract deployment. - Implemented Vite configuration for the orchestration portal, supporting both Vue and React frameworks. - Added server-side logic for the Multi-Cloud Orchestration Portal, including API endpoints for environment management and monitoring. - Created scripts for resource import and usage validation across non-US regions. - Added tests for CCIP error handling and integration to ensure robust functionality. - Included various new files and directories for the orchestration portal and deployment scripts.
73 lines
2.1 KiB
Solidity
73 lines
2.1 KiB
Solidity
// SPDX-License-Identifier: MIT
|
|
pragma solidity ^0.8.19;
|
|
|
|
/**
|
|
* @title Wrapped Ether (WETH9)
|
|
* @notice Standard implementation of WETH9 for ChainID 138
|
|
* @dev Based on the canonical WETH9 implementation
|
|
*/
|
|
contract WETH {
|
|
string public name = "Wrapped Ether";
|
|
string public symbol = "WETH";
|
|
uint8 public decimals = 18;
|
|
|
|
event Approval(address indexed src, address indexed guy, uint256 wad);
|
|
event Transfer(address indexed src, address indexed dst, uint256 wad);
|
|
event Deposit(address indexed dst, uint256 wad);
|
|
event Withdrawal(address indexed src, uint256 wad);
|
|
|
|
mapping(address => uint256) public balanceOf;
|
|
mapping(address => mapping(address => uint256)) public allowance;
|
|
|
|
receive() external payable {
|
|
deposit();
|
|
}
|
|
|
|
function deposit() public payable {
|
|
balanceOf[msg.sender] += msg.value;
|
|
emit Deposit(msg.sender, msg.value);
|
|
}
|
|
|
|
function withdraw(uint256 wad) public {
|
|
require(balanceOf[msg.sender] >= wad, "WETH: insufficient balance");
|
|
balanceOf[msg.sender] -= wad;
|
|
payable(msg.sender).transfer(wad);
|
|
emit Withdrawal(msg.sender, wad);
|
|
}
|
|
|
|
function totalSupply() public view returns (uint256) {
|
|
return address(this).balance;
|
|
}
|
|
|
|
function approve(address guy, uint256 wad) public returns (bool) {
|
|
allowance[msg.sender][guy] = wad;
|
|
emit Approval(msg.sender, guy, wad);
|
|
return true;
|
|
}
|
|
|
|
function transfer(address dst, uint256 wad) public returns (bool) {
|
|
return transferFrom(msg.sender, dst, wad);
|
|
}
|
|
|
|
function transferFrom(
|
|
address src,
|
|
address dst,
|
|
uint256 wad
|
|
) public returns (bool) {
|
|
require(balanceOf[src] >= wad, "WETH: insufficient balance");
|
|
|
|
if (src != msg.sender && allowance[src][msg.sender] != type(uint256).max) {
|
|
require(allowance[src][msg.sender] >= wad, "WETH: insufficient allowance");
|
|
allowance[src][msg.sender] -= wad;
|
|
}
|
|
|
|
balanceOf[src] -= wad;
|
|
balanceOf[dst] += wad;
|
|
|
|
emit Transfer(src, dst, wad);
|
|
|
|
return true;
|
|
}
|
|
}
|
|
|