Token USD Coin (Wormhole)

Overview ERC20

Price
$1.00 @ 1.469897 CELO (-0.01%)
Fully Diluted Market Cap
Total Supply:
16,648,511.557009 USDC

Holders:
227 addresses

Transfers:
-

Loading
[ Download CSV Export  ] 
Loading
[ Download CSV Export  ] 
Loading

OVERVIEW

Portal is a bridge that offers unlimited transfers across chains for tokens and NFTs wrapped by Wormhole.

Market

Volume (24H):$4,274,091,200.00
Market Capitalization:$32,522,419,578.00
Circulating Supply:32,511,583,779.00 USDC
Market Data Source: Coinmarketcap


Update? Click here to update the token ICO / general information
# Exchange Pair Price  24H Volume % Volume
1
Uniswap (v3)
0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48-0XC02AAA39B223FE8D0A0E5C4F27EAD9083C756CC2$0.999
0.0000352 Btc
$323,738,581.00
321,436,386.511 0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48
29.8927%
2
Binance
USDC-USDT$1.001
0.0000353 Btc
$317,144,812.00
316,908,998.876 USDC
29.4717%
3
LBank
ETH-USDC$1.001
0.0000353 Btc
$297,773,149.00
163,128.097 ETH
0.0152%
4
Biconomy
BTC-USDC$0.9999
0.0000353 Btc
$285,019,948.00
10,053.037 BTC
0.0009%
5
LBank
BTC-USDC$1.001
0.0000353 Btc
$210,989,907.00
7,435.698 BTC
0.0007%
6
Uniswap (v3)
0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48-0XDAC17F958D2EE523A2206206994597C13D831EC7$0.999
0.0000352 Btc
$132,111,073.00
132,222,165.668 0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48
12.2963%
7
Bybit
BTC-USDC$0.9999
0.0000353 Btc
$120,711,742.00
4,257.984 BTC
0.0004%
8
Uniswap (Arbitrum One)
0X82AF49447D8A07E3BD95BD0D56F35241523FBAB1-0XFF970A61A04B1CA14834A43F5DE4533EBDDB5CC8$1.00
0.0000353 Btc
$108,971,629.00
60,227.267 0X82AF49447D8A07E3BD95BD0D56F35241523FBAB1
0.0056%
9
Uniswap (Arbitrum One)
0X912CE59144191C1204E64559FE8253A0E49E6548-0XFF970A61A04B1CA14834A43F5DE4533EBDDB5CC8$1.00
0.0000353 Btc
$61,539,662.00
44,552,240.454 0X912CE59144191C1204E64559FE8253A0E49E6548
4.1432%
10
ApeX Pro
BTC-USDC$0.9999
0.0000353 Btc
$47,641,594.00
1,693.089 BTC
0.0002%
11
Bybit
ETH-USDC$0.9999
0.0000353 Btc
$41,806,296.00
22,936.878 ETH
0.0021%
12
Kraken
USDC-USD$1.00
0.0000353 Btc
$29,062,891.00
29,059,984.887 USDC
2.7025%
13
Bybit
USDC-USDT$1.00
0.0000353 Btc
$24,971,399.00
24,965,231.630 USDC
2.3217%
14
OKX
BTC-USDC$0.9999
0.0000353 Btc
$20,786,601.00
738.453 BTC
0.0001%
15
Uniswap (Arbitrum One)
0X912CE59144191C1204E64559FE8253A0E49E6548-0XFF970A61A04B1CA14834A43F5DE4533EBDDB5CC8$1.00
0.0000353 Btc
$20,386,869.00
14,776,223.710 0X912CE59144191C1204E64559FE8253A0E49E6548
1.3741%
16
Uniswap (v3)
0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48-0XC02AAA39B223FE8D0A0E5C4F27EAD9083C756CC2$0.999
0.0000352 Btc
$16,664,998.00
16,611,000.317 0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48
1.5448%
17
OKX
USDC-USDT$1.00
0.0000353 Btc
$14,957,556.00
14,956,449.241 USDC
1.3909%
18
BingX
USDC-USDT$1.00
0.0000353 Btc
$14,741,267.00
14,744,742.009 USDC
1.3712%
19
Binance
BTC-USDC$0.9999
0.0000353 Btc
$14,428,849.00
509.476 BTC
0.0000%
20
OKX
ETH-USDC$0.9999
0.0000353 Btc
$14,375,531.00
7,947.986 ETH
0.0007%
21
BKEX
BTC-USDC$0.9997
0.0000353 Btc
$14,339,678.00
509.533 BTC
0.0000%
22
Biconomy
ETH-USDC$0.9999
0.0000353 Btc
$14,234,331.00
7,807.432 ETH
0.0007%
23
Kraken
USDC-EUR$1.001
0.0000353 Btc
$13,796,725.00
13,781,218.868 USDC
1.2816%
24
ApeX Pro
ETH-USDC$0.9999
0.0000353 Btc
$12,976,430.00
7,163.130 ETH
0.0007%
25
Kraken
USDC-USDT$1.001
0.0000353 Btc
$12,619,023.00
12,612,235.322 USDC
1.1729%
26
Uniswap (v3)
0X6B175474E89094C44DA98B954EEDEAC495271D0F-0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48$0.999
0.0000352 Btc
$10,038,131.00
10,048,398.046 0X6B175474E89094C44DA98B954EEDEAC495271D0F
0.9345%
27
Gate.io
USDC-USDT$1.00
0.0000353 Btc
$9,585,538.00
9,586,725.516 USDC
0.8915%
28
LBank
XRP-USDC$1.001
0.0000353 Btc
$9,184,616.00
17,203,644.000 XRP
1.5999%
29
BKEX
ETH-USDC$0.9995
0.0000353 Btc
$8,621,549.00
4,769.800 ETH
0.0004%
30
KuCoin
BTC-USDC$0.9999
0.0000353 Btc
$8,025,878.00
283.119 BTC
0.0000%
31
Pancakeswap (Stableswap)
0X8AC76A51CC950D9822D68B83FE1AD97B32CD580D-0XE9E7CEA3DEDCA5984780BAFC599BD69ADD087D56$1.00
0.0000353 Btc
$7,915,085.00
7,913,133.778 0X8AC76A51CC950D9822D68B83FE1AD97B32CD580D
0.7359%
32
Huobi
USDC-USDT$1.00
0.0000353 Btc
$6,453,767.00
6,457,259.938 USDC
0.6005%
33
Phemex
USDC-USDT$0.9999
0.0000353 Btc
$5,865,900.00
5,866,289.540 USDC
0.5455%
34
KuCoin
USDC-USDT$1.00
0.0000353 Btc
$5,535,732.00
5,535,357.806 USDC
0.5148%
35
BKEX
USDC-USDT$1.00
0.0000353 Btc
$5,379,692.00
5,379,635.327 USDC
0.5003%
36
Binance
ETH-USDC$0.9999
0.0000353 Btc
$5,201,221.00
2,854.504 ETH
0.0003%
37
Bitget
USDC-USDT$1.00
0.0000353 Btc
$4,833,284.00
4,833,404.421 USDC
0.4495%
38
KuCoin
USDT-USDC$0.9999
0.0000353 Btc
$4,718,193.00
4,718,093.546 USDT
0.4388%
39
OKX
USDT-USDC$0.9999
0.0000353 Btc
$4,560,890.00
4,560,246.038 USDT
0.4241%
40
ZigZag (zkSync v1)
ETH-USDC$0.9999
0.0000353 Btc
$3,576,763.00
1,983.230 ETH
0.0002%
41
Kraken
USDC-GBP$1.001
0.0000353 Btc
$3,286,029.00
3,283,145.384 USDC
0.3053%
42
Uniswap (v3)
0X2260FAC5E5542A773AA44FBCFEDF7C193BC2C599-0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48$1.003
0.0000354 Btc
$3,175,970.00
112.376 0X2260FAC5E5542A773AA44FBCFEDF7C193BC2C599
0.0000%
43
Binance US
BTC-USDC$1.001
0.0000353 Btc
$2,975,727.00
104.879 BTC
0.0000%
44
Bitstamp
USDC-USD$1.00
0.0000353 Btc
$2,882,173.00
2,881,855.795 USDC
0.2680%
45
Uniswap (v2)
0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48-0XC02AAA39B223FE8D0A0E5C4F27EAD9083C756CC2$0.9967
0.0000352 Btc
$2,781,113.00
2,688,025.065 0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48
0.2500%
46
Kraken
BTC-USDC$1.001
0.0000353 Btc
$2,659,126.00
93.702 BTC
0.0000%
47
Camelot
0X82AF49447D8A07E3BD95BD0D56F35241523FBAB1-0XFF970A61A04B1CA14834A43F5DE4533EBDDB5CC8$0.9985
0.0000352 Btc
$2,157,033.00
1,194.385 0X82AF49447D8A07E3BD95BD0D56F35241523FBAB1
0.0001%
48
Cryptology
BTC-USDC$1.001
0.0000353 Btc
$1,843,593.00
65.030 BTC
0.0000%
49
Bitget
BTC-USDC$1.001
0.0000353 Btc
$1,808,282.00
64.285 BTC
0.0000%
50
Tidex
BTC-USDC$1.001
0.0000353 Btc
$1,808,155.00
63.743 BTC
0.0000%
51
WOO X
BTC-USDC$0.9999
0.0000353 Btc
$1,798,772.00
63.449 BTC
0.0000%
52
Pancakeswap (Stableswap)
0X55D398326F99059FF775485246999027B3197955-0X8AC76A51CC950D9822D68B83FE1AD97B32CD580D$1.00
0.0000353 Btc
$1,731,129.00
1,730,679.479 0X55D398326F99059FF775485246999027B3197955
0.1609%
53
Coinsbit
BTC-USDC$0.9995
0.0000353 Btc
$1,714,236.00
60.565 BTC
0.0000%
54
Sushiswap (Arbitrum One)
0XFF970A61A04B1CA14834A43F5DE4533EBDDB5CC8-0X82AF49447D8A07E3BD95BD0D56F35241523FBAB1$0.9956
0.0000351 Btc
$1,677,914.00
1,674,491.903 0XFF970A61A04B1CA14834A43F5DE4533EBDDB5CC8
0.1557%
55
Bitget
ETH-USDC$1.001
0.0000353 Btc
$1,580,107.00
875.031 ETH
0.0001%
56
Camelot
0X3D9907F9A368AD0A51BE60F7DA3B97CF940982D8-0XFF970A61A04B1CA14834A43F5DE4533EBDDB5CC8$0.9985
0.0000352 Btc
$1,557,355.00
524.074 0X3D9907F9A368AD0A51BE60F7DA3B97CF940982D8
0.0000%
57
Sushiswap
0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48-0XC02AAA39B223FE8D0A0E5C4F27EAD9083C756CC2$0.9936
0.0000351 Btc
$1,436,801.00
1,429,054.695 0XA0B86991C6218B36C1D19D4A2E9EB0CE3606EB48
0.1329%
58
Tidex
USDC-USDT$0.9996
0.0000353 Btc
$1,351,378.00
1,351,888.249 USDC
0.1257%
59
Coinsbit
ETH-USDC$0.9995
0.0000353 Btc
$1,021,316.00
560.259 ETH
0.0001%
60
Gemini
USDC-USD$1.00
0.0000353 Btc
$1,017,984.00
1,018,034.556 USDC
0.0947%
61
Coinbase Exchange
USDT-USDC$1.001
0.0000353 Btc
$887,679.00
886,846.370 USDT
0.0825%
62
MEXC Global
BTC-USDC$0.9999
0.0000353 Btc
$840,557.00
29.647 BTC
0.0000%
63
BitMart
ETH-USDC$0.9999
0.0000353 Btc
$822,789.00
451.598 ETH
0.0000%
64
MEXC Global
AVAX-USDC$0.9999
0.0000353 Btc
$708,691.00
40,188.080 AVAX
0.0037%
65
Kraken
ETH-USDC$1.001
0.0000353 Btc
$611,116.00
335.607 ETH
0.0000%
66
BitMart
OP-USDC$0.9999
0.0000353 Btc
$592,396.00
259,806.800 OP
0.0242%
67
ApeX Pro
XRP-USDC$0.9999
0.0000353 Btc
$586,128.00
1,096,764.000 XRP
0.1020%
68
Bitstamp
USDC-EUR$0.9995
0.0000353 Btc
$561,420.00
561,702.402 USDC
0.0522%
69
MEXC Global
XRP-USDC$0.9999
0.0000353 Btc
$561,360.00
1,052,378.700 XRP
0.0979%
70
PancakeSwap (v2)
0X2170ED0880AC9A755FD29B2688956BD959F933F8-0X8AC76A51CC950D9822D68B83FE1AD97B32CD580D$1.001
0.0000353 Btc
$547,107.00
302.136 0X2170ED0880AC9A755FD29B2688956BD959F933F8
0.0000%
71
BitMart
USDC-USDT$0.9999
0.0000353 Btc
$502,177.00
502,233.180 USDC
0.0467%
72
P2B
USDC-USDT$0.9998
0.0000353 Btc
$499,321.00
499,409.900 USDC
0.0464%
73
BitMart
DOGE-USDC$0.9999
0.0000353 Btc
$496,658.00
6,555,096.000 DOGE
0.6096%
74
Bitget
EOS-USDC$1.001
0.0000353 Btc
$485,828.00
409,120.500 EOS
0.0380%
75
Velodrome Finance
0X8C6F28F2F1A3C87F0F938B96D27520D9751EC8D9-0X7F5C764CBC14F9669B88837CA1490CCA17C31607$0.9993
0.0000352 Btc
$419,567.00
419,830.669 0X8C6F28F2F1A3C87F0F938B96D27520D9751EC8D9
0.0390%
76
Bitfinex
UDC-USDT$1.00
0.0000353 Btc
$418,835.00
418,781.578 UDC
0.0389%
77
Bitfinex
UDC-USD$0.9995
0.0000353 Btc
$407,712.00
407,924.211 UDC
0.0379%
78
WOO X
ETH-USDC$0.9999
0.0000353 Btc
$362,761.00
199.059 ETH
0.0000%
79
BingX
BTC-USDC$0.9999
0.0000353 Btc
$333,146.00
11.834 BTC
0.0000%
80
Zyberswap
0X82AF49447D8A07E3BD95BD0D56F35241523FBAB1-0XFF970A61A04B1CA14834A43F5DE4533EBDDB5CC8$1.002
0.0000353 Btc
$324,552.00
179.034 0X82AF49447D8A07E3BD95BD0D56F35241523FBAB1
0.0000%
81
MEXC Global
EOS-USDC$0.9999
0.0000353 Btc
$246,652.00
205,848.550 EOS
0.0191%
82
Coinfield
BTC-USDC$1.001
0.0000353 Btc
$226,317.00
7.989 BTC
0.0000%
83
BitMart
APE-USDC$0.9999
0.0000353 Btc
$200,975.00
48,168.800 APE
0.0045%
84
Bitstamp
BTC-USDC$0.9999
0.0000353 Btc
$186,975.00
6.604 BTC
0.0000%
85
BitMart
FXS-USDC$0.9999
0.0000353 Btc
$186,734.00
21,001.000 FXS
0.0020%
86
Orderly Network
NEAR-USDC$0.9999
0.0000353 Btc
$173,949.00
90,228.140 NEAR
0.0084%
87
BitMart
TRX-USDC$0.9999
0.0000353 Btc
$156,929.00
2,383,634.000 TRX
0.2217%
88
BitMart
XLM-USDC$0.9999
0.0000353 Btc
$150,376.00
1,367,596.200 XLM
0.1272%
89
Orderly Network
WBTC-USDC$0.9999
0.0000353 Btc
$136,164.00
4.858 WBTC
0.0000%
90
MEXC Global
ATOM-USDC$0.9999
0.0000353 Btc
$135,386.00
12,114.850 ATOM
0.0011%
91
Bitget
FIL-USDC$1.001
0.0000353 Btc
$125,490.00
22,505.708 FIL
0.0021%
92
CoinJar Exchange
USDC-AUD$0.9999
0.0000353 Btc
$117,955.00
117,965.239 USDC
0.0110%
93
Bitget
AVAX-USDC$1.001
0.0000353 Btc
$112,146.00
6,463.600 AVAX
0.0006%
94
BitMart
LTC-USDC$0.9999
0.0000353 Btc
$112,035.00
1,254.530 LTC
0.0001%
95
Bittrex
USDC-USD$1.002
0.0000354 Btc
$108,046.00
107,819.585 USDC
0.0100%
96
Independent Reserve
USDC-AUD$0.997
0.0000352 Btc
$107,495.00
107,820.000 USDC
0.0100%
97
BitMart
ADA-USDC$0.9999
0.0000353 Btc
$101,725.00
251,810.000 ADA
0.0234%
98
Bitget
ATOM-USDC$1.001
0.0000353 Btc
$99,009.00
8,860.370 ATOM
0.0008%
99
Bitget
TRX-USDC$1.001
0.0000353 Btc
$88,239.00
1,351,452.400 TRX
0.1257%
100
Bitget
DOGE-USDC$1.001
0.0000353 Btc
$74,103.00
989,238.760 DOGE
0.0920%

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

Contract Name:
BridgeToken

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Apache-2.0 license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-07-08
*/

/**
 *Submitted for verification at Etherscan.io on 2022-07-08
*/

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

// SPDX-License-Identifier: MIT

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"}]

608060405234801561001057600080fd5b5060405161099338038061099383398101604081905261002f9161048e565b818161005c60017fa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d51610599565b60008051602061094c8339815191521461008657634e487b7160e01b600052600160045260246000fd5b6100928282600061009b565b505050506105fe565b6100a483610175565b6040516001600160a01b038416907f1cf3b03a6cf19fa2baba4df148e9dcabedea7f8a5c07840e207e5c089be95d3e90600090a26000825111806100e55750805b156101705761016e836001600160a01b0316635c60da1b6040518163ffffffff1660e01b815260040160206040518083038186803b15801561012657600080fd5b505afa15801561013a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061015e9190610474565b8361031560201b6100291760201c565b505b505050565b6101888161034160201b6100551760201c565b6101e75760405162461bcd60e51b815260206004820152602560248201527f455243313936373a206e657720626561636f6e206973206e6f74206120636f6e6044820152641d1c9858dd60da1b60648201526084015b60405180910390fd5b61026a816001600160a01b0316635c60da1b6040518163ffffffff1660e01b815260040160206040518083038186803b15801561022357600080fd5b505afa158015610237573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061025b9190610474565b61034160201b6100551760201c565b6102cf5760405162461bcd60e51b815260206004820152603060248201527f455243313936373a20626561636f6e20696d706c656d656e746174696f6e206960448201526f1cc81b9bdd08184818dbdb9d1c9858dd60821b60648201526084016101de565b806102f460008051602061094c83398151915260001b61034760201b61005b1760201c565b80546001600160a01b0319166001600160a01b039290921691909117905550565b606061033a838360405180606001604052806027815260200161096c6027913961034a565b9392505050565b3b151590565b90565b6060833b6103a95760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b60648201526084016101de565b600080856001600160a01b0316856040516103c4919061054a565b600060405180830381855af49150503d80600081146103ff576040519150601f19603f3d011682016040523d82523d6000602084013e610404565b606091505b50909250905061041582828661041f565b9695505050505050565b6060831561042e57508161033a565b82511561043e5782518084602001fd5b8160405162461bcd60e51b81526004016101de9190610566565b80516001600160a01b038116811461046f57600080fd5b919050565b600060208284031215610485578081fd5b61033a82610458565b600080604083850312156104a0578081fd5b6104a983610458565b60208401519092506001600160401b03808211156104c5578283fd5b818501915085601f8301126104d8578283fd5b8151818111156104ea576104ea6105e8565b604051601f8201601f19908116603f01168101908382118183101715610512576105126105e8565b8160405282815288602084870101111561052a578586fd5b61053b8360208301602088016105bc565b80955050505050509250929050565b6000825161055c8184602087016105bc565b9190910192915050565b60208152600082518060208401526105858160408501602087016105bc565b601f01601f19169190910160400192915050565b6000828210156105b757634e487b7160e01b81526011600452602481fd5b500390565b60005b838110156105d75781810151838201526020016105bf565b8381111561016e5750506000910152565b634e487b7160e01b600052604160045260246000fd5b61033f8061060d6000396000f3fe60806040523661001357610011610017565b005b6100115b61002761002261005e565b610106565b565b606061004e83836040518060600160405280602781526020016102e36027913961012a565b9392505050565b3b151590565b90565b60006100917fa3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50546001600160a01b031690565b6001600160a01b0316635c60da1b6040518163ffffffff1660e01b815260040160206040518083038186803b1580156100c957600080fd5b505afa1580156100dd573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610101919061023c565b905090565b3660008037600080366000845af43d6000803e808015610125573d6000f35b3d6000fd5b6060833b61018e5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a2064656c65676174652063616c6c20746f206e6f6e2d636f6044820152651b9d1c9858dd60d21b60648201526084015b60405180910390fd5b600080856001600160a01b0316856040516101a99190610263565b600060405180830381855af49150503d80600081146101e4576040519150601f19603f3d011682016040523d82523d6000602084013e6101e9565b606091505b50915091506101f9828286610203565b9695505050505050565b6060831561021257508161004e565b8251156102225782518084602001fd5b8160405162461bcd60e51b8152600401610185919061027f565b60006020828403121561024d578081fd5b81516001600160a01b038116811461004e578182fd5b600082516102758184602087016102b2565b9190910192915050565b602081526000825180602084015261029e8160408501602087016102b2565b601f01601f19169190910160400192915050565b60005b838110156102cd5781810151838201526020016102b5565b838111156102dc576000848401525b5050505056fe416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564a26469706673582212203e23ac4f79a95247999f8e0df94ea5bd5e38561ccfd051b0ea50ba9aea59b8f164736f6c63430008040033a3f0ad74e5423aebfd80d3ef4346578335a9a72aeaee59ff6cb3582b35133d50416464726573733a206c6f772d6c6576656c2064656c65676174652063616c6c206661696c6564000000000000000000000000796dff6d74f3e27060b71255fe517bfb23c93eed00000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000164c71f461500000000000000000000000000000000000000000000000000000000000000e0000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000000120000000000000000000000000000000000000000000000000000000000010e51000000000000000000000000796dff6d74f3e27060b71255fe517bfb23c93eed0000000000000000000000000000000000000000000000000000000000000002000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2000000000000000000000000000000000000000000000000000000000000000d57726170706564204574686572000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000004574554480000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000

Deployed ByteCode Sourcemap

23463:129:0:-:0;;;;;;3465:11;:9;:11::i;:::-;23463:129;;3234:11;2871:113;2948:28;2958:17;:15;:17::i;:::-;2948:9;:28::i;:::-;2871:113::o;10184:200::-;10267:12;10299:77;10320:6;10328:4;10299:77;;;;;;;;;;;;;;;;;:20;:77::i;:::-;10292:84;10184:200;-1:-1:-1;;;10184:200:0:o;4590:387::-;4913:20;4961:8;;;4590:387::o;13538:151::-;13667:4;13642:40::o;22691:140::-;22758:7;22793:12;19732:66;20059:46;-1:-1:-1;;;;;20059:46:0;;19987:126;22793:12;-1:-1:-1;;;;;22785:36:0;;:38;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;22778:45;;22691:140;:::o;1461:918::-;1804:14;1801:1;1798;1785:34;2022:1;2019;2003:14;2000:1;1984:14;1977:5;1964:60;2101:16;2098:1;2095;2080:38;2141:6;2210:68;;;;2329:16;2326:1;2319:27;2210:68;2246:16;2243:1;2236:27;10578:396;10723:12;4913:20;;10748:69;;;;-1:-1:-1;;;10748:69:0;;1198:2:1;10748: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;;10748:69:0;;;;;;;;;10831:12;10845:23;10872:6;-1:-1:-1;;;;;10872:19:0;10892:4;10872:25;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10830:67;;;;10915:51;10932:7;10941:10;10953:12;10915:16;:51::i;:::-;10908:58;10578:396;-1:-1:-1;;;;;;10578:396:0:o;11202:712::-;11352:12;11381:7;11377:530;;;-1:-1:-1;11412:10:0;11405:17;;11377:530;11526:17;;:21;11522:374;;11724:10;11718:17;11785:15;11772:10;11768:2;11764:19;11757:44;11672:148;11867:12;11860:20;;-1:-1:-1;;;11860: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