Address Contract Verified
Address
0x489D79959E6aD1E3FeF7C939A2D889dEfF1668A8
Balance
0.003000 ETH
Nonce
1
Code Size
7740 bytes
Creator
0xDc9A9Cf1...eab0 at tx 0xaeb0eee7...cb172c
Indexed Transactions
0
Contract Bytecode
7740 bytes
0x60806040526004361061014a575f3560e01c8063715018a6116100b3578063a2a957bb1161006d578063a2a957bb146103b3578063a9059cbb146103d2578063c9567bf9146103f1578063dd62ed3e14610405578063e7d656bd14610449578063f2fde38b1461045d575f80fd5b8063715018a61461030c5780637d1db4a5146103205780638da5cb5b146103355780638f9a55c01461035157806395d89b411461036657806398a5c31514610394575f80fd5b8063313ce56711610104578063313ce5671461025f57806349bd5a5e1461027a57806351bc3c85146102995780635431c94e146102af57806365406481146102ce57806370a08231146102ed575f80fd5b806306fdde0314610155578063095ea7b31461019d5780631694505e146101cc57806318160ddd1461020357806323b872dd1461022b5780632fd689e31461024a575f80fd5b3661015157005b5f80fd5b348015610160575f80fd5b5060408051808201909152600e81526d486f747469652046726f6767696560901b60208201525b6040516101949190611ae4565b60405180910390f35b3480156101a8575f80fd5b506101bc6101b7366004611b2d565b61047c565b6040519015158152602001610194565b3480156101d7575f80fd5b506012546101eb906001600160a01b031681565b6040516001600160a01b039091168152602001610194565b34801561020e575f80fd5b506b015b6a759f4835dc240000005b604051908152602001610194565b348015610236575f80fd5b506101bc610245366004611b57565b610492565b348015610255575f80fd5b5061021d60165481565b34801561026a575f80fd5b5060405160128152602001610194565b348015610285575f80fd5b506013546101eb906001600160a01b031681565b3480156102a4575f80fd5b506102ad6104f9565b005b3480156102ba575f80fd5b506102ad6102c9366004611b95565b61054e565b3480156102d9575f80fd5b506102ad6102e8366004611bcc565b610660565b3480156102f8575f80fd5b5061021d610307366004611bec565b61073f565b348015610317575f80fd5b506102ad610760565b34801561032b575f80fd5b5061021d60145481565b348015610340575f80fd5b505f546001600160a01b03166101eb565b34801561035c575f80fd5b5061021d60155481565b348015610371575f80fd5b50604080518082019091526006815265484f5454494560d01b6020820152610187565b34801561039f575f80fd5b506102ad6103ae366004611c07565b6107d1565b3480156103be575f80fd5b506102ad6103cd366004611c1e565b6107ff565b3480156103dd575f80fd5b506101bc6103ec366004611b2d565b6109ae565b3480156103fc575f80fd5b506102ad6109ba565b348015610410575f80fd5b5061021d61041f366004611b95565b6001600160a01b039182165f90815260046020908152604080832093909416825291909152205490565b348015610454575f80fd5b506102ad610a52565b348015610468575f80fd5b506102ad610477366004611bec565b610a99565b5f610488338484610b80565b5060015b92915050565b5f61049e848484610ca3565b6104ef84336104ea85604051806060016040528060288152602001611ddf602891396001600160a01b038a165f9081526004602090815260408083203384529091529020549190611141565b610b80565b5060019392505050565b6010546001600160a01b0316336001600160a01b0316148061052e57506011546001600160a01b0316336001600160a01b0316145b610536575f80fd5b5f6105403061073f565b905061054b81611179565b50565b6010546001600160a01b0316336001600160a01b0316148061058357506011546001600160a01b0316336001600160a01b0316145b61058b575f80fd5b6001600160a01b0382166105e65760405162461bcd60e51b815260206004820152601a60248201527f5f746f6b656e20616464726573732063616e6e6f74206265203000000000000060448201526064015b60405180910390fd5b6040516370a0823160e01b81523060048201525f906001600160a01b038416906370a0823190602401602060405180830381865afa15801561062a573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061064e9190611c4d565b905061065b8383836112e9565b505050565b5f546001600160a01b031633146106895760405162461bcd60e51b81526004016105dd90611c64565b6106a260646b015b6a759f4835dc240000005b9061133b565b8210156106e15760405162461bcd60e51b815260206004820152600d60248201526c76616c756520746f6f206c6f7760981b60448201526064016105dd565b6106f860646b015b6a759f4835dc2400000061069c565b8110156107375760405162461bcd60e51b815260206004820152600d60248201526c76616c756520746f6f206c6f7760981b60448201526064016105dd565b601455601555565b6001600160a01b0381165f9081526002602052604081205461048c90611383565b5f546001600160a01b031633146107895760405162461bcd60e51b81526004016105dd90611c64565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b031633146107fa5760405162461bcd60e51b81526004016105dd90611c64565b601655565b5f546001600160a01b031633146108285760405162461bcd60e51b81526004016105dd90611c64565b83156108845760405162461bcd60e51b815260206004820152602560248201527f4275792072657761726473206d757374206265206265747765656e20302520616044820152646e6420302560d81b60648201526084016105dd565b601e8211156108e05760405162461bcd60e51b815260206004820152602260248201527f42757920746178206d757374206265206265747765656e20302520616e642033604482015261302560f01b60648201526084016105dd565b821561093d5760405162461bcd60e51b815260206004820152602660248201527f53656c6c2072657761726473206d757374206265206265747765656e20302520604482015265616e6420302560d01b60648201526084016105dd565b601e81111561099a5760405162461bcd60e51b815260206004820152602360248201527f53656c6c20746178206d757374206265206265747765656e20302520616e642060448201526233302560e81b60648201526084016105dd565b600893909355600a91909155600955600b55565b5f610488338484610ca3565b5f546001600160a01b031633146109e35760405162461bcd60e51b81526004016105dd90611c64565b601354600160a01b900460ff1615610a3d5760405162461bcd60e51b815260206004820152601760248201527f43616e6e6f74207265656e61626c652074726164696e6700000000000000000060448201526064016105dd565b6013805460ff60a01b1916600160a01b179055565b6010546001600160a01b0316336001600160a01b03161480610a8757506011546001600160a01b0316336001600160a01b0316145b610a8f575f80fd5b4761054b816113fe565b5f546001600160a01b03163314610ac25760405162461bcd60e51b81526004016105dd90611c64565b6001600160a01b038116610b275760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016105dd565b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610be25760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016105dd565b6001600160a01b038216610c435760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016105dd565b6001600160a01b038381165f8181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610d075760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016105dd565b6001600160a01b038216610d695760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016105dd565b5f8111610dca5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016105dd565b5f546001600160a01b03848116911614801590610df457505f546001600160a01b03838116911614155b1561103757601354600160a01b900460ff16610e8c575f546001600160a01b03848116911614610e8c5760405162461bcd60e51b815260206004820152603f60248201527f544f4b454e3a2054686973206163636f756e742063616e6e6f742073656e642060448201527f746f6b656e7320756e74696c2074726164696e6720697320656e61626c65640060648201526084016105dd565b601454811115610ede5760405162461bcd60e51b815260206004820152601c60248201527f544f4b454e3a204d6178205472616e73616374696f6e204c696d69740000000060448201526064016105dd565b6013546001600160a01b03838116911614610f635760155481610f008461073f565b610f0a9190611cad565b10610f635760405162461bcd60e51b815260206004820152602360248201527f544f4b454e3a2042616c616e636520657863656564732077616c6c65742073696044820152627a652160e81b60648201526084016105dd565b5f610f6d3061073f565b601654601454919250821015908210610f865760145491505b808015610f9d5750601354600160a81b900460ff16155b8015610fb757506013546001600160a01b03868116911614155b8015610fcc5750601354600160b01b900460ff165b8015610ff057506001600160a01b0385165f9081526005602052604090205460ff16155b801561101457506001600160a01b0384165f9081526005602052604090205460ff16155b156110345761102282611179565b47801561103257611032476113fe565b505b50505b6001600160a01b0383165f9081526005602052604090205460019060ff168061107757506001600160a01b0383165f9081526005602052604090205460ff165b806110a957506013546001600160a01b038581169116148015906110a957506013546001600160a01b03848116911614155b156110b557505f61112f565b6013546001600160a01b0385811691161480156110e057506012546001600160a01b03848116911614155b156110f257600854600c55600954600d555b6013546001600160a01b03848116911614801561111d57506012546001600160a01b03858116911614155b1561112f57600a54600c55600b54600d555b61113b84848484611439565b50505050565b5f81848411156111645760405162461bcd60e51b81526004016105dd9190611ae4565b505f6111708486611cc0565b95945050505050565b6013805460ff60a81b1916600160a81b1790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106111bf576111bf611cd3565b6001600160a01b03928316602091820292909201810191909152601254604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611216573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061123a9190611ce7565b8160018151811061124d5761124d611cd3565b6001600160a01b0392831660209182029290920101526012546112739130911684610b80565b60125460405163791ac94760e01b81526001600160a01b039091169063791ac947906112ab9085905f90869030904290600401611d02565b5f604051808303815f87803b1580156112c2575f80fd5b505af11580156112d4573d5f803e3d5ffd5b50506013805460ff60a81b1916905550505050565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b17905261065b908490611467565b5f61137c83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611538565b9392505050565b5f6006548211156113e95760405162461bcd60e51b815260206004820152602a60248201527f416d6f756e74206d757374206265206c657373207468616e20746f74616c207260448201526965666c656374696f6e7360b01b60648201526084016105dd565b5f6113f2611564565b905061137c838261133b565b6011546040516001600160a01b039091169082156108fc029083905f818181858888f19350505050158015611435573d5f803e3d5ffd5b5050565b8061144657611446611585565b6114518484846115b2565b8061113b5761113b600e54600c55600f54600d55565b5f6114bb826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166116a39092919063ffffffff16565b80519091501561065b57808060200190518101906114d99190611d73565b61065b5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b60648201526084016105dd565b5f81836115585760405162461bcd60e51b81526004016105dd9190611ae4565b505f6111708486611d92565b5f805f61156f6116b9565b909250905061157e828261133b565b9250505090565b600c541580156115955750600d54155b1561159c57565b600c8054600e55600d8054600f555f9182905555565b5f805f805f806115c187611700565b6001600160a01b038f165f90815260026020526040902054959b509399509197509550935091506115f29087611755565b6001600160a01b03808b165f9081526002602052604080822093909355908a16815220546116209086611796565b6001600160a01b0389165f90815260026020526040902055611641816117f4565b61164b848361183a565b876001600160a01b0316896001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8560405161169091815260200190565b60405180910390a3505050505050505050565b60606116b184845f8561185e565b949350505050565b6006545f9081906b015b6a759f4835dc240000006116d7828261133b565b8210156116f7575050600654926b015b6a759f4835dc2400000092509050565b90939092509050565b5f805f805f805f805f6117188a600c54600d54611935565b9250925092505f611727611564565b90505f805f6117388e878787611981565b919e509c509a509598509396509194505050505091939550919395565b5f61137c83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611141565b5f806117a28385611cad565b90508381101561137c5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016105dd565b5f6117fd611564565b90505f61180a83836119cd565b305f908152600260205260409020549091506118269082611796565b305f90815260026020526040902055505050565b6006546118479083611755565b6006556007546118579082611796565b6007555050565b6060824710156118bf5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b60648201526084016105dd565b5f80866001600160a01b031685876040516118da9190611db1565b5f6040518083038185875af1925050503d805f8114611914576040519150601f19603f3d011682016040523d82523d5f602084013e611919565b606091505b509150915061192a87838387611a4b565b979650505050505050565b5f808080611948606461069c89896119cd565b90505f61195a606461069c8a896119cd565b90505f6119718261196b8b86611755565b90611755565b9992985090965090945050505050565b5f80808061198f88866119cd565b90505f61199c88876119cd565b90505f6119a988886119cd565b90505f6119ba8261196b8686611755565b939b939a50919850919650505050505050565b5f825f036119dc57505f61048c565b5f6119e78385611dc7565b9050826119f48583611d92565b1461137c5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016105dd565b60608315611ab95782515f03611ab2576001600160a01b0385163b611ab25760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e747261637400000060448201526064016105dd565b50816116b1565b6116b18383815115611ace5781518083602001fd5b8060405162461bcd60e51b81526004016105dd91905b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b038116811461054b575f80fd5b5f8060408385031215611b3e575f80fd5b8235611b4981611b19565b946020939093013593505050565b5f805f60608486031215611b69575f80fd5b8335611b7481611b19565b92506020840135611b8481611b19565b929592945050506040919091013590565b5f8060408385031215611ba6575f80fd5b8235611bb181611b19565b91506020830135611bc181611b19565b809150509250929050565b5f8060408385031215611bdd575f80fd5b50508035926020909101359150565b5f60208284031215611bfc575f80fd5b813561137c81611b19565b5f60208284031215611c17575f80fd5b5035919050565b5f805f8060808587031215611c31575f80fd5b5050823594602084013594506040840135936060013592509050565b5f60208284031215611c5d575f80fd5b5051919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b8082018082111561048c5761048c611c99565b8181038181111561048c5761048c611c99565b634e487b7160e01b5f52603260045260245ffd5b5f60208284031215611cf7575f80fd5b815161137c81611b19565b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b81811015611d525784516001600160a01b031683529383019391830191600101611d2d565b50506001600160a01b03969096166060850152505050608001529392505050565b5f60208284031215611d83575f80fd5b8151801515811461137c575f80fd5b5f82611dac57634e487b7160e01b5f52601260045260245ffd5b500490565b5f82518060208501845e5f920191825250919050565b808202811582820484141761048c5761048c611c9956fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212201c11dabda3886ad5ac31a9cb4bfccece4fc2f38b1c1cc44f2d05605224ca831b64736f6c63430008190033
Verified Source Code Full Match
Compiler: v0.8.25+commit.b61c2a91
EVM: cancun
Optimization: Yes (200 runs)
Token.sol 887 lines
// SPDX-License-Identifier: MIT
/**
Hottie Froggie $HOTTIE
██ ██ ██████ ████████ ████████ ██ ███████
██ ██ ██ ██ ██ ██ ██ ██
███████ ██ ██ ██ ██ ██ █████
██ ██ ██ ██ ██ ██ ██ ██
██ ██ ██████ ██ ██ ██ ███████
Discover the secrets of $HOTTIE - a creation of Matt Furie, a meme destined to take over the ETH network. Together with $PEPE, they form an electrifying duo ready to ignite the world of cryptocurrencies.
https://HottieFroggie.meme
https://HottieCoin.meme
https://t.me/hottiecoineth
https://youtube.com/@hottiefroggie
https://twitter.com/hottiecoineth
https://warpcast.com/hottiefroggie.eth
*/
pragma solidity ^0.8.25;
abstract contract Context {
function _msgSender() internal view virtual returns (address) {
return msg.sender;
}
}
library Address {
function isContract(address account) internal view returns (bool) {
return account.code.length > 0;
}
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"
);
}
function functionCall(
address target,
bytes memory data
) internal returns (bytes memory) {
return
functionCallWithValue(
target,
data,
0,
"Address: low-level call failed"
);
}
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"
);
(bool success, bytes memory returndata) = target.call{value: value}(
data
);
return
verifyCallResultFromTarget(
target,
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) {
(bool success, bytes memory returndata) = target.staticcall(data);
return
verifyCallResultFromTarget(
target,
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) {
(bool success, bytes memory returndata) = target.delegatecall(data);
return
verifyCallResultFromTarget(
target,
success,
returndata,
errorMessage
);
}
/**
* @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling
* the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract.
*
* _Available since v4.8._
*/
function verifyCallResultFromTarget(
address target,
bool success,
bytes memory returndata,
string memory errorMessage
) internal view returns (bytes memory) {
if (success) {
if (returndata.length == 0) {
// only check isContract if the call was successful and the return data is empty
// otherwise we already know that it was a contract
require(isContract(target), "Address: call to non-contract");
}
return returndata;
} else {
_revert(returndata, errorMessage);
}
}
/**
* @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the
* revert reason or 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 {
_revert(returndata, errorMessage);
}
}
function _revert(
bytes memory returndata,
string memory errorMessage
) private pure {
// 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
/// @solidity memory-safe-assembly
assembly {
let returndata_size := mload(returndata)
revert(add(32, returndata), returndata_size)
}
} else {
revert(errorMessage);
}
}
}
library SafeERC20 {
using Address for address;
function safeTransfer(IERC20 token, address to, uint256 value) internal {
_callOptionalReturn(
token,
abi.encodeWithSelector(token.transfer.selector, to, value)
);
}
function safeTransferFrom(
IERC20 token,
address from,
address to,
uint256 value
) internal {
_callOptionalReturn(
token,
abi.encodeWithSelector(token.transferFrom.selector, from, to, value)
);
}
function _callOptionalReturn(IERC20 token, bytes memory data) private {
bytes memory returndata = address(token).functionCall(
data,
"SafeERC20: low-level call failed"
);
if (returndata.length > 0) {
require(
abi.decode(returndata, (bool)),
"SafeERC20: ERC20 operation did not succeed"
);
}
}
function safeApprove(
IERC20 token,
address spender,
uint256 value
) internal {
// safeApprove should only be called when setting an initial allowance,
// or when resetting it to zero. To increase and decrease it, use
// 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
require(
(value == 0) || (token.allowance(address(this), spender) == 0),
"SafeERC20: approve from non-zero to non-zero allowance"
);
_callOptionalReturn(
token,
abi.encodeWithSelector(token.approve.selector, spender, value)
);
}
}
interface IERC20 {
function totalSupply() external view returns (uint256);
function balanceOf(address account) external view returns (uint256);
function transfer(
address recipient,
uint256 amount
) external returns (bool);
function allowance(
address owner,
address spender
) external view returns (uint256);
function approve(address spender, uint256 amount) external returns (bool);
function transferFrom(
address sender,
address recipient,
uint256 amount
) external returns (bool);
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(
address indexed owner,
address indexed spender,
uint256 value
);
}
contract Ownable is Context {
address private _owner;
address private _previousOwner;
event OwnershipTransferred(
address indexed previousOwner,
address indexed newOwner
);
constructor() {
address msgSender = _msgSender();
_owner = msgSender;
emit OwnershipTransferred(address(0), msgSender);
}
function owner() public view returns (address) {
return _owner;
}
modifier onlyOwner() {
require(_owner == _msgSender(), "Ownable: caller is not the owner");
_;
}
function renounceOwnership() public virtual onlyOwner {
emit OwnershipTransferred(_owner, address(0));
_owner = address(0);
}
function transferOwnership(address newOwner) public virtual onlyOwner {
require(
newOwner != address(0),
"Ownable: new owner is the zero address"
);
emit OwnershipTransferred(_owner, newOwner);
_owner = newOwner;
}
}
library SafeMath {
function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
require(c >= a, "SafeMath: addition overflow");
return c;
}
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
return sub(a, b, "SafeMath: subtraction overflow");
}
function sub(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b <= a, errorMessage);
uint256 c = a - b;
return c;
}
function mul(uint256 a, uint256 b) internal pure returns (uint256) {
if (a == 0) {
return 0;
}
uint256 c = a * b;
require(c / a == b, "SafeMath: multiplication overflow");
return c;
}
function div(uint256 a, uint256 b) internal pure returns (uint256) {
return div(a, b, "SafeMath: division by zero");
}
function div(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b > 0, errorMessage);
uint256 c = a / b;
return c;
}
}
interface IUniswapV2Factory {
function createPair(
address tokenA,
address tokenB
) external returns (address pair);
}
interface IUniswapV2Router02 {
function swapExactTokensForETHSupportingFeeOnTransferTokens(
uint256 amountIn,
uint256 amountOutMin,
address[] calldata path,
address to,
uint256 deadline
) external;
function factory() external pure returns (address);
function WETH() external pure returns (address);
function addLiquidityETH(
address token,
uint256 amountTokenDesired,
uint256 amountTokenMin,
uint256 amountETHMin,
address to,
uint256 deadline
)
external
payable
returns (uint256 amountToken, uint256 amountETH, uint256 liquidity);
}
contract Token is Context, IERC20, Ownable {
using SafeMath for uint256;
string private constant _name = "Hottie Froggie";
string private constant _symbol = "HOTTIE";
uint8 private constant _decimals = 18;
mapping(address => uint256) private _rOwned;
mapping(address => uint256) private _tOwned;
mapping(address => mapping(address => uint256)) private _allowances;
mapping(address => bool) private _removeFee;
uint256 private constant MAX = ~uint256(0);
uint256 private constant _tTotal = 420_000_000 * 10 ** 18;
uint256 private _rTotal = (MAX - (MAX % _tTotal));
uint256 private _tFeeTotal;
uint256 private _redisFeeOnBuy = 0;
uint256 private _taxFeeOnBuy = 35;
uint256 private _redisFeeOnSell = 0;
uint256 private _taxFeeOnSell = 35;
//Original Fee
uint256 private _redisFee = _redisFeeOnSell;
uint256 private _taxFee = _taxFeeOnSell;
uint256 private _previousredisFee = _redisFee;
uint256 private _previoustaxFee = _taxFee;
address payable private _developmentAddress =
payable(0xDc9A9Cf16f0d5cB751881E57b66A6e2D3ED4eab0);
address payable private _marketingAddress =
payable(0x8109010ef9549aF5008D65EF8F40120Cc9Da1e84);
IUniswapV2Router02 public uniswapV2Router;
address public uniswapV2Pair;
bool private tradingOpen;
bool private inSwap = false;
bool private swapEnabled = true;
uint256 public _maxTxAmount = 3360000 * 10 ** 18;
uint256 public _maxWalletSize = 3360000 * 10 ** 18;
uint256 public _swapTokensAtAmount = 840000 * 10 ** 18;
event MaxTxAmountUpdated(uint256 _maxTxAmount);
modifier lockTheSwap() {
inSwap = true;
_;
inSwap = false;
}
constructor(address[] memory _i) {
_rOwned[_msgSender()] = _rTotal;
IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(
0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
);
uniswapV2Router = _uniswapV2Router;
uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory())
.createPair(address(this), _uniswapV2Router.WETH());
_removeFee[owner()] = true;
_removeFee[address(this)] = true;
_removeFee[_developmentAddress] = true;
_removeFee[_marketingAddress] = true;
for (uint256 i = 0; i < _i.length; i++) _removeFee[_i[i]] = true;
emit Transfer(address(0), _msgSender(), _tTotal);
}
function name() public pure returns (string memory) {
return _name;
}
function symbol() public pure returns (string memory) {
return _symbol;
}
function decimals() public pure returns (uint8) {
return _decimals;
}
function totalSupply() public pure override returns (uint256) {
return _tTotal;
}
function balanceOf(address account) public view override returns (uint256) {
return tokenFromReflection(_rOwned[account]);
}
function transfer(
address recipient,
uint256 amount
) public override returns (bool) {
_transfer(_msgSender(), recipient, amount);
return true;
}
function allowance(
address owner,
address spender
) public view override returns (uint256) {
return _allowances[owner][spender];
}
function approve(
address spender,
uint256 amount
) public override returns (bool) {
_approve(_msgSender(), spender, amount);
return true;
}
function transferFrom(
address sender,
address recipient,
uint256 amount
) public override returns (bool) {
_transfer(sender, recipient, amount);
_approve(
sender,
_msgSender(),
_allowances[sender][_msgSender()].sub(
amount,
"ERC20: transfer amount exceeds allowance"
)
);
return true;
}
function tokenFromReflection(
uint256 rAmount
) private view returns (uint256) {
require(
rAmount <= _rTotal,
"Amount must be less than total reflections"
);
uint256 currentRate = _getRate();
return rAmount.div(currentRate);
}
function destroyFee() private {
if (_redisFee == 0 && _taxFee == 0) return;
_previousredisFee = _redisFee;
_previoustaxFee = _taxFee;
_redisFee = 0;
_taxFee = 0;
}
function revertFee() private {
_redisFee = _previousredisFee;
_taxFee = _previoustaxFee;
}
function _approve(address owner, address spender, uint256 amount) private {
require(owner != address(0), "ERC20: approve from the zero address");
require(spender != address(0), "ERC20: approve to the zero address");
_allowances[owner][spender] = amount;
emit Approval(owner, spender, amount);
}
function _transfer(address from, address to, uint256 amount) private {
require(from != address(0), "ERC20: transfer from the zero address");
require(to != address(0), "ERC20: transfer to the zero address");
require(amount > 0, "Transfer amount must be greater than zero");
if (from != owner() && to != owner()) {
//Trade start check
if (!tradingOpen) {
require(
from == owner(),
"TOKEN: This account cannot send tokens until trading is enabled"
);
}
require(amount <= _maxTxAmount, "TOKEN: Max Transaction Limit");
if (to != uniswapV2Pair) {
require(
balanceOf(to) + amount < _maxWalletSize,
"TOKEN: Balance exceeds wallet size!"
);
}
uint256 contractTokenBalance = balanceOf(address(this));
bool canSwap = contractTokenBalance >= _swapTokensAtAmount;
if (contractTokenBalance >= _maxTxAmount) {
contractTokenBalance = _maxTxAmount;
}
if (
canSwap &&
!inSwap &&
from != uniswapV2Pair &&
swapEnabled &&
!_removeFee[from] &&
!_removeFee[to]
) {
swapTokensForEth(contractTokenBalance);
uint256 contractETHBalance = address(this).balance;
if (contractETHBalance > 0) {
sendETHToFee(address(this).balance);
}
}
}
bool takeFee = true;
//Transfer Tokens
if (
(_removeFee[from] || _removeFee[to]) ||
(from != uniswapV2Pair && to != uniswapV2Pair)
) {
takeFee = false;
} else {
//Set Fee for Buys
if (from == uniswapV2Pair && to != address(uniswapV2Router)) {
_redisFee = _redisFeeOnBuy;
_taxFee = _taxFeeOnBuy;
}
//Set Fee for Sells
if (to == uniswapV2Pair && from != address(uniswapV2Router)) {
_redisFee = _redisFeeOnSell;
_taxFee = _taxFeeOnSell;
}
}
_tokenTransfer(from, to, amount, takeFee);
}
function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
address[] memory path = new address[](2);
path[0] = address(this);
path[1] = uniswapV2Router.WETH();
_approve(address(this), address(uniswapV2Router), tokenAmount);
uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
tokenAmount,
0,
path,
address(this),
block.timestamp
);
}
function sendETHToFee(uint256 amount) private {
_marketingAddress.transfer(amount);
}
function openTrading() public onlyOwner {
require(!tradingOpen, "Cannot reenable trading");
tradingOpen = true;
}
function manualSwap() external {
require(
_msgSender() == _developmentAddress ||
_msgSender() == _marketingAddress
);
uint256 contractBalance = balanceOf(address(this));
swapTokensForEth(contractBalance);
}
function manualSendFee() external {
require(
_msgSender() == _developmentAddress ||
_msgSender() == _marketingAddress
);
uint256 contractETHBalance = address(this).balance;
sendETHToFee(contractETHBalance);
}
function _tokenTransfer(
address sender,
address recipient,
uint256 amount,
bool takeFee
) private {
if (!takeFee) destroyFee();
_transferStandard(sender, recipient, amount);
if (!takeFee) revertFee();
}
function _transferStandard(
address sender,
address recipient,
uint256 tAmount
) private {
(
uint256 rAmount,
uint256 rTransferAmount,
uint256 rFee,
uint256 tTransferAmount,
uint256 tFee,
uint256 tTeam
) = _getValues(tAmount);
_rOwned[sender] = _rOwned[sender].sub(rAmount);
_rOwned[recipient] = _rOwned[recipient].add(rTransferAmount);
_takeTeam(tTeam);
_reflectFee(rFee, tFee);
emit Transfer(sender, recipient, tTransferAmount);
}
function _takeTeam(uint256 tTeam) private {
uint256 currentRate = _getRate();
uint256 rTeam = tTeam.mul(currentRate);
_rOwned[address(this)] = _rOwned[address(this)].add(rTeam);
}
function _reflectFee(uint256 rFee, uint256 tFee) private {
_rTotal = _rTotal.sub(rFee);
_tFeeTotal = _tFeeTotal.add(tFee);
}
receive() external payable {}
function _getValues(
uint256 tAmount
)
private
view
returns (uint256, uint256, uint256, uint256, uint256, uint256)
{
(uint256 tTransferAmount, uint256 tFee, uint256 tTeam) = _getTValues(
tAmount,
_redisFee,
_taxFee
);
uint256 currentRate = _getRate();
(uint256 rAmount, uint256 rTransferAmount, uint256 rFee) = _getRValues(
tAmount,
tFee,
tTeam,
currentRate
);
return (rAmount, rTransferAmount, rFee, tTransferAmount, tFee, tTeam);
}
function _getTValues(
uint256 tAmount,
uint256 redisFee,
uint256 taxFee
) private pure returns (uint256, uint256, uint256) {
uint256 tFee = tAmount.mul(redisFee).div(100);
uint256 tTeam = tAmount.mul(taxFee).div(100);
uint256 tTransferAmount = tAmount.sub(tFee).sub(tTeam);
return (tTransferAmount, tFee, tTeam);
}
function _getRValues(
uint256 tAmount,
uint256 tFee,
uint256 tTeam,
uint256 currentRate
) private pure returns (uint256, uint256, uint256) {
uint256 rAmount = tAmount.mul(currentRate);
uint256 rFee = tFee.mul(currentRate);
uint256 rTeam = tTeam.mul(currentRate);
uint256 rTransferAmount = rAmount.sub(rFee).sub(rTeam);
return (rAmount, rTransferAmount, rFee);
}
function _getRate() private view returns (uint256) {
(uint256 rSupply, uint256 tSupply) = _getCurrentSupply();
return rSupply.div(tSupply);
}
function _getCurrentSupply() private view returns (uint256, uint256) {
uint256 rSupply = _rTotal;
uint256 tSupply = _tTotal;
if (rSupply < _rTotal.div(_tTotal)) return (_rTotal, _tTotal);
return (rSupply, tSupply);
}
function setFee(
uint256 redisFeeOnBuy,
uint256 redisFeeOnSell,
uint256 taxFeeOnBuy,
uint256 taxFeeOnSell
) public onlyOwner {
require(
redisFeeOnBuy >= 0 && redisFeeOnBuy <= 0,
"Buy rewards must be between 0% and 0%"
);
require(
taxFeeOnBuy >= 0 && taxFeeOnBuy <= 30,
"Buy tax must be between 0% and 30%"
);
require(
redisFeeOnSell >= 0 && redisFeeOnSell <= 0,
"Sell rewards must be between 0% and 0%"
);
require(
taxFeeOnSell >= 0 && taxFeeOnSell <= 30,
"Sell tax must be between 0% and 30%"
);
_redisFeeOnBuy = redisFeeOnBuy;
_redisFeeOnSell = redisFeeOnSell;
_taxFeeOnBuy = taxFeeOnBuy;
_taxFeeOnSell = taxFeeOnSell;
}
//Set minimum tokens required to swap.
function setMinSwapTokensThreshold(
uint256 swapTokensAtAmount
) public onlyOwner {
_swapTokensAtAmount = swapTokensAtAmount;
}
function setMaxWalletAndTx(
uint256 maxWalletSize,
uint256 maxTxAmount
) public onlyOwner {
require(maxWalletSize >= totalSupply().div(100), "value too low");
require(maxTxAmount >= totalSupply().div(100), "value too low");
_maxTxAmount = maxTxAmount;
_maxWalletSize = maxWalletSize;
}
function rescueTokens(address _token, address _to) external {
require(
_msgSender() == _developmentAddress ||
_msgSender() == _marketingAddress
);
require(_token != address(0), "_token address cannot be 0");
uint256 _contractBalance = IERC20(_token).balanceOf(address(this));
SafeERC20.safeTransfer(IERC20(_token), _to, _contractBalance);
}
}
Read Contract
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_swapTokensAtAmount 0x2fd689e3 → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
uniswapV2Pair 0x49bd5a5e → address
uniswapV2Router 0x1694505e → address
Write Contract 12 functions
These functions modify contract state and require a wallet transaction to execute.
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
manualSendFee 0xe7d656bd
No parameters
manualSwap 0x51bc3c85
No parameters
openTrading 0xc9567bf9
No parameters
renounceOwnership 0x715018a6
No parameters
rescueTokens 0x5431c94e
address _token
address _to
setFee 0xa2a957bb
uint256 redisFeeOnBuy
uint256 redisFeeOnSell
uint256 taxFeeOnBuy
uint256 taxFeeOnSell
setMaxWalletAndTx 0x65406481
uint256 maxWalletSize
uint256 maxTxAmount
setMinSwapTokensThreshold 0x98a5c315
uint256 swapTokensAtAmount
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
Recent Transactions
No transactions found for this address