ETH Price: $1,975.05 (-0.06%)
 
Transaction Hash
Method
Block
From
To
Manual Withdraw220978092025-03-21 21:02:2322 mins ago1742590943IN
0x4315990D...03FA1126f
0 ETH0.000165730.9324682
Deposit Eth220974422025-03-21 19:48:591 hr ago1742586539IN
0x4315990D...03FA1126f
0.004 ETH0.000070780.43110679
Manual Withdraw220973362025-03-21 19:27:471 hr ago1742585267IN
0x4315990D...03FA1126f
0 ETH0.000153140.88561889
Deposit Eth220970512025-03-21 18:30:352 hrs ago1742581835IN
0x4315990D...03FA1126f
0.101 ETH0.000170530.94068477
Deposit Eth220970502025-03-21 18:30:232 hrs ago1742581823IN
0x4315990D...03FA1126f
0.103 ETH0.000162550.89666898
Deposit Eth220970462025-03-21 18:29:352 hrs ago1742581775IN
0x4315990D...03FA1126f
0.102 ETH0.000162320.89539726
Deposit Eth220969782025-03-21 18:15:593 hrs ago1742580959IN
0x4315990D...03FA1126f
0.000001 ETH0.000086910.47941869
Deposit Eth220967192025-03-21 17:24:114 hrs ago1742577851IN
0x4315990D...03FA1126f
0.00002111 ETH0.00016190.89308244
Manual Withdraw220966292025-03-21 17:06:114 hrs ago1742576771IN
0x4315990D...03FA1126f
0 ETH0.000120471.03928577
Deposit Eth220966132025-03-21 17:02:594 hrs ago1742576579IN
0x4315990D...03FA1126f
0.025 ETH0.000097540.59409557
Manual Withdraw220965802025-03-21 16:56:234 hrs ago1742576183IN
0x4315990D...03FA1126f
0 ETH0.000187781.08576573
Manual Withdraw220965202025-03-21 16:44:234 hrs ago1742575463IN
0x4315990D...03FA1126f
0 ETH0.000182061.05267129
Manual Withdraw220962912025-03-21 15:58:355 hrs ago1742572715IN
0x4315990D...03FA1126f
0 ETH0.000166960.96560738
Deposit Eth220959962025-03-21 14:59:356 hrs ago1742569175IN
0x4315990D...03FA1126f
0.21 ETH0.000092880.5657391
Manual Withdraw220959282025-03-21 14:45:596 hrs ago1742568359IN
0x4315990D...03FA1126f
0 ETH0.000170630.98667098
Manual Withdraw220959282025-03-21 14:45:596 hrs ago1742568359IN
0x4315990D...03FA1126f
0 ETH0.000170630.98667098
Manual Withdraw220959282025-03-21 14:45:596 hrs ago1742568359IN
0x4315990D...03FA1126f
0 ETH0.000170630.98667098
Manual Withdraw220959282025-03-21 14:45:596 hrs ago1742568359IN
0x4315990D...03FA1126f
0 ETH0.000170630.98667098
Manual Withdraw220959282025-03-21 14:45:596 hrs ago1742568359IN
0x4315990D...03FA1126f
0 ETH0.000170630.98667098
Manual Withdraw220959282025-03-21 14:45:596 hrs ago1742568359IN
0x4315990D...03FA1126f
0 ETH0.000170630.98667098
Deposit Eth220958472025-03-21 14:29:476 hrs ago1742567387IN
0x4315990D...03FA1126f
0.8104 ETH0.000177650.97998016
Deposit Eth220958212025-03-21 14:24:357 hrs ago1742567075IN
0x4315990D...03FA1126f
0.59 ETH0.000175580.96855883
Deposit Eth220957612025-03-21 14:12:237 hrs ago1742566343IN
0x4315990D...03FA1126f
0.03 ETH0.000181281
Manual Withdraw220957242025-03-21 14:04:597 hrs ago1742565899IN
0x4315990D...03FA1126f
0 ETH0.000182681.05627263
Manual Withdraw220957072025-03-21 14:01:357 hrs ago1742565695IN
0x4315990D...03FA1126f
0 ETH0.000173021.00041268
View all transactions

Latest 25 internal transactions (View All)

Advanced mode:
Parent Transaction Hash Method Block
From
To
Transfer220978092025-03-21 21:02:2322 mins ago1742590943
0x4315990D...03FA1126f
0.00068399 ETH
Transfer220973362025-03-21 19:27:471 hr ago1742585267
0x4315990D...03FA1126f
0.1108087 ETH
Transfer220965802025-03-21 16:56:234 hrs ago1742576183
0x4315990D...03FA1126f
1.10617051 ETH
Transfer220965202025-03-21 16:44:234 hrs ago1742575463
0x4315990D...03FA1126f
0.11080823 ETH
Transfer220962912025-03-21 15:58:355 hrs ago1742572715
0x4315990D...03FA1126f
0.00000015 ETH
Transfer220959282025-03-21 14:45:596 hrs ago1742568359
0x4315990D...03FA1126f
0.00427181 ETH
Transfer220959282025-03-21 14:45:596 hrs ago1742568359
0x4315990D...03FA1126f
0.00437232 ETH
Transfer220959282025-03-21 14:45:596 hrs ago1742568359
0x4315990D...03FA1126f
0.0045834 ETH
Transfer220959282025-03-21 14:45:596 hrs ago1742568359
0x4315990D...03FA1126f
0.00467386 ETH
Transfer220959282025-03-21 14:45:596 hrs ago1742568359
0x4315990D...03FA1126f
0.00467788 ETH
Transfer220959282025-03-21 14:45:596 hrs ago1742568359
0x4315990D...03FA1126f
0.0042316 ETH
Transfer220957242025-03-21 14:04:597 hrs ago1742565899
0x4315990D...03FA1126f
0.10000564 ETH
Transfer220957072025-03-21 14:01:357 hrs ago1742565695
0x4315990D...03FA1126f
0.10000564 ETH
Transfer220956952025-03-21 13:59:117 hrs ago1742565551
0x4315990D...03FA1126f
2.95787274 ETH
Transfer220956802025-03-21 13:56:117 hrs ago1742565371
0x4315990D...03FA1126f
0.10000564 ETH
Transfer220956662025-03-21 13:53:237 hrs ago1742565203
0x4315990D...03FA1126f
0.10000564 ETH
Transfer220956552025-03-21 13:51:117 hrs ago1742565071
0x4315990D...03FA1126f
0.10000564 ETH
Transfer220956452025-03-21 13:49:117 hrs ago1742564951
0x4315990D...03FA1126f
0.90868032 ETH
Transfer220956312025-03-21 13:46:237 hrs ago1742564783
0x4315990D...03FA1126f
0.10000564 ETH
Transfer220955822025-03-21 13:36:357 hrs ago1742564195
0x4315990D...03FA1126f
0.10000564 ETH
Transfer220954772025-03-21 13:15:358 hrs ago1742562935
0x4315990D...03FA1126f
0.10000564 ETH
Transfer220954682025-03-21 13:13:478 hrs ago1742562827
0x4315990D...03FA1126f
0.00469397 ETH
Transfer220954682025-03-21 13:13:478 hrs ago1742562827
0x4315990D...03FA1126f
0.00500556 ETH
Transfer220954682025-03-21 13:13:478 hrs ago1742562827
0x4315990D...03FA1126f
0.00480453 ETH
Transfer220954682025-03-21 13:13:478 hrs ago1742562827
0x4315990D...03FA1126f
0.00491509 ETH
View All Internal Transactions
Loading...
Loading

Similar Match Source Code
This contract matches the deployed Bytecode of the Source Code for Contract 0x6790660A...c5Ca66C5F
The constructor portion of the code might be different and could alter the actual behaviour of the contract

Contract Name:
Diamond

Compiler Version
v0.8.24+commit.e11b9ed9

Optimization Enabled:
No with 200 runs

Other Settings:
paris EvmVersion
File 1 of 3 : Diamond.sol
// SPDX-License-Identifier: Apache-2.0.
pragma solidity ^0.8.24;

import {LibDiamond} from "./libraries/LibDiamond.sol";
import {IDiamondCut} from "./interfaces/IDiamondCut.sol";

contract Diamond {
  constructor(address _contractOwner, address _diamondCutFacet) payable {
    LibDiamond.setContractOwner(_contractOwner);

    // Add the diamondCut external function from the diamondCutFacet
    IDiamondCut.FacetCut[] memory cut = new IDiamondCut.FacetCut[](1);
    bytes4[] memory functionSelectors = new bytes4[](1);
    functionSelectors[0] = IDiamondCut.diamondCut.selector;
    cut[0] = IDiamondCut.FacetCut({
      facetAddress: _diamondCutFacet,
      action: IDiamondCut.FacetCutAction.Add,
      functionSelectors: functionSelectors
    });
    LibDiamond.diamondCut(cut, address(0), "");
  }

  // Find facet for function that is called and execute the
  // function if a facet is found and return any value.
  fallback() external payable {
    LibDiamond.DiamondStorage storage ds;
    bytes32 position = LibDiamond.DIAMOND_STORAGE_POSITION;
    // get diamond storage
    assembly {
      ds.slot := position
    }
    // get facet from function selector
    address facet = ds.selectorToFacetAndPosition[msg.sig].facetAddress;
    require(facet != address(0), "Diamond: Function does not exist");
    // Execute external function from facet using delegatecall and return any value.
    assembly {
      // copy function selector and any arguments
      calldatacopy(0, 0, calldatasize())
      // execute function call using the facet
      let result := delegatecall(gas(), facet, 0, calldatasize(), 0, 0)
      // get any return value
      returndatacopy(0, 0, returndatasize())
      // return any return value or error back to the caller
      switch result
      case 0 {
        revert(0, returndatasize())
      }
      default {
        return(0, returndatasize())
      }
    }
  }

  receive() external payable {}
}

File 2 of 3 : IDiamondCut.sol
// SPDX-License-Identifier: Apache-2.0.
pragma solidity ^0.8.24;

/******************************************************************************\
* Author: Nick Mudge <[email protected]> (https://twitter.com/mudgen)
* EIP-2535 Diamonds: https://eips.ethereum.org/EIPS/eip-2535
/******************************************************************************/

interface IDiamondCut {
  enum FacetCutAction {
    Add,
    Replace,
    Remove
  }
  // Add=0, Replace=1, Remove=2

  struct FacetCut {
    address facetAddress;
    FacetCutAction action;
    bytes4[] functionSelectors;
  }

  /// @notice Add/replace/remove any number of functions and optionally execute
  ///         a function with delegatecall
  /// @param _diamondCut Contains the facet addresses and function selectors
  /// @param _init The address of the contract or facet to execute _calldata
  /// @param _calldata A function call, including function selector and arguments
  ///                  _calldata is executed with delegatecall on _init
  function diamondCut(
    FacetCut[] calldata _diamondCut,
    address _init,
    bytes calldata _calldata
  ) external;

  event DiamondCut(FacetCut[] _diamondCut, address _init, bytes _calldata);
}

File 3 of 3 : LibDiamond.sol
// SPDX-License-Identifier: Apache-2.0.
pragma solidity ^0.8.24;

/******************************************************************************\
* Author: Nick Mudge <[email protected]> (https://twitter.com/mudgen)
* EIP-2535 Diamonds: https://eips.ethereum.org/EIPS/eip-2535
/******************************************************************************/
import {IDiamondCut} from "../interfaces/IDiamondCut.sol";

// Remember to add the loupe functions from DiamondLoupeFacet to the diamond.
// The loupe functions are required by the EIP2535 Diamonds standard

error InitializationFunctionReverted(
  address _initializationContractAddress,
  bytes _calldata
);

library LibDiamond {
  bytes32 constant DIAMOND_STORAGE_POSITION =
    keccak256("diamond.standard.diamond.storage");

  struct FacetAddressAndPosition {
    address facetAddress;
    uint96 functionSelectorPosition; // position in facetFunctionSelectors.functionSelectors array
  }

  struct FacetFunctionSelectors {
    bytes4[] functionSelectors;
    uint256 facetAddressPosition; // position of facetAddress in facetAddresses array
  }

  struct DiamondStorage {
    // maps function selector to the facet address and
    // the position of the selector in the facetFunctionSelectors.selectors array
    mapping(bytes4 => FacetAddressAndPosition) selectorToFacetAndPosition;
    // maps facet addresses to function selectors
    mapping(address => FacetFunctionSelectors) facetFunctionSelectors;
    // facet addresses
    address[] facetAddresses;
    // Used to query if a contract implements an interface.
    // Used to implement ERC-165.
    mapping(bytes4 => bool) supportedInterfaces;
    // owner of the contract
    address contractOwner;
  }

  function diamondStorage() internal pure returns (DiamondStorage storage ds) {
    bytes32 position = DIAMOND_STORAGE_POSITION;
    assembly {
      ds.slot := position
    }
  }

  event OwnershipTransferred(
    address indexed previousOwner,
    address indexed newOwner
  );

  function setContractOwner(address _newOwner) internal {
    DiamondStorage storage ds = diamondStorage();
    address previousOwner = ds.contractOwner;
    ds.contractOwner = _newOwner;
    emit OwnershipTransferred(previousOwner, _newOwner);
  }

  function contractOwner() internal view returns (address contractOwner_) {
    contractOwner_ = diamondStorage().contractOwner;
  }

  function enforceIsContractOwner() internal view {
    require(
      msg.sender == diamondStorage().contractOwner,
      "LibDiamond: Must be contract owner"
    );
  }

  event DiamondCut(
    IDiamondCut.FacetCut[] _diamondCut,
    address _init,
    bytes _calldata
  );

  // Internal function version of diamondCut
  function diamondCut(
    IDiamondCut.FacetCut[] memory _diamondCut,
    address _init,
    bytes memory _calldata
  ) internal {
    for (uint256 facetIndex; facetIndex < _diamondCut.length; facetIndex++) {
      IDiamondCut.FacetCutAction action = _diamondCut[facetIndex].action;
      if (action == IDiamondCut.FacetCutAction.Add) {
        addFunctions(
          _diamondCut[facetIndex].facetAddress,
          _diamondCut[facetIndex].functionSelectors
        );
      } else if (action == IDiamondCut.FacetCutAction.Replace) {
        replaceFunctions(
          _diamondCut[facetIndex].facetAddress,
          _diamondCut[facetIndex].functionSelectors
        );
      } else if (action == IDiamondCut.FacetCutAction.Remove) {
        removeFunctions(
          _diamondCut[facetIndex].facetAddress,
          _diamondCut[facetIndex].functionSelectors
        );
      } else {
        revert("LibDiamondCut: Incorrect FacetCutAction");
      }
    }
    emit DiamondCut(_diamondCut, _init, _calldata);
    initializeDiamondCut(_init, _calldata);
  }

  function addFunctions(
    address _facetAddress,
    bytes4[] memory _functionSelectors
  ) internal {
    require(
      _functionSelectors.length > 0,
      "LibDiamondCut: No selectors in facet to cut"
    );
    DiamondStorage storage ds = diamondStorage();
    require(
      _facetAddress != address(0),
      "LibDiamondCut: Add facet can't be address(0)"
    );
    uint96 selectorPosition = uint96(
      ds.facetFunctionSelectors[_facetAddress].functionSelectors.length
    );
    // add new facet address if it does not exist
    if (selectorPosition == 0) {
      addFacet(ds, _facetAddress);
    }
    for (
      uint256 selectorIndex;
      selectorIndex < _functionSelectors.length;
      selectorIndex++
    ) {
      bytes4 selector = _functionSelectors[selectorIndex];
      address oldFacetAddress = ds
        .selectorToFacetAndPosition[selector]
        .facetAddress;
      require(
        oldFacetAddress == address(0),
        "LibDiamondCut: Can't add function that already exists"
      );
      addFunction(ds, selector, selectorPosition, _facetAddress);
      selectorPosition++;
    }
  }

  function replaceFunctions(
    address _facetAddress,
    bytes4[] memory _functionSelectors
  ) internal {
    require(
      _functionSelectors.length > 0,
      "LibDiamondCut: No selectors in facet to cut"
    );
    DiamondStorage storage ds = diamondStorage();
    require(
      _facetAddress != address(0),
      "LibDiamondCut: Add facet can't be address(0)"
    );
    uint96 selectorPosition = uint96(
      ds.facetFunctionSelectors[_facetAddress].functionSelectors.length
    );
    // add new facet address if it does not exist
    if (selectorPosition == 0) {
      addFacet(ds, _facetAddress);
    }
    for (
      uint256 selectorIndex;
      selectorIndex < _functionSelectors.length;
      selectorIndex++
    ) {
      bytes4 selector = _functionSelectors[selectorIndex];
      address oldFacetAddress = ds
        .selectorToFacetAndPosition[selector]
        .facetAddress;
      require(
        oldFacetAddress != _facetAddress,
        "LibDiamondCut: Can't replace function with same function"
      );
      removeFunction(ds, oldFacetAddress, selector);
      addFunction(ds, selector, selectorPosition, _facetAddress);
      selectorPosition++;
    }
  }

  function removeFunctions(
    address _facetAddress,
    bytes4[] memory _functionSelectors
  ) internal {
    require(
      _functionSelectors.length > 0,
      "LibDiamondCut: No selectors in facet to cut"
    );
    DiamondStorage storage ds = diamondStorage();
    // if function does not exist then do nothing and return
    require(
      _facetAddress == address(0),
      "LibDiamondCut: Remove facet address must be address(0)"
    );
    for (
      uint256 selectorIndex;
      selectorIndex < _functionSelectors.length;
      selectorIndex++
    ) {
      bytes4 selector = _functionSelectors[selectorIndex];
      address oldFacetAddress = ds
        .selectorToFacetAndPosition[selector]
        .facetAddress;
      removeFunction(ds, oldFacetAddress, selector);
    }
  }

  function addFacet(DiamondStorage storage ds, address _facetAddress) internal {
    enforceHasContractCode(
      _facetAddress,
      "LibDiamondCut: New facet has no code"
    );
    ds.facetFunctionSelectors[_facetAddress].facetAddressPosition = ds
      .facetAddresses
      .length;
    ds.facetAddresses.push(_facetAddress);
  }

  function addFunction(
    DiamondStorage storage ds,
    bytes4 _selector,
    uint96 _selectorPosition,
    address _facetAddress
  ) internal {
    ds
      .selectorToFacetAndPosition[_selector]
      .functionSelectorPosition = _selectorPosition;
    ds.facetFunctionSelectors[_facetAddress].functionSelectors.push(_selector);
    ds.selectorToFacetAndPosition[_selector].facetAddress = _facetAddress;
  }

  function removeFunction(
    DiamondStorage storage ds,
    address _facetAddress,
    bytes4 _selector
  ) internal {
    require(
      _facetAddress != address(0),
      "LibDiamondCut: Can't remove function that doesn't exist"
    );
    // an immutable function is a function defined directly in a diamond
    require(
      _facetAddress != address(this),
      "LibDiamondCut: Can't remove immutable function"
    );
    // replace selector with last selector, then delete last selector
    uint256 selectorPosition = ds
      .selectorToFacetAndPosition[_selector]
      .functionSelectorPosition;
    uint256 lastSelectorPosition = ds
      .facetFunctionSelectors[_facetAddress]
      .functionSelectors
      .length - 1;
    // if not the same then replace _selector with lastSelector
    if (selectorPosition != lastSelectorPosition) {
      bytes4 lastSelector = ds
        .facetFunctionSelectors[_facetAddress]
        .functionSelectors[lastSelectorPosition];
      ds.facetFunctionSelectors[_facetAddress].functionSelectors[
        selectorPosition
      ] = lastSelector;
      ds
        .selectorToFacetAndPosition[lastSelector]
        .functionSelectorPosition = uint96(selectorPosition);
    }
    // delete the last selector
    ds.facetFunctionSelectors[_facetAddress].functionSelectors.pop();
    delete ds.selectorToFacetAndPosition[_selector];

    // if no more selectors for facet address then delete the facet address
    if (lastSelectorPosition == 0) {
      // replace facet address with last facet address and delete last facet address
      uint256 lastFacetAddressPosition = ds.facetAddresses.length - 1;
      uint256 facetAddressPosition = ds
        .facetFunctionSelectors[_facetAddress]
        .facetAddressPosition;
      if (facetAddressPosition != lastFacetAddressPosition) {
        address lastFacetAddress = ds.facetAddresses[lastFacetAddressPosition];
        ds.facetAddresses[facetAddressPosition] = lastFacetAddress;
        ds
          .facetFunctionSelectors[lastFacetAddress]
          .facetAddressPosition = facetAddressPosition;
      }
      ds.facetAddresses.pop();
      delete ds.facetFunctionSelectors[_facetAddress].facetAddressPosition;
    }
  }

  function initializeDiamondCut(
    address _init,
    bytes memory _calldata
  ) internal {
    if (_init == address(0)) {
      return;
    }
    enforceHasContractCode(_init, "LibDiamondCut: _init address has no code");
    (bool success, bytes memory error) = _init.delegatecall(_calldata);
    if (!success) {
      if (error.length > 0) {
        // bubble up error
        /// @solidity memory-safe-assembly
        assembly {
          let returndata_size := mload(error)
          revert(add(32, error), returndata_size)
        }
      } else {
        revert InitializationFunctionReverted(_init, _calldata);
      }
    }
  }

  function enforceHasContractCode(
    address _contract,
    string memory _errorMessage
  ) internal view {
    uint256 contractSize;
    assembly {
      contractSize := extcodesize(_contract)
    }
    require(contractSize > 0, _errorMessage);
  }
}

Settings
{
  "evmVersion": "paris",
  "optimizer": {
    "enabled": false,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  },
  "libraries": {}
}

Contract Security Audit

Contract ABI

API
[{"inputs":[{"internalType":"address","name":"_contractOwner","type":"address"},{"internalType":"address","name":"_diamondCutFacet","type":"address"}],"stateMutability":"payable","type":"constructor"},{"inputs":[{"internalType":"address","name":"_initializationContractAddress","type":"address"},{"internalType":"bytes","name":"_calldata","type":"bytes"}],"name":"InitializationFunctionReverted","type":"error"},{"anonymous":false,"inputs":[{"components":[{"internalType":"address","name":"facetAddress","type":"address"},{"internalType":"enum IDiamondCut.FacetCutAction","name":"action","type":"uint8"},{"internalType":"bytes4[]","name":"functionSelectors","type":"bytes4[]"}],"indexed":false,"internalType":"struct IDiamondCut.FacetCut[]","name":"_diamondCut","type":"tuple[]"},{"indexed":false,"internalType":"address","name":"_init","type":"address"},{"indexed":false,"internalType":"bytes","name":"_calldata","type":"bytes"}],"name":"DiamondCut","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"stateMutability":"payable","type":"fallback"},{"stateMutability":"payable","type":"receive"}]

Deployed Bytecode

0x60806040523661000b57005b6000807fc8fcad8db84d3cc18b4c41d551ea0ee66dd599cde068d998e57d5e09332c131c9050809150600082600001600080357fffffffff00000000000000000000000000000000000000000000000000000000167bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19167bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916815260200190815260200160002060000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1603610141576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610138906101c4565b60405180910390fd5b3660008037600080366000845af43d6000803e8060008114610162573d6000f35b3d6000fd5b600082825260208201905092915050565b7f4469616d6f6e643a2046756e6374696f6e20646f6573206e6f74206578697374600082015250565b60006101ae602083610167565b91506101b982610178565b602082019050919050565b600060208201905081810360008301526101dd816101a1565b905091905056fea26469706673582212204897019434b4377d0294d051161153584bc9b27bea1602d4501b4ca5249fd14a64736f6c63430008180033

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.