ETH Price: $3,229.06 (+1.02%)

Contract

0xa98A7632CCf46Dd332FfDb8ee2C7fBF4957E8F3b
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

Token Holdings

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Settle120000902021-03-08 20:41:111414 days ago1615236071IN
0xa98A7632...4957E8F3b
0 ETH0.02104038128

Latest 1 internal transaction

Advanced mode:
Parent Transaction Hash Block
From
To
117393492021-01-27 17:57:501454 days ago1611770270  Contract Creation0 ETH
Loading...
Loading

Minimal Proxy Contract for 0x82c1cc1685be4825400854ce5b1c7d86da75b7ac

Contract Name:
Vyper_contract

Compiler Version
vyper:0.2.8

Optimization Enabled:
N/A

Other Settings:
default evmVersion, MIT license

Contract Source Code (Vyper language format)

# @version 0.2.8
"""
@title Synth Settler
@author Curve.fi
@license MIT
"""

from vyper.interfaces import ERC20


interface AddressProvider:
    def get_address(_id: uint256) -> address: view

interface RegistrySwap:
    def exchange(
        _pool: address,
        _from: address,
        _to: address,
        _amount: uint256,
        _expected: uint256,
        _receiver: address,
    ) -> uint256: payable

interface Synthetix:
    def exchangeWithTracking(
        sourceCurrencyKey: bytes32,
        sourceAmount: uint256,
        destinationCurrencyKey: bytes32,
        originator: address,
        trackingCode: bytes32,
    ): nonpayable
    def settle(currencyKey: bytes32) -> uint256[3]: nonpayable

interface Synth:
    def currencyKey() -> bytes32: nonpayable


ADDRESS_PROVIDER: constant(address) = 0x0000000022D53366457F9d5E68Ec105046FC4383
SNX: constant(address) = 0xC011a73ee8576Fb46F5E1c5751cA3B9Fe0af2a6F

# "CURVE" as a bytes32
TRACKING_CODE: constant(bytes32) = 0x4355525645000000000000000000000000000000000000000000000000000000

# synth -> spender -> is approved?
is_approved: HashMap[address, HashMap[address, bool]]

admin: public(address)
synth: public(address)

@external
def __init__():
    self.admin = msg.sender


@external
def convert_synth(
    _target: address,
    _amount: uint256,
    _source_key: bytes32,
    _dest_key: bytes32
) -> bool:
    """
    @notice Convert between two synths
    @dev Called via `SynthSwap.swap_into_synth`
    @param _target Address of the synth being converted into
    @param _amount Amount of the original synth to convert
    @param _source_key Currency key for the initial synth
    @param _dest_key Currency key for the target synth
    @return bool Success
    """
    assert msg.sender == self.admin

    self.synth = _target
    Synthetix(SNX).exchangeWithTracking(_source_key, _amount, _dest_key, msg.sender, TRACKING_CODE)

    return True


@external
def exchange(
    _target: address,
    _pool: address,
    _amount: uint256,
    _expected: uint256,
    _receiver: address,
) -> uint256:
    """
    @notice Exchange the synth deposited in this contract for another asset
    @dev Called via `SynthSwap.swap_from_synth`
    @param _target Address of the asset being swapped into
    @param _pool Address of the Curve pool used in the exchange
    @param _amount Amount of the deposited synth to exchange
    @param _expected Minimum amount of `_target` to receive in the exchange
    @param _receiver Receiver address for `_target`
    @return uint256 Amount of the deposited synth remaining in the contract
    """
    assert msg.sender == self.admin

    synth: address = self.synth
    registry_swap: address = AddressProvider(ADDRESS_PROVIDER).get_address(2)

    if not self.is_approved[synth][registry_swap]:
        ERC20(synth).approve(registry_swap, MAX_UINT256)
        self.is_approved[synth][registry_swap] = True

    RegistrySwap(registry_swap).exchange(_pool, synth, _target, _amount, _expected, _receiver)

    return ERC20(synth).balanceOf(self)


@external
def withdraw(_receiver: address, _amount: uint256) -> uint256:
    """
    @notice Withdraw the synth deposited in this contract
    @dev Called via `SynthSwap.withdraw`
    @param _receiver Receiver address for the deposited synth
    @param _amount Amount of the deposited synth to withdraw
    @return uint256 Amount of the deposited synth remaining in the contract
    """
    assert msg.sender == self.admin

    synth: address = self.synth
    ERC20(synth).transfer(_receiver, _amount)

    return ERC20(synth).balanceOf(self)


@external
def settle() -> bool:
    """
    @notice Settle the synth deposited in this contract
    @dev Settlement is performed when swapping or withdrawing, there
         is no requirement to call this function separately
    @return bool Success
    """
    currency_key: bytes32 = Synth(self.synth).currencyKey()
    Synthetix(SNX).settle(currency_key)

    return True


@external
def initialize():
    """
    @notice Initialize the contract
    @dev This function is seperate from `__init__` because of the factory
         pattern used in `SynthSwap`. It may be called once per deployment.
    """
    assert self.admin == ZERO_ADDRESS

    self.admin = msg.sender

Contract ABI

[{"outputs":[],"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"name":"convert_synth","outputs":[{"type":"bool","name":""}],"inputs":[{"type":"address","name":"_target"},{"type":"uint256","name":"_amount"},{"type":"bytes32","name":"_source_key"},{"type":"bytes32","name":"_dest_key"}],"stateMutability":"nonpayable","type":"function","gas":37972},{"name":"exchange","outputs":[{"type":"uint256","name":""}],"inputs":[{"type":"address","name":"_target"},{"type":"address","name":"_pool"},{"type":"uint256","name":"_amount"},{"type":"uint256","name":"_expected"},{"type":"address","name":"_receiver"}],"stateMutability":"nonpayable","type":"function","gas":41296},{"name":"withdraw","outputs":[{"type":"uint256","name":""}],"inputs":[{"type":"address","name":"_receiver"},{"type":"uint256","name":"_amount"}],"stateMutability":"nonpayable","type":"function","gas":3441},{"name":"settle","outputs":[{"type":"bool","name":""}],"inputs":[],"stateMutability":"nonpayable","type":"function","gas":3118},{"name":"initialize","outputs":[],"inputs":[],"stateMutability":"nonpayable","type":"function","gas":36232},{"name":"admin","outputs":[{"type":"address","name":""}],"inputs":[],"stateMutability":"view","type":"function","gas":1211},{"name":"synth","outputs":[{"type":"address","name":""}],"inputs":[],"stateMutability":"view","type":"function","gas":1241}]

Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.