Token USD Coin

Overview ERC20

Price
$1.00 @ 3.620565 GLMR (-0.02%)
Fully Diluted Market Cap
Total Supply:
4,654,772.778514 USDC

Holders:
2,146 addresses
Balance
15,435.853239 USDC

Value
$15,435.85 ( ~55,886.4953 GLMR) [0.3316%]
0x8ccbbcaf58f5422f6efd4034d8e8a3c9120adf79
Loading
[ Download CSV Export  ] 
Loading
[ Download CSV Export  ] 
Loading

OVERVIEW

Wormhole is a generic message passing protocol that connects to multiple chains including Ethereum, Solana, Terra, Binance Smart Chain, Polygon, Avalanche, Oasis, Fantom, Karura, Celo, Acala, Aurora and Klaytn.

Market

Volume (24H):$2,107,546,565.00
Market Capitalization:$28,916,363,177.00
Circulating Supply:28,910,574,459.00 USDC
Market Data Source: Coinmarketcap


Update? Click here to update the token ICO / general information
# Exchange Pair Price  24H Volume % Volume
1
Binance
USDC-USDT$1.00
0.0000368 Btc
$170,919,583.00
170,836,300.396 USDC
0.7395%
2
Bybit
BTC-USDC$1.00
0.0000368 Btc
$99,829,546.00
3,675.206 BTC
0.0000%
3
Bybit
ETH-USDC$1.00
0.0000368 Btc
$74,575,063.00
39,184.948 ETH
0.0002%
4
Uniswap V3 (Arbitrum One)
0X82AF49447D8A07E3BD95BD0D56F35241523FBAB1-0XFF970A61A04B1CA14834A43F5DE4533EBDDB5CC8$1.00
0.0000368 Btc
$73,651,995.00
38,857.881 0X82AF49447D8A07E3BD95BD0D56F35241523FBAB1
0.0002%
5
LBank
ETH-USDC$1.00
0.0000368 Btc
$44,715,308.00
23,489.311 ETH
0.0001%
6
Kraken
USDC-USD$0.9999
0.0000368 Btc
$27,949,790.00
27,952,584.945 USDC
0.1210%
7
Toobit
USDC-USDT$0.9999
0.0000368 Btc
$21,312,251.00
21,315,117.000 USDC
0.0923%
8
Bybit
USDC-USDT$1.00
0.0000368 Btc
$17,061,886.00
17,055,075.910 USDC
0.0738%
9
SyncSwap
0X5AEA5775959FBC2557CC8789BC1BF90A239D9A91-0X3355DF6D4C9C3035724FD0E3914DE96A5A83AAF4$1.006
0.0000371 Btc
$11,577,086.00
6,074.164 0X5AEA5775959FBC2557CC8789BC1BF90A239D9A91
0.0000%
10
Uniswap V3 (Polygon)
0X2791BCA1F2DE4661ED88A30C99A7A9449AA84174-0X7CEB23FD6BC0ADD59E62AC25578270CFF1B9F619$1.00
0.0000368 Btc
$9,850,519.00
9,805,974.908 0X2791BCA1F2DE4661ED88A30C99A7A9449AA84174
0.0424%
11
Kraken
USDC-USDT$0.9998
0.0000368 Btc
$7,723,307.00
7,724,860.056 USDC
0.0334%
12
Kraken
USDC-EUR$1.001
0.0000369 Btc
$7,622,845.00
7,614,687.183 USDC
0.0330%
13
OKX
BTC-USDC$1.00
0.0000368 Btc
$7,509,303.00
276.253 BTC
0.0000%
14
OKX
ETH-USDC$1.00
0.0000368 Btc
$7,473,152.00
3,933.158 ETH
0.0000%
15
BingX
BTC-USDC$1.00
0.0000368 Btc
$6,761,130.00
249.584 BTC
0.0000%
16
Bitget
BTC-USDC$1.00
0.0000368 Btc
$6,116,373.00
225.222 BTC
0.0000%
17
Bybit
XRP-USDC$1.00
0.0000368 Btc
$6,045,234.00
11,555,934.960 XRP
0.0500%
18
Uniswap V3 (Arbitrum One)
0XFD086BC7CD5C481DCC9C85EBE478A1C0B69FCBB9-0XFF970A61A04B1CA14834A43F5DE4533EBDDB5CC8$0.9996
0.0000368 Btc
$5,667,879.00
5,669,010.607 0XFD086BC7CD5C481DCC9C85EBE478A1C0B69FCBB9
0.0245%
19
LBank
USDC-USDT$1.00
0.0000368 Btc
$5,562,184.00
5,559,473.675 USDC
0.0241%
20
Pancakeswap V3 (BSC)
0X8AC76A51CC950D9822D68B83FE1AD97B32CD580D-0XE9E7CEA3DEDCA5984780BAFC599BD69ADD087D56$0.9999
0.0000368 Btc
$5,341,566.00
5,341,866.633 0X8AC76A51CC950D9822D68B83FE1AD97B32CD580D
0.0231%
21
Bitget
ETH-USDC$1.00
0.0000368 Btc
$5,248,935.00
2,763.716 ETH
0.0000%
22
Binance
ETH-USDC$1.001
0.0000368 Btc
$4,113,229.00
2,160.757 ETH
0.0000%
23
Uniswap V3 (Ethereum)
0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48-0XC02AAA39B223FE8D0A0E5C4F27EAD9083C756CC2$0.9964
0.0000367 Btc
$3,796,386.00
3,777,899.100 0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48
0.0164%
24
Bitget
USDC-USDT$1.001
0.0000368 Btc
$3,789,026.00
3,787,225.805 USDC
0.0164%
25
KuCoin
BTC-USDC$1.00
0.0000368 Btc
$3,443,411.00
126.792 BTC
0.0000%
26
KuCoin
ETH-USDC$1.00
0.0000368 Btc
$3,171,016.00
1,666.781 ETH
0.0000%
27
DigiFinex
USDC-USDT$1.00
0.0000368 Btc
$2,862,875.00
2,862,018.634 USDC
0.0124%
28
Gemini
USDC-USD$1.00
0.0000368 Btc
$2,368,691.00
2,368,287.901 USDC
0.0103%
29
DigiFinex
BTC-USDC$1.00
0.0000368 Btc
$2,284,626.00
84.135 BTC
0.0000%
30
Binance US
BTC-USDC$1.00
0.0000368 Btc
$2,078,016.00
76.520 BTC
0.0000%
31
MEXC Global
USDC-USDT$1.001
0.0000368 Btc
$1,991,743.00
1,990,573.780 USDC
0.0086%
32
Bybit
SOL-USDC$1.00
0.0000368 Btc
$1,860,902.00
88,089.344 SOL
0.0004%
33
KuCoin
USDC-USDT$0.9998
0.0000368 Btc
$1,707,203.00
1,707,517.393 USDC
0.0074%
34
Kraken
ETH-USDC$1.00
0.0000368 Btc
$1,607,796.00
844.958 ETH
0.0000%
35
Huobi
USDC-USDT$1.00
0.0000368 Btc
$1,573,848.00
1,573,273.819 USDC
0.0068%
36
Uniswap V2 (Ethereum)
0XC02AAA39B223FE8D0A0E5C4F27EAD9083C756CC2-0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48$1.002
0.0000369 Btc
$1,467,041.00
771.527 0XC02AAA39B223FE8D0A0E5C4F27EAD9083C756CC2
0.0000%
37
KuCoin
USDT-USDC$1.00
0.0000368 Btc
$1,407,228.00
1,406,809.612 USDT
0.0061%
38
DigiFinex
ETH-USDC$1.00
0.0000368 Btc
$1,342,896.00
705.541 ETH
0.0000%
39
Bitstamp
USDC-EUR$1.001
0.0000369 Btc
$1,321,807.00
1,320,463.404 USDC
0.0057%
40
KuCoin
XRP-USDC$1.00
0.0000368 Btc
$1,264,784.00
2,419,111.253 XRP
0.0105%
41
OKX
XRP-USDC$1.00
0.0000368 Btc
$1,102,648.00
2,108,008.922 XRP
0.0091%
42
Kraken
BTC-USDC$1.00
0.0000368 Btc
$1,093,640.00
40.278 BTC
0.0000%
43
Kraken
USDC-GBP$1.00
0.0000368 Btc
$1,044,647.00
1,044,318.988 USDC
0.0045%
44
Uniswap V3 (Ethereum)
0X2260FAC5E5542A773AA44FBCFEDF7C193BC2C599-0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48$1.001
0.0000369 Btc
$1,012,731.00
37.238 0X2260FAC5E5542A773AA44FBCFEDF7C193BC2C599
0.0000%
45
Coinsbit
BTC-USDC$1.00
0.0000368 Btc
$976,544.00
35.952 BTC
0.0000%
46
Phemex
USDC-USDT$1.00
0.0000368 Btc
$932,232.00
931,952.910 USDC
0.0040%
47
Bitstamp
USDC-USD$1.00
0.0000368 Btc
$826,166.00
826,116.632 USDC
0.0036%
48
Bitget
XRP-USDC$1.00
0.0000368 Btc
$825,992.00
1,584,575.000 XRP
0.0069%
49
Coinsbit
ETH-USDC$1.00
0.0000368 Btc
$704,573.00
370.092 ETH
0.0000%
50
Tidex
BTC-USDC$1.001
0.0000368 Btc
$571,738.00
21.045 BTC
0.0000%
51
Orderly Network
WOO-USDC$1.00
0.0000368 Btc
$545,225.00
2,330,279.260 WOO
0.0101%
52
Bitget
ADA-USDC$1.00
0.0000368 Btc
$529,914.00
1,407,753.000 ADA
0.0061%
53
BitMart
BTC-USDC$1.00
0.0000368 Btc
$508,253.00
18.716 BTC
0.0000%
54
Bitget
EOS-USDC$1.00
0.0000368 Btc
$505,437.00
558,346.400 EOS
0.0024%
55
Bitget
DOGE-USDC$1.00
0.0000368 Btc
$476,963.00
6,592,692.207 DOGE
0.0285%
56
Bitget
MATIC-USDC$1.00
0.0000368 Btc
$475,932.00
528,718.000 MATIC
0.0023%
57
BitMart
USDC-USDT$0.9999
0.0000368 Btc
$453,233.00
453,285.100 USDC
0.0020%
58
Bitget
SOL-USDC$1.00
0.0000368 Btc
$447,096.00
21,115.470 SOL
0.0001%
59
BitMart
ETH-USDC$1.00
0.0000368 Btc
$446,866.00
234.839 ETH
0.0000%
60
Bitget
AVAX-USDC$1.00
0.0000368 Btc
$428,908.00
29,611.370 AVAX
0.0001%
61
OKX
LTC-USDC$1.00
0.0000368 Btc
$413,532.00
4,342.014 LTC
0.0000%
62
Bitget
TRX-USDC$1.00
0.0000368 Btc
$408,083.00
5,112,010.400 TRX
0.0221%
63
BitMart
OP-USDC$1.00
0.0000368 Btc
$331,382.00
225,525.200 OP
0.0010%
64
Coinbase Exchange
USDT-USDC$1.00
0.0000368 Btc
$323,819.00
323,703.290 USDT
0.0014%
65
Bitget
ATOM-USDC$1.00
0.0000368 Btc
$314,187.00
29,642.690 ATOM
0.0001%
66
QMall
BTC-USDC$1.00
0.0000368 Btc
$307,333.00
11.336 BTC
0.0000%
67
Bitget
APE-USDC$1.00
0.0000368 Btc
$306,979.00
98,060.660 APE
0.0004%
68
Bitget
BCH-USDC$1.00
0.0000368 Btc
$306,003.00
2,671.102 BCH
0.0000%
69
Tidex
USDC-USDT$0.9998
0.0000368 Btc
$278,497.00
278,552.564 USDC
0.0012%
70
Bitfinex
UDC-USDT$0.9999
0.0000368 Btc
$252,069.00
252,097.301 UDC
0.0011%
71
BitMart
DAI-USDC$1.00
0.0000368 Btc
$240,500.00
240,491.600 DAI
0.0010%
72
MEXC Global
XRP-USDC$1.00
0.0000368 Btc
$225,506.00
431,084.200 XRP
0.0019%
73
MEXC Global
BTC-USDC$1.00
0.0000368 Btc
$223,239.00
8.220 BTC
0.0000%
74
Bitget
BNB-USDC$1.00
0.0000368 Btc
$220,898.00
719.949 BNB
0.0000%
75
Kanga
BTC-USDC$1.00
0.0000368 Btc
$208,460.00
0.000 BTC
0.0000%
76
BitMart
TRX-USDC$1.00
0.0000368 Btc
$206,045.00
2,434,008.000 TRX
0.0105%
77
xExchange
WEGLD-BD4D79-USDC-C76F1F$0.9995
0.0000368 Btc
$196,679.00
5,243.512 WEGLD-BD4D79
0.0000%
78
MEXC Global
SHIB-USDC$1.00
0.0000368 Btc
$196,570.00
22,756,673,026.000 SHIB
98.5052%
79
MEXC Global
ETH-USDC$1.00
0.0000368 Btc
$184,741.00
97.082 ETH
0.0000%
80
Velodrome Finance
0X340FE1D898ECCAAD394E2BA0FC1F93D27C7B717A-0X7F5C764CBC14F9669B88837CA1490CCA17C31607$1.00
0.0000368 Btc
$176,034.00
167,079.099 0X340FE1D898ECCAAD394E2BA0FC1F93D27C7B717A
0.0007%
81
Bitget
LTC-USDC$1.00
0.0000368 Btc
$151,769.00
1,602.318 LTC
0.0000%
82
BitMart
LTC-USDC$1.00
0.0000368 Btc
$141,861.00
1,494.148 LTC
0.0000%
83
Pancakeswap V3 (Ethereum)
0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48-0XDAC17F958D2EE523A2206206994597C13D831EC7$0.9999
0.0000368 Btc
$136,087.00
136,093.992 0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48
0.0006%
84
BitMart
APE-USDC$1.00
0.0000368 Btc
$130,660.00
41,776.400 APE
0.0002%
85
MEXC Global
EOS-USDC$1.00
0.0000368 Btc
$127,943.00
140,916.930 EOS
0.0006%
86
Bitvavo
USDC-EUR$1.001
0.0000369 Btc
$126,549.00
126,435.174 USDC
0.0005%
87
C-Patex
USDC-USDT$1.00
0.0000368 Btc
$124,938.00
124,919.881 USDC
0.0005%
88
BitMart
DOGE-USDC$1.00
0.0000368 Btc
$102,454.00
1,413,200.000 DOGE
0.0061%
89
BitMart
FXS-USDC$1.00
0.0000368 Btc
$102,158.00
15,430.800 FXS
0.0001%
90
BitMart
XLM-USDC$1.00
0.0000368 Btc
$85,927.00
927,906.000 XLM
0.0040%
91
Bitstamp
BTC-USDC$1.00
0.0000368 Btc
$84,842.00
3.124 BTC
0.0000%
92
Bitget
FIL-USDC$1.00
0.0000368 Btc
$82,482.00
16,679.395 FIL
0.0001%
93
Coinfield
BTC-USDC$1.00
0.0000368 Btc
$76,645.00
2.820 BTC
0.0000%
94
LBank
DOT-USDC$1.00
0.0000368 Btc
$74,309.00
14,055.234 DOT
0.0001%
95
MEXC Global
BCH-USDC$1.00
0.0000368 Btc
$73,248.00
637.940 BCH
0.0000%
96
MEXC Global
ADA-USDC$1.00
0.0000368 Btc
$70,021.00
186,273.360 ADA
0.0008%
97
MEXC Global
ATOM-USDC$1.00
0.0000368 Btc
$57,222.00
5,401.510 ATOM
0.0000%
98
LBank
XRP-USDC$1.00
0.0000368 Btc
$51,699.00
98,830.000 XRP
0.0004%
99
CoinEx
USDC-USDT$1.001
0.0000369 Btc
$49,236.00
49,209.072 USDC
0.0002%
100
MEXC Global
FTM-USDC$1.00
0.0000368 Btc
$46,959.00
145,757.250 FTM
0.0006%

Similar Match Source Code
Note: This contract matches the deployed ByteCode of the Source Code for Contract 0xab3f0245b83feb11d15aaffefd7ad465a59817ed

Contract Name:
BridgeToken

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
Yes with 200 runs

Other Settings:
istanbul EvmVersion, Apache-2.0 license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-12-01
*/

// File: @openzeppelin/contracts/proxy/beacon/IBeacon.sol


pragma solidity ^0.8.0;

/**
 * @dev This is the interface that {BeaconProxy} expects of its beacon.
 */
interface IBeacon {
    /**
     * @dev Must return an address that can be used as a delegate call target.
     *
     * {BeaconProxy} will check that this address is a contract.
     */
    function implementation() external view returns (address);
}

// File: @openzeppelin/contracts/proxy/Proxy.sol


pragma solidity ^0.8.0;

/**
 * @dev This abstract contract provides a fallback function that delegates all calls to another contract using the EVM
 * instruction `delegatecall`. We refer to the second contract as the _implementation_ behind the proxy, and it has to
 * be specified by overriding the virtual {_implementation} function.
 *
 * Additionally, delegation to the implementation can be triggered manually through the {_fallback} function, or to a
 * different contract through the {_delegate} function.
 *
 * The success and return data of the delegated call will be returned back to the caller of the proxy.
 */
abstract contract Proxy {
    /**
     * @dev Delegates the current call to `implementation`.
     *
     * This function does not return to its internall call site, it will return directly to the external caller.
     */
    function _delegate(address implementation) internal virtual {
        assembly {
            // Copy msg.data. We take full control of memory in this inline assembly
            // block because it will not return to Solidity code. We overwrite the
            // Solidity scratch pad at memory position 0.
            calldatacopy(0, 0, calldatasize())

            // Call the implementation.
            // out and outsize are 0 because we don't know the size yet.
            let result := delegatecall(gas(), implementation, 0, calldatasize(), 0, 0)

            // Copy the returned data.
            returndatacopy(0, 0, returndatasize())

            switch result
            // delegatecall returns 0 on error.
            case 0 {
                revert(0, returndatasize())
            }
            default {
                return(0, returndatasize())
            }
        }
    }

    /**
     * @dev This is a virtual function that should be overriden so it returns the address to which the fallback function
     * and {_fallback} should delegate.
     */
    function _implementation() internal view virtual returns (address);

    /**
     * @dev Delegates the current call to the address returned by `_implementation()`.
     *
     * This function does not return to its internall call site, it will return directly to the external caller.
     */
    function _fallback() internal virtual {
        _beforeFallback();
        _delegate(_implementation());
    }

    /**
     * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if no other
     * function in the contract matches the call data.
     */
    fallback() external payable virtual {
        _fallback();
    }

    /**
     * @dev Fallback function that delegates calls to the address returned by `_implementation()`. Will run if call data
     * is empty.
     */
    receive() external payable virtual {
        _fallback();
    }

    /**
     * @dev Hook that is called before falling back to the implementation. Can happen as part of a manual `_fallback`
     * call, or as part of the Solidity `fallback` or `receive` functions.
     *
     * If overriden should call `super._beforeFallback()`.
     */
    function _beforeFallback() internal virtual {}
}

// File: @openzeppelin/contracts/utils/Address.sol


pragma solidity ^0.8.0;

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        (bool success, ) = recipient.call{value: amount}("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain `call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionCall(target, data, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        require(isContract(target), "Address: call to non-contract");

        (bool success, bytes memory returndata) = target.call{value: value}(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
        return functionStaticCall(target, data, "Address: low-level static call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        (bool success, bytes memory returndata) = target.staticcall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionDelegateCall(target, data, "Address: low-level delegate call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        (bool success, bytes memory returndata) = target.delegatecall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the
     * revert reason using the provided one.
     *
     * _Available since v4.3._
     */
    function verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal pure returns (bytes memory) {
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

// File: @openzeppelin/contracts/utils/StorageSlot.sol


pragma solidity ^0.8.0;

/**
 * @dev Library for reading and writing primitive types to specific storage slots.
 *
 * Storage slots are often used to avoid storage conflict when dealing with upgradeable contracts.
 * This library helps with reading and writing to such slots without the need for inline assembly.
 *
 * The functions in this library return Slot structs that contain a `value` member that can be used to read or write.
 *
 * Example usage to set ERC1967 implementation slot:
 * ```
 * contract ERC1967 {
 *     bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;
 *
 *     function _getImplementation() internal view returns (address) {
 *         return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;
 *     }
 *
 *     function _setImplementation(address newImplementation) internal {
 *         require(Address.isContract(newImplementation), "ERC1967: new implementation is not a contract");
 *         StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;
 *     }
 * }
 * ```
 *
 * _Available since v4.1 for `address`, `bool`, `bytes32`, and `uint256`._
 */
library StorageSlot {
    struct AddressSlot {
        address value;
    }

    struct BooleanSlot {
        bool value;
    }

    struct Bytes32Slot {
        bytes32 value;
    }

    struct Uint256Slot {
        uint256 value;
    }

    /**
     * @dev Returns an `AddressSlot` with member `value` located at `slot`.
     */
    function getAddressSlot(bytes32 slot) internal pure returns (AddressSlot storage r) {
        assembly {
            r.slot := slot
        }
    }

    /**
     * @dev Returns an `BooleanSlot` with member `value` located at `slot`.
     */
    function getBooleanSlot(bytes32 slot) internal pure returns (BooleanSlot storage r) {
        assembly {
            r.slot := slot
        }
    }

    /**
     * @dev Returns an `Bytes32Slot` with member `value` located at `slot`.
     */
    function getBytes32Slot(bytes32 slot) internal pure returns (Bytes32Slot storage r) {
        assembly {
            r.slot := slot
        }
    }

    /**
     * @dev Returns an `Uint256Slot` with member `value` located at `slot`.
     */
    function getUint256Slot(bytes32 slot) internal pure returns (Uint256Slot storage r) {
        assembly {
            r.slot := slot
        }
    }
}

// File: @openzeppelin/contracts/proxy/ERC1967/ERC1967Upgrade.sol


pragma solidity ^0.8.2;



/**
 * @dev This abstract contract provides getters and event emitting update functions for
 * https://eips.ethereum.org/EIPS/eip-1967[EIP1967] slots.
 *
 * _Available since v4.1._
 *
 * @custom:oz-upgrades-unsafe-allow delegatecall
 */
abstract contract ERC1967Upgrade {
    // This is the keccak-256 hash of "eip1967.proxy.rollback" subtracted by 1
    bytes32 private constant _ROLLBACK_SLOT = 0x4910fdfa16fed3260ed0e7147f7cc6da11a60208b5b9406d12a635614ffd9143;

    /**
     * @dev Storage slot with the address of the current implementation.
     * This is the keccak-256 hash of "eip1967.proxy.implementation" subtracted by 1, and is
     * validated in the constructor.
     */
    bytes32 internal constant _IMPLEMENTATION_SLOT = 0x360894a13ba1a3210667c828492db98dca3e2076cc3735a920a3ca505d382bbc;

    /**
     * @dev Emitted when the implementation is upgraded.
     */
    event Upgraded(address indexed implementation);

    /**
     * @dev Returns the current implementation address.
     */
    function _getImplementation() internal view returns (address) {
        return StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value;
    }

    /**
     * @dev Stores a new address in the EIP1967 implementation slot.
     */
    function _setImplementation(address newImplementation) private {
        require(Address.isContract(newImplementation), "ERC1967: new implementation is not a contract");
        StorageSlot.getAddressSlot(_IMPLEMENTATION_SLOT).value = newImplementation;
    }

    /**
     * @dev Perform implementation upgrade
     *
     * Emits an {Upgraded} event.
     */
    function _upgradeTo(address newImplementation) internal {
        _setImplementation(newImplementation);
        emit Upgraded(newImplementation);
    }

    /**
     * @dev Perform implementation upgrade with additional setup call.
     *
     * Emits an {Upgraded} event.
     */
    function _upgradeToAndCall(
        address newImplementation,
        bytes memory data,
        bool forceCall
    ) internal {
        _upgradeTo(newImplementation);
        if (data.length > 0 || forceCall) {
            Address.functionDelegateCall(newImplementation, data);
        }
    }

    /**
     * @dev Perform implementation upgrade with security checks for UUPS proxies, and additional setup call.
     *
     * Emits an {Upgraded} event.
     */
    function _upgradeToAndCallSecure(
        address newImplementation,
        bytes memory data,
        bool forceCall
    ) internal {
        address oldImplementation = _getImplementation();

        // Initial upgrade and setup call
        _setImplementation(newImplementation);
        if (data.length > 0 || forceCall) {
            Address.functionDelegateCall(newImplementation, data);
        }

        // Perform rollback test if not already in progress
        StorageSlot.BooleanSlot storage rollbackTesting = StorageSlot.getBooleanSlot(_ROLLBACK_SLOT);
        if (!rollbackTesting.value) {
            // Trigger rollback using upgradeTo from the new implementation
            rollbackTesting.value = true;
            Address.functionDelegateCall(
                newImplementation,
                abi.encodeWithSignature("upgradeTo(address)", oldImplementation)
            );
            rollbackTesting.value = false;
            // Check rollback was effective
            require(oldImplementation == _getImplementation(), "ERC1967Upgrade: upgrade breaks further upgrades");
            // Finally reset to the new implementation and log the upgrade
            _upgradeTo(newImplementation);
        }
    }

    /**
     * @dev Storage slot with the admin of the contract.
     * This is the keccak-256 hash of "eip1967.proxy.admin" subtracted by 1, and is
     * validated in the constructor.
     */
    bytes32 internal constant _ADMIN_SLOT = 0xb53127684a568b3173ae13b9f8a6016e243e63b6e8ee1178d6a717850b5d6103;

    /**
     * @dev Emitted when the admin account has changed.
     */
    event AdminChanged(address previousAdmin, address newAdmin);

    /**
     * @dev Returns the current admin.
     */
    function _getAdmin() internal view returns (address) {
        return StorageSlot.getAddressSlot(_ADMIN_SLOT).value;
    }

    /**
     * @dev Stores a new address in the EIP1967 admin slot.
     */
    function _setAdmin(address newAdmin) private {
        require(newAdmin != address(0), "ERC1967: new admin is the zero address");
        StorageSlot.getAddressSlot(_ADMIN_SLOT).value = newAdmin;
    }

    /**
     * @dev Changes the admin of the proxy.
     *
     * Emits an {AdminChanged} event.
     */
    function _changeAdmin(address newAdmin) internal {
        emit AdminChanged(_getAdmin(), newAdmin);
        _setAdmin(newAdmin);
    }

    /**
     * @dev The storage slot of the UpgradeableBeacon contract which defines the implementation for this proxy.
     * This is bytes32(uint256(keccak256('eip1967.proxy.beacon')) - 1)) and is validated in the constructor.
     */
    bytes32 internal constant _BEACON_SLOT = 0xa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50;

    /**
     * @dev Emitted when the beacon is upgraded.
     */
    event BeaconUpgraded(address indexed beacon);

    /**
     * @dev Returns the current beacon.
     */
    function _getBeacon() internal view returns (address) {
        return StorageSlot.getAddressSlot(_BEACON_SLOT).value;
    }

    /**
     * @dev Stores a new beacon in the EIP1967 beacon slot.
     */
    function _setBeacon(address newBeacon) private {
        require(Address.isContract(newBeacon), "ERC1967: new beacon is not a contract");
        require(
            Address.isContract(IBeacon(newBeacon).implementation()),
            "ERC1967: beacon implementation is not a contract"
        );
        StorageSlot.getAddressSlot(_BEACON_SLOT).value = newBeacon;
    }

    /**
     * @dev Perform beacon upgrade with additional setup call. Note: This upgrades the address of the beacon, it does
     * not upgrade the implementation contained in the beacon (see {UpgradeableBeacon-_setImplementation} for that).
     *
     * Emits a {BeaconUpgraded} event.
     */
    function _upgradeBeaconToAndCall(
        address newBeacon,
        bytes memory data,
        bool forceCall
    ) internal {
        _setBeacon(newBeacon);
        emit BeaconUpgraded(newBeacon);
        if (data.length > 0 || forceCall) {
            Address.functionDelegateCall(IBeacon(newBeacon).implementation(), data);
        }
    }
}

// File: @openzeppelin/contracts/proxy/beacon/BeaconProxy.sol


pragma solidity ^0.8.0;



/**
 * @dev This contract implements a proxy that gets the implementation address for each call from a {UpgradeableBeacon}.
 *
 * The beacon address is stored in storage slot `uint256(keccak256('eip1967.proxy.beacon')) - 1`, so that it doesn't
 * conflict with the storage layout of the implementation behind the proxy.
 *
 * _Available since v3.4._
 */
contract BeaconProxy is Proxy, ERC1967Upgrade {
    /**
     * @dev Initializes the proxy with `beacon`.
     *
     * If `data` is nonempty, it's used as data in a delegate call to the implementation returned by the beacon. This
     * will typically be an encoded function call, and allows initializating the storage of the proxy like a Solidity
     * constructor.
     *
     * Requirements:
     *
     * - `beacon` must be a contract with the interface {IBeacon}.
     */
    constructor(address beacon, bytes memory data) payable {
        assert(_BEACON_SLOT == bytes32(uint256(keccak256("eip1967.proxy.beacon")) - 1));
        _upgradeBeaconToAndCall(beacon, data, false);
    }

    /**
     * @dev Returns the current beacon address.
     */
    function _beacon() internal view virtual returns (address) {
        return _getBeacon();
    }

    /**
     * @dev Returns the current implementation address of the associated beacon.
     */
    function _implementation() internal view virtual override returns (address) {
        return IBeacon(_getBeacon()).implementation();
    }

    /**
     * @dev Changes the proxy to use a new beacon. Deprecated: see {_upgradeBeaconToAndCall}.
     *
     * If `data` is nonempty, it's used as data in a delegate call to the implementation returned by the beacon.
     *
     * Requirements:
     *
     * - `beacon` must be a contract.
     * - The implementation returned by `beacon` must be a contract.
     */
    function _setBeacon(address beacon, bytes memory data) internal virtual {
        _upgradeBeaconToAndCall(beacon, data, false);
    }
}

// File: contracts/bridge/token/Token.sol

// contracts/Structs.sol

pragma solidity ^0.8.0;

contract BridgeToken is BeaconProxy {
    constructor(address beacon, bytes memory data) BeaconProxy(beacon, data) {

    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"beacon","type":"address"},{"internalType":"bytes","name":"data","type":"bytes"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"previousAdmin","type":"address"},{"indexed":false,"internalType":"address","name":"newAdmin","type":"address"}],"name":"AdminChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"beacon","type":"address"}],"name":"BeaconUpgraded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"implementation","type":"address"}],"name":"Upgraded","type":"event"},{"stateMutability":"payable","type":"fallback"},{"stateMutability":"payable","type":"receive"}]

608060405234801561001057600080fd5b5060405161099338038061099383398101604081905261002f9161048e565b818161005c60017fa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d51610599565b60008051602061094c8339815191521461008657634e487b7160e01b600052600160045260246000fd5b6100928282600061009b565b505050506105fe565b6100a483610175565b6040516001600160a01b038416907f1cf3b03a6cf19fa2baba4df148e9dcabedea7f8a5c07840e207e5c089be95d3e90600090a26000825111806100e55750805b156101705761016e836001600160a01b0316635c60da1b6040518163ffffffff1660e01b815260040160206040518083038186803b15801561012657600080fd5b505afa15801561013a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061015e9190610474565b8361031560201b6100291760201c565b505b505050565b6101888161034160201b6100551760201c565b6101e75760405162461bcd60e51b815260206004820152602560248201527f455243313936373a206e657720626561636f6e206973206e6f74206120636f6e6044820152641d1c9858dd60da1b60648201526084015b60405180910390fd5b61026a816001600160a01b0316635c60da1b6040518163ffffffff1660e01b815260040160206040518083038186803b15801561022357600080fd5b505afa158015610237573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061025b9190610474565b61034160201b6100551760201c565b6102cf5760405162461bcd60e51b815260206004820152603060248201527f455243313936373a20626561636f6e20696d706c656d656e746174696f6e206960448201526f1cc81b9bdd08184818dbdb9d1c9858dd60821b60648201526084016101de565b806102f460008051602061094c83398151915260001b61034760201b61005b1760201c565b80546001600160a01b0319166001600160a01b039290921691909117905550565b606061033a838360405180606001604052806027815260200161096c6027913961034a565b9392505050565b3b151590565b90565b6060833b6103a95760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b60648201526084016101de565b600080856001600160a01b0316856040516103c4919061054a565b600060405180830381855af49150503d80600081146103ff576040519150601f19603f3d011682016040523d82523d6000602084013e610404565b606091505b50909250905061041582828661041f565b9695505050505050565b6060831561042e57508161033a565b82511561043e5782518084602001fd5b8160405162461bcd60e51b81526004016101de9190610566565b80516001600160a01b038116811461046f57600080fd5b919050565b600060208284031215610485578081fd5b61033a82610458565b600080604083850312156104a0578081fd5b6104a983610458565b60208401519092506001600160401b03808211156104c5578283fd5b818501915085601f8301126104d8578283fd5b8151818111156104ea576104ea6105e8565b604051601f8201601f19908116603f01168101908382118183101715610512576105126105e8565b8160405282815288602084870101111561052a578586fd5b61053b8360208301602088016105bc565b80955050505050509250929050565b6000825161055c8184602087016105bc565b9190910192915050565b60208152600082518060208401526105858160408501602087016105bc565b601f01601f19169190910160400192915050565b6000828210156105b757634e487b7160e01b81526011600452602481fd5b500390565b60005b838110156105d75781810151838201526020016105bf565b8381111561016e5750506000910152565b634e487b7160e01b600052604160045260246000fd5b61033f8061060d6000396000f3fe60806040523661001357610011610017565b005b6100115b61002761002261005e565b610106565b565b606061004e83836040518060600160405280602781526020016102e36027913961012a565b9392505050565b3b151590565b90565b60006100917fa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50546001600160a01b031690565b6001600160a01b0316635c60da1b6040518163ffffffff1660e01b815260040160206040518083038186803b1580156100c957600080fd5b505afa1580156100dd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610101919061023c565b905090565b3660008037600080366000845af43d6000803e808015610125573d6000f35b3d6000fd5b6060833b61018e5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b60648201526084015b60405180910390fd5b600080856001600160a01b0316856040516101a99190610263565b600060405180830381855af49150503d80600081146101e4576040519150601f19603f3d011682016040523d82523d6000602084013e6101e9565b606091505b50915091506101f9828286610203565b9695505050505050565b6060831561021257508161004e565b8251156102225782518084602001fd5b8160405162461bcd60e51b8152600401610185919061027f565b60006020828403121561024d578081fd5b81516001600160a01b038116811461004e578182fd5b600082516102758184602087016102b2565b9190910192915050565b602081526000825180602084015261029e8160408501602087016102b2565b601f01601f19169190910160400192915050565b60005b838110156102cd5781810151838201526020016102b5565b838111156102dc576000848401525b5050505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a26469706673582212203e23ac4f79a95247999f8e0df94ea5bd5e38561ccfd051b0ea50ba9aea59b8f164736f6c63430008040033a3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564000000000000000000000000b1731c586ca89a23809861c6103f0b96b3f57d9200000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000164c71f461500000000000000000000000000000000000000000000000000000000000000e0000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000000120000000000000000000000000000000000000000000000000000000000014c53000000000000000000000000b1731c586ca89a23809861c6103f0b96b3f57d920000000000000000000000000000000000000000000000000000000000000002000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000000000000000000000000000000000000000000d57726170706564204574686572000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000004574554480000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000

Deployed ByteCode Sourcemap

23359:129:0:-:0;;;;;;3361:11;:9;:11::i;:::-;23359:129;;3130:11;2767:113;2844:28;2854:17;:15;:17::i;:::-;2844:9;:28::i;:::-;2767:113::o;10080:200::-;10163:12;10195:77;10216:6;10224:4;10195:77;;;;;;;;;;;;;;;;;:20;:77::i;:::-;10188:84;10080:200;-1:-1:-1;;;10080:200:0:o;4486:387::-;4809:20;4857:8;;;4486:387::o;13434:151::-;13563:4;13538:40::o;22587:140::-;22654:7;22689:12;19628:66;19955:46;-1:-1:-1;;;;;19955:46:0;;19883:126;22689:12;-1:-1:-1;;;;;22681:36:0;;:38;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;22674:45;;22587:140;:::o;1357:918::-;1700:14;1697:1;1694;1681:34;1918:1;1915;1899:14;1896:1;1880:14;1873:5;1860:60;1997:16;1994:1;1991;1976:38;2037:6;2106:68;;;;2225:16;2222:1;2215:27;2106:68;2142:16;2139:1;2132:27;10474:396;10619:12;4809:20;;10644:69;;;;-1:-1:-1;;;10644:69:0;;1198:2:1;10644:69:0;;;1180:21:1;1237:2;1217:18;;;1210:30;1276:34;1256:18;;;1249:62;-1:-1:-1;;;1327:18:1;;;1320:36;1373:19;;10644:69:0;;;;;;;;;10727:12;10741:23;10768:6;-1:-1:-1;;;;;10768:19:0;10788:4;10768:25;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10726:67;;;;10811:51;10828:7;10837:10;10849:12;10811:16;:51::i;:::-;10804:58;10474:396;-1:-1:-1;;;;;;10474:396:0:o;11098:712::-;11248:12;11277:7;11273:530;;;-1:-1:-1;11308:10:0;11301:17;;11273:530;11422:17;;:21;11418:374;;11620:10;11614:17;11681:15;11668:10;11664:2;11660:19;11653:44;11568:148;11763:12;11756:20;;-1:-1:-1;;;11756:20:0;;;;;;;;:::i;14:310:1:-;84:6;137:2;125:9;116:7;112:23;108:32;105:2;;;158:6;150;143:22;105:2;189:16;;-1:-1:-1;;;;;234:31:1;;224:42;;214:2;;285:6;277;270:22;329:274;458:3;496:6;490:13;512:53;558:6;553:3;546:4;538:6;534:17;512:53;:::i;:::-;581:16;;;;;466:137;-1:-1:-1;;466:137:1:o;608:383::-;757:2;746:9;739:21;720:4;789:6;783:13;832:6;827:2;816:9;812:18;805:34;848:66;907:6;902:2;891:9;887:18;882:2;874:6;870:15;848:66;:::i;:::-;975:2;954:15;-1:-1:-1;;950:29:1;935:45;;;;982:2;931:54;;729:262;-1:-1:-1;;729:262:1:o;1403:258::-;1475:1;1485:113;1499:6;1496:1;1493:13;1485:113;;;1575:11;;;1569:18;1556:11;;;1549:39;1521:2;1514:10;1485:113;;;1616:6;1613:1;1610:13;1607:2;;;1651:1;1642:6;1637:3;1633:16;1626:27;1607:2;;1456:205;;;:::o

Swarm Source

ipfs://3e23ac4f79a95247999f8e0df94ea5bd5e38561ccfd051b0ea50ba9aea59b8f1
Loading