Source Code
Latest 25 from a total of 56 transactions
| Transaction Hash |
Method
|
Block
|
From
|
|
To
|
||||
|---|---|---|---|---|---|---|---|---|---|
| Public Mint | 14541123 | 1430 days ago | IN | 0.31415 ETH | 0.00218277 | ||||
| Public Mint | 14538165 | 1430 days ago | IN | 0.31415 ETH | 0.00632588 | ||||
| Public Mint | 14533509 | 1431 days ago | IN | 0.31415 ETH | 0.01323674 | ||||
| Public Mint | 14530703 | 1431 days ago | IN | 0.31415 ETH | 0.00546419 | ||||
| Public Mint | 14527132 | 1432 days ago | IN | 0.6283 ETH | 0.01073123 | ||||
| Public Mint | 14527111 | 1432 days ago | IN | 0.31415 ETH | 0.00924619 | ||||
| Public Mint | 14523643 | 1432 days ago | IN | 0.31415 ETH | 0.00889969 | ||||
| Public Mint | 14515125 | 1434 days ago | IN | 0.31415 ETH | 0.0077572 | ||||
| Public Mint | 14512709 | 1434 days ago | IN | 0.31415 ETH | 0.00766879 | ||||
| Public Mint | 14508282 | 1435 days ago | IN | 0.31415 ETH | 0.00752594 | ||||
| Public Mint | 14507256 | 1435 days ago | IN | 0.6283 ETH | 0.01118425 | ||||
| Public Mint | 14505503 | 1435 days ago | IN | 0.31415 ETH | 0.0049406 | ||||
| Public Mint | 14502642 | 1436 days ago | IN | 0.31415 ETH | 0.01399421 | ||||
| Public Mint | 14502135 | 1436 days ago | IN | 1.2566 ETH | 0.02443025 | ||||
| Public Mint | 14501863 | 1436 days ago | IN | 0.31415 ETH | 0.01242024 | ||||
| Public Mint | 14501169 | 1436 days ago | IN | 3.1415 ETH | 0.06260476 | ||||
| Public Mint | 14500304 | 1436 days ago | IN | 0.31415 ETH | 0.00705018 | ||||
| Public Mint | 14500263 | 1436 days ago | IN | 0.31415 ETH | 0.00606132 | ||||
| Public Mint | 14500054 | 1436 days ago | IN | 0.94245 ETH | 0.01084535 | ||||
| Public Mint | 14498763 | 1436 days ago | IN | 0.31415 ETH | 0.00467023 | ||||
| Public Mint | 14498423 | 1436 days ago | IN | 0.31415 ETH | 0.00540214 | ||||
| Public Mint | 14498395 | 1436 days ago | IN | 0.31415 ETH | 0.00706018 | ||||
| Public Mint | 14498372 | 1436 days ago | IN | 0.31415 ETH | 0.00581099 | ||||
| Public Mint | 14498358 | 1436 days ago | IN | 0.31415 ETH | 0.00899571 | ||||
| Public Mint | 14497971 | 1436 days ago | IN | 0.31415 ETH | 0.01490864 |
Latest 25 internal transactions (View All)
Advanced mode:
| Parent Transaction Hash | Method | Block |
From
|
|
To
|
||
|---|---|---|---|---|---|---|---|
| - | 14541123 | 1430 days ago | 0.31415 ETH | ||||
| - | 14538165 | 1430 days ago | 0.31415 ETH | ||||
| - | 14533509 | 1431 days ago | 0.31415 ETH | ||||
| - | 14530703 | 1431 days ago | 0.31415 ETH | ||||
| - | 14527132 | 1432 days ago | 0.6283 ETH | ||||
| - | 14527111 | 1432 days ago | 0.31415 ETH | ||||
| - | 14523643 | 1432 days ago | 0.31415 ETH | ||||
| - | 14515125 | 1434 days ago | 0.31415 ETH | ||||
| - | 14512709 | 1434 days ago | 0.31415 ETH | ||||
| - | 14508282 | 1435 days ago | 0.31415 ETH | ||||
| - | 14507256 | 1435 days ago | 0.6283 ETH | ||||
| - | 14505503 | 1435 days ago | 0.31415 ETH | ||||
| - | 14502642 | 1436 days ago | 0.31415 ETH | ||||
| - | 14502135 | 1436 days ago | 1.2566 ETH | ||||
| - | 14501863 | 1436 days ago | 0.31415 ETH | ||||
| - | 14501169 | 1436 days ago | 3.1415 ETH | ||||
| - | 14500304 | 1436 days ago | 0.31415 ETH | ||||
| - | 14500263 | 1436 days ago | 0.31415 ETH | ||||
| - | 14500054 | 1436 days ago | 0.94245 ETH | ||||
| - | 14498763 | 1436 days ago | 0.31415 ETH | ||||
| - | 14498423 | 1436 days ago | 0.31415 ETH | ||||
| - | 14498395 | 1436 days ago | 0.31415 ETH | ||||
| - | 14498372 | 1436 days ago | 0.31415 ETH | ||||
| - | 14498358 | 1436 days ago | 0.31415 ETH | ||||
| - | 14497971 | 1436 days ago | 0.31415 ETH |
Loading...
Loading
Loading...
Loading
Cross-Chain Transactions
Loading...
Loading
Contract Name:
UniverseMachinePublicSale
Compiler Version
v0.8.13+commit.abaa5c0e
Optimization Enabled:
Yes with 1 runs
Other Settings:
default evmVersion
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.13;
import "./IPublicMintable.sol";
import "@openzeppelin/contracts/access/Ownable.sol";
import "@openzeppelin/contracts/utils/Address.sol";
contract UniverseMachinePublicSale is Ownable {
using Address for address payable;
IPublicMintable immutable parent;
constructor(IPublicMintable _parent) {
parent = _parent;
}
event RefundReceived(uint256 value);
event RefundForwarded(address to, uint256 value);
receive() external payable {
emit RefundReceived(msg.value);
}
function publicMint(uint256 n) external payable {
parent.mintPublic{value: msg.value}(msg.sender, n);
// ethier Seller contract will refund here so we need to propagate it
// and always have a zero balance at the end. This will only happen if
// there's a race condition for the final token.
uint256 balance = address(this).balance;
if (balance > 0) {
payable(msg.sender).sendValue(balance);
emit RefundForwarded(msg.sender, balance);
}
assert(address(this).balance == 0);
}
}// SPDX-License-Identifier: MIT
pragma solidity ^0.8.13;
interface IPublicMintable {
function mintPublic(address to, uint256 n) external payable;
}// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (access/Ownable.sol)
pragma solidity ^0.8.0;
import "../utils/Context.sol";
/**
* @dev Contract module which provides a basic access control mechanism, where
* there is an account (an owner) that can be granted exclusive access to
* specific functions.
*
* By default, the owner account will be the one that deploys the contract. This
* can later be changed with {transferOwnership}.
*
* This module is used through inheritance. It will make available the modifier
* `onlyOwner`, which can be applied to your functions to restrict their use to
* the owner.
*/
abstract contract Ownable is Context {
address private _owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
/**
* @dev Initializes the contract setting the deployer as the initial owner.
*/
constructor() {
_transferOwnership(_msgSender());
}
/**
* @dev Returns the address of the current owner.
*/
function owner() public view virtual returns (address) {
return _owner;
}
/**
* @dev Throws if called by any account other than the owner.
*/
modifier onlyOwner() {
require(owner() == _msgSender(), "Ownable: caller is not the owner");
_;
}
/**
* @dev Leaves the contract without owner. It will not be possible to call
* `onlyOwner` functions anymore. Can only be called by the current owner.
*
* NOTE: Renouncing ownership will leave the contract without an owner,
* thereby removing any functionality that is only available to the owner.
*/
function renounceOwnership() public virtual onlyOwner {
_transferOwnership(address(0));
}
/**
* @dev Transfers ownership of the contract to a new account (`newOwner`).
* Can only be called by the current owner.
*/
function transferOwnership(address newOwner) public virtual onlyOwner {
require(newOwner != address(0), "Ownable: new owner is the zero address");
_transferOwnership(newOwner);
}
/**
* @dev Transfers ownership of the contract to a new account (`newOwner`).
* Internal function without access restriction.
*/
function _transferOwnership(address newOwner) internal virtual {
address oldOwner = _owner;
_owner = newOwner;
emit OwnershipTransferred(oldOwner, newOwner);
}
}// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.5.0) (utils/Address.sol)
pragma solidity ^0.8.1;
/**
* @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
* ====
*
* [IMPORTANT]
* ====
* You shouldn't rely on `isContract` to protect against flash loan attacks!
*
* Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets
* like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract
* constructor.
* ====
*/
function isContract(address account) internal view returns (bool) {
// This method relies on extcodesize/address.code.length, which returns 0
// for contracts in construction, since the code is only stored at the end
// of the constructor execution.
return account.code.length > 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);
}
}
}
}// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)
pragma solidity ^0.8.0;
/**
* @dev Provides information about the current execution context, including the
* sender of the transaction and its data. While these are generally available
* via msg.sender and msg.data, they should not be accessed in such a direct
* manner, since when dealing with meta-transactions the account sending and
* paying for execution may not be the actual sender (as far as an application
* is concerned).
*
* This contract is only required for intermediate, library-like contracts.
*/
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
function _msgData() internal view virtual returns (bytes calldata) {
return msg.data;
}
}{
"optimizer": {
"enabled": true,
"runs": 1
},
"outputSelection": {
"*": {
"*": [
"evm.bytecode",
"evm.deployedBytecode",
"devdoc",
"userdoc",
"metadata",
"abi"
]
}
},
"libraries": {}
}Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
Contract ABI
API[{"inputs":[{"internalType":"contract IPublicMintable","name":"_parent","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"RefundForwarded","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"RefundReceived","type":"event"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"n","type":"uint256"}],"name":"publicMint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]Contract Creation Code
60a060405234801561001057600080fd5b5060405161060438038061060483398101604081905261002f91610099565b61003833610049565b6001600160a01b03166080526100c9565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6000602082840312156100ab57600080fd5b81516001600160a01b03811681146100c257600080fd5b9392505050565b6080516105206100e4600039600061011401526105206000f3fe6080604052600436106100435760003560e01c80632db1154414610082578063715018a6146100975780638da5cb5b146100ac578063f2fde38b146100dd57600080fd5b3661007d576040513481527f5f9145ef1ebbf201190a609438526a6db7cdbd1c7a06a90825b66f8dfe65c2fb9060200160405180910390a1005b600080fd5b61009561009036600461043d565b6100fd565b005b3480156100a357600080fd5b506100956101df565b3480156100b857600080fd5b506100c1610223565b6040516001600160a01b03909116815260200160405180910390f35b3480156100e957600080fd5b506100956100f8366004610456565b610232565b604051639f93f77960e01b81526001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001690639f93f77990349061014d9033908690600401610486565b6000604051808303818588803b15801561016657600080fd5b505af115801561017a573d6000803e3d6000fd5b5047935050821591506101cd90505761019333826102d2565b7f5753b66e6d7ce364d00a2e45e98be9ff05596c8122900d45894ea0ee21f3580533826040516101c4929190610486565b60405180910390a15b47156101db576101db61049f565b5050565b336101e8610223565b6001600160a01b0316146102175760405162461bcd60e51b815260040161020e906104b5565b60405180910390fd5b61022160006103ed565b565b6000546001600160a01b031690565b3361023b610223565b6001600160a01b0316146102615760405162461bcd60e51b815260040161020e906104b5565b6001600160a01b0381166102c65760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161020e565b6102cf816103ed565b50565b804710156103225760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e6365000000604482015260640161020e565b6000826001600160a01b03168260405160006040518083038185875af1925050503d806000811461036f576040519150601f19603f3d011682016040523d82523d6000602084013e610374565b606091505b50509050806103e85760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c20726044820152791958da5c1a595b9d081b585e481a185d99481c995d995c9d195960321b606482015260840161020e565b505050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006020828403121561044f57600080fd5b5035919050565b60006020828403121561046857600080fd5b81356001600160a01b038116811461047f57600080fd5b9392505050565b6001600160a01b03929092168252602082015260400190565b634e487b7160e01b600052600160045260246000fd5b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260408201526060019056fea2646970667358221220f64aa4fadcdecbdfe4899f3d5e0aee2b19b603b41bc1d7cd41b0cad53727b6f664736f6c634300080d0033000000000000000000000000a04c6bd65e4352b30dcc6b0f21cf58adecc52781
Deployed Bytecode
0x6080604052600436106100435760003560e01c80632db1154414610082578063715018a6146100975780638da5cb5b146100ac578063f2fde38b146100dd57600080fd5b3661007d576040513481527f5f9145ef1ebbf201190a609438526a6db7cdbd1c7a06a90825b66f8dfe65c2fb9060200160405180910390a1005b600080fd5b61009561009036600461043d565b6100fd565b005b3480156100a357600080fd5b506100956101df565b3480156100b857600080fd5b506100c1610223565b6040516001600160a01b03909116815260200160405180910390f35b3480156100e957600080fd5b506100956100f8366004610456565b610232565b604051639f93f77960e01b81526001600160a01b037f000000000000000000000000a04c6bd65e4352b30dcc6b0f21cf58adecc527811690639f93f77990349061014d9033908690600401610486565b6000604051808303818588803b15801561016657600080fd5b505af115801561017a573d6000803e3d6000fd5b5047935050821591506101cd90505761019333826102d2565b7f5753b66e6d7ce364d00a2e45e98be9ff05596c8122900d45894ea0ee21f3580533826040516101c4929190610486565b60405180910390a15b47156101db576101db61049f565b5050565b336101e8610223565b6001600160a01b0316146102175760405162461bcd60e51b815260040161020e906104b5565b60405180910390fd5b61022160006103ed565b565b6000546001600160a01b031690565b3361023b610223565b6001600160a01b0316146102615760405162461bcd60e51b815260040161020e906104b5565b6001600160a01b0381166102c65760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161020e565b6102cf816103ed565b50565b804710156103225760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e6365000000604482015260640161020e565b6000826001600160a01b03168260405160006040518083038185875af1925050503d806000811461036f576040519150601f19603f3d011682016040523d82523d6000602084013e610374565b606091505b50509050806103e85760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c20726044820152791958da5c1a595b9d081b585e481a185d99481c995d995c9d195960321b606482015260840161020e565b505050565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006020828403121561044f57600080fd5b5035919050565b60006020828403121561046857600080fd5b81356001600160a01b038116811461047f57600080fd5b9392505050565b6001600160a01b03929092168252602082015260400190565b634e487b7160e01b600052600160045260246000fd5b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260408201526060019056fea2646970667358221220f64aa4fadcdecbdfe4899f3d5e0aee2b19b603b41bc1d7cd41b0cad53727b6f664736f6c634300080d0033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
000000000000000000000000a04c6bd65e4352b30dcc6b0f21cf58adecc52781
-----Decoded View---------------
Arg [0] : _parent (address): 0xA04C6BD65E4352B30DCc6B0f21CF58aDEcc52781
-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 000000000000000000000000a04c6bd65e4352b30dcc6b0f21cf58adecc52781
Loading...
Loading
Loading...
Loading
Net Worth in USD
$0.00
Net Worth in ETH
0
Multichain Portfolio | 33 Chains
| Chain | Token | Portfolio % | Price | Amount | Value |
|---|
Loading...
Loading
Loading...
Loading
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.