-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathOFTWrapper.sol
116 lines (106 loc) · 3.88 KB
/
OFTWrapper.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.20;
import {OFTCore, IOFT} from "@layerzerolabs/lz-evm-oapp-v2/contracts/oft/OFTCore.sol";
import {RateLimiter} from "@layerzerolabs/oapp-evm/contracts/oapp/utils/RateLimiter.sol";
import {PaxosTokenV2} from "PaxosToken/contracts/PaxosTokenV2.sol";
/**
* @title OFTWrapper
* @dev This contract is a proxy around LayerZero's OFT standard. The OFTWrapper can be called
* by LayerZero to mint and burn tokens like normal. The OFTWrapper then forwards those requests
* to the underlying token. The underlying token must grant this contract permission to mint and burn.
* @custom:security-contact [email protected]
*/
contract OFTWrapper is OFTCore, RateLimiter {
//The Paxos token
PaxosTokenV2 private immutable paxosToken;
/**
* @dev Constructor for the OFT wrapper contract.
* @param _paxosToken The address of the Paxos token
* @param _lzEndpoint The LayerZero endpoint address.
* @param _delegate The delegate capable of making OApp configurations inside of the endpoint.
*/
constructor(
address _paxosToken,
address _lzEndpoint,
address _delegate,
RateLimitConfig[] memory _rateLimitConfigs
) OFTCore(PaxosTokenV2(_paxosToken).decimals(), _lzEndpoint, _delegate) {
paxosToken = PaxosTokenV2(_paxosToken);
_setRateLimits(_rateLimitConfigs);
}
/**
* @dev See {OFTCore-oftVersion}
*/
function oftVersion()
external
pure
override
returns (bytes4 interfaceId, uint64 version)
{
return (type(IOFT).interfaceId, 1);
}
/**
* @dev Returns underlying token address
*/
function token() public view override returns (address) {
return address(paxosToken);
}
/**
* @dev See {OFTCore-approvalRequired}
*/
function approvalRequired() external pure returns (bool) {
return false;
}
/**
* @dev Sets the rate limits based on RateLimitConfig array. Only callable by the owner.
* @param _rateLimitConfigs An array of RateLimitConfig structures defining the rate limits.
*/
function setRateLimits(
RateLimitConfig[] calldata _rateLimitConfigs
) external onlyOwner {
_setRateLimits(_rateLimitConfigs);
}
/**
* @dev Internal function to perform a debit operation. Calls the underlying token
* to perform the burn via `decreaseSupplyFromAddress`.
* @param _from The address to debit.
* @param _amountLD The amount to send in local decimals.
* @param _minAmountLD The minimum amount to send in local decimals.
* @param _dstEid The destination endpoint ID.
* @return amountSentLD The amount sent in local decimals.
* @return amountReceivedLD The amount received in local decimals on the remote.
*/
function _debit(
address _from,
uint256 _amountLD,
uint256 _minAmountLD,
uint32 _dstEid
)
internal
override
returns (uint256 amountSentLD, uint256 amountReceivedLD)
{
(amountSentLD, amountReceivedLD) = _debitView(
_amountLD,
_minAmountLD,
_dstEid
);
_checkAndUpdateRateLimit(_dstEid, amountSentLD);
paxosToken.decreaseSupplyFromAddress(amountSentLD, _from);
}
/**
* @dev Internal function to perform a credit operation. Calls the underlying token
* to perform the mint via `increaseSupplyToAddress`.
* @param _to The address to credit.
* @param _amountLD The amount to credit in local decimals.
* @return amountReceivedLD The amount received in local decimals.
*/
function _credit(
address _to,
uint256 _amountLD,
uint32 /*_srcEid*/
) internal override returns (uint256 amountReceivedLD) {
paxosToken.increaseSupplyToAddress(_amountLD, _to);
return _amountLD;
}
}