uups-checker 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gitmodules +6 -0
- package/AIFI_AUDIT.md +220 -0
- package/ALL_AUDITS_SUMMARY.md +366 -0
- package/ALPHA_PROXY_CRITICAL_FINDING.md +136 -0
- package/ALPHA_PROXY_FINAL_ANALYSIS.md +213 -0
- package/ALPHA_PROXY_FINAL_VERDICT.md +233 -0
- package/ALPHA_PROXY_SELFDESTRUCT_EXPLOIT.md +161 -0
- package/ARIA-foundry-test.txt +9 -0
- package/ARIA-mythril-analysis.txt +20 -0
- package/ARIA-slither-analysis.txt +38 -0
- package/ARIA_AI_SECURITY_AUDIT.md +290 -0
- package/ARIA_VERIFIED_AUDIT.md +259 -0
- package/ARIA_VERIFIED_slither.txt +76 -0
- package/ARIVA_source.txt +1 -0
- package/ARK_AUDIT.md +349 -0
- package/BANANA_AUDIT.md +365 -0
- package/BAS_AUDIT.md +451 -0
- package/BAS_TOKEN_AUDIT.md +235 -0
- package/BCE_EXPLOIT_ANALYSIS.md +165 -0
- package/BEEFY_BNB_CHAIN_ANALYSIS.md +488 -0
- package/BEEFY_MONAD_ANALYSIS.md +239 -0
- package/BEEFY_STAKING_ANALYSIS.md +136 -0
- package/BEEFY_XVS_WBNB_ACTUAL_FINDINGS.md +223 -0
- package/BEEFY_XVS_WBNB_CRITICAL_FINDINGS.md +269 -0
- package/BLOCKSEC_ATTACK_KNOWLEDGE_BASE.md +771 -0
- package/BRISE_ANALYSIS.txt +31 -0
- package/BRISE_BSC_DAPPS.txt +68 -0
- package/BRISE_EXPLOITS_FOUND.md +98 -0
- package/BRISE_REAL_EXPLOITS.md +115 -0
- package/BRISE_WHITEHAT_REPORT.md +162 -0
- package/BRISEstake_Analysis.txt +95 -0
- package/BSCSLOCKTOKEN_CRITICAL_FINDING.md +240 -0
- package/BSW_BISWAP_SECURITY_AUDIT.md +330 -0
- package/BTCST_FINAL_VERDICT.md +319 -0
- package/BTCST_MINING_REBASE_ANALYSIS.md +229 -0
- package/BTCST_ROUNDING_DEEP_DIVE.md +293 -0
- package/BTCST_ROUNDING_FINAL_VERDICT.md +9 -0
- package/BTCST_SECURITY_ANALYSIS.md +391 -0
- package/BTR_AUDIT.md +210 -0
- package/BeamBridge-analysis.md +226 -0
- package/BeamToken-analysis.md +201 -0
- package/BitgertSwap_Investigation.txt +107 -0
- package/CEEK_STAKING_ANALYSIS.md +0 -0
- package/CHAINBASE_AUDIT.md +422 -0
- package/COMPLETE_AUDIT_SUMMARY.md +342 -0
- package/CORRECTED_ANALYSIS.txt +115 -0
- package/DBXEN_COMPARISON_SUMMARY.md +232 -0
- package/DBXEN_EXPLOIT_ANALYSIS.md +530 -0
- package/DOPFairLaunch_raw.json +29 -0
- package/DOPFairLaunch_source.txt +0 -0
- package/DOP_BRIDGE_FINAL_ANALYSIS.txt +86 -0
- package/DOP_BUSD_LP_ANALYSIS.txt +44 -0
- package/DOP_FAIRLAUNCH_ANALYSIS.txt +61 -0
- package/DOP_FAIRLAUNCH_FINAL_VERDICT.txt +113 -0
- package/DOP_STAKING_CONTRACT_ANALYSIS.txt +67 -0
- package/DSYNC_ECOSYSTEM_ANALYSIS.md +221 -0
- package/DSyncStaking-exploit-analysis.md +153 -0
- package/DSyncVault-analysis.md +120 -0
- package/DUSD_PROXY_AUDIT.md +407 -0
- package/DXSALE_LOCK_AUDIT.md +0 -0
- package/DXSaleLock_bytecode.txt +1 -0
- package/ECHIDNA_QUICK_START.md +101 -0
- package/ELEPHANT_ECOSYSTEM_AUDIT_PLAN.md +159 -0
- package/ELEPHANT_ECOSYSTEM_COMPREHENSIVE_AUDIT.md +427 -0
- package/ELEPHANT_SECURITY_ANALYSIS.md +209 -0
- package/ELEPHANT_VULNERABILITIES_EXPLAINED.md +455 -0
- package/EXPLOIT_FIX.md +300 -0
- package/EXPLOIT_INSTRUCTIONS.md +273 -0
- package/EXPLOIT_SUMMARY.md +285 -0
- package/EXPLOIT_SUMMARY.txt +175 -0
- package/FALCON_FINANCE_AUDIT.md +258 -0
- package/FANDOM_AUDIT.md +359 -0
- package/FEE_ON_TRANSFER_ANALYSIS.md +228 -0
- package/FINAL_AUDIT_REPORT.md +0 -0
- package/FOLIO_PROXY_AUDIT.md +299 -0
- package/FOT_EXPLOIT_RESULTS.txt +110 -0
- package/FOT_TOKENS_AUDITED.md +103 -0
- package/HEGIC-mythril-analysis.txt +39 -0
- package/HEGIC_COMPLETE_ANALYSIS.md +343 -0
- package/HOTCROSS_SWAP_EXPLOIT_ANALYSIS.md +123 -0
- package/ICECREAMSWAP_EXPLOITS.md +259 -0
- package/IMMUNEFI_REPORT.md +314 -0
- package/KCCPAD_EXPLOIT_GUIDE.md +285 -0
- package/KEL_CEL_EXPLOIT_ANALYSIS.md +0 -0
- package/KOGE_AUDIT.md +328 -0
- package/LENDFLARE_ANALYSIS.md +239 -0
- package/LENDFLARE_ECHIDNA_GUIDE.md +356 -0
- package/LENDFLARE_EXPLOIT_INSTRUCTIONS.md +297 -0
- package/LENDFLARE_EXPLOIT_SUMMARY.md +292 -0
- package/LENDFLARE_FLASHLOAN_GUIDE.md +383 -0
- package/LENDFLARE_FUZZING_RESULTS.md +252 -0
- package/LENDFLARE_HONEYPOT_BYPASS_ANALYSIS.md +420 -0
- package/LENDFLARE_MANUAL_FUZZING.md +324 -0
- package/LENDFLARE_MYTHRIL_ANALYSIS.md +339 -0
- package/LENDFLARE_V3_BYPASS.md +296 -0
- package/LFTDECOMPILE.txt +14478 -0
- package/LFT_ACCOUNTING_ANALYSIS.md +0 -0
- package/LFT_ACCOUNTING_BUG_ANALYSIS.md +426 -0
- package/LFT_BACKDOOR_DEEP_DIVE.md +0 -0
- package/LFT_CRITICAL_EXPLOIT_CONFIRMED.md +428 -0
- package/LFT_EXPLOIT_VISUAL.md +253 -0
- package/LFT_QUICK_SUMMARY.md +124 -0
- package/LFT_REVERSE_EXPLOIT_ANALYSIS.md +521 -0
- package/MGO_AUDIT_REPORT.md +420 -0
- package/MYTHRIL_FINAL_REPORT.md +306 -0
- package/MYTHRIL_SLITHER_SUMMARY.md +244 -0
- package/NETX_MIGRATION_AUDIT.md +0 -0
- package/NPM_PUBLISH_GUIDE.md +0 -0
- package/NRV_CRITICAL_EXPLOIT.txt +143 -0
- package/NetX_Analysis.txt +76 -0
- package/NetX_Migration_bytecode.txt +1 -0
- package/NetX_Migration_source.txt +0 -0
- package/NetX_Token_source.txt +0 -0
- package/NetxWhitehatRescue +22 -0
- package/OILER_ATTACK_VISUAL.md +351 -0
- package/OILER_BLOCKSEC_TEST_RESULTS.md +421 -0
- package/OILER_DEEP_ANALYSIS.md +212 -0
- package/OILER_FINAL_EXPLOIT_REPORT.md +241 -0
- package/OILER_FINAL_VERDICT.md +339 -0
- package/OILER_REENTRANCY_EXPLAINED.md +638 -0
- package/OILER_REENTRANCY_FINAL_SUMMARY.md +391 -0
- package/OILER_REENTRANCY_REALITY_CHECK.md +393 -0
- package/OILER_REENTRANCY_STEP_BY_STEP.md +597 -0
- package/OILER_STAKING_MAINNET_ANALYSIS.md +366 -0
- package/OILER_STAKING_SECURITY_ANALYSIS.md +409 -0
- package/PANCAKESWAP_UNDERFLOW_HUNTING.md +317 -0
- package/POLS_MULTICHAIN_AUDIT.md +0 -0
- package/POSI_STAKING_AUDIT.md +0 -0
- package/PROXY2_SECURITY_ANALYSIS.md +0 -0
- package/Proxy2TACS +29748 -0
- package/QUICK_START.md +240 -0
- package/RAMP_SECURITY_ANALYSIS.md +0 -0
- package/README.md +238 -0
- package/REAUDIT_MASTER_LIST.txt +15 -0
- package/RING_analysis.txt +212 -0
- package/RPC +4 -0
- package/RULES.txt +20 -0
- package/SIREN_AUDIT.md +186 -0
- package/SYNC_EXPLOIT_README.md +0 -0
- package/SYNC_TOKEN_EXPLOIT_REPORT.md +224 -0
- package/TLM_raw.html +0 -0
- package/TLM_raw.txt +0 -0
- package/TLM_response.json +1 -0
- package/TRADOOR_AUDIT.md +253 -0
- package/TRUNK_AUDIT.md +285 -0
- package/UNIBASE_AUDIT.md +241 -0
- package/UNLOCK_ANALYSIS.md +0 -0
- package/UNLOCK_EXPLOIT.md +49 -0
- package/UNLOCK_EXPLOIT_ANALYSIS.md +0 -0
- package/UPS +232 -0
- package/UUPSCHECKER +208 -0
- package/VAULT_PROXY_AUDIT.md +457 -0
- package/VAULT_PROXY_FINAL_VERDICT.md +0 -0
- package/VERIFIED_EXPLOITS_FINAL.txt +146 -0
- package/WKEYDAO2_AUDIT.md +245 -0
- package/WSG_AUDIT.md +0 -0
- package/XFI_DEEP_ANALYSIS.md +327 -0
- package/YOOSHI_EXPLOIT_GUIDE.md +119 -0
- package/YSDAO_EXPLOIT_GUIDE.md +0 -0
- package/agent-4-bundle.md +22490 -0
- package/alpha-proxy-echidna.txt +1 -0
- package/alpha-proxy-fuzz-results.txt +81 -0
- package/alpha-proxy-mythril.txt +2 -0
- package/analyze-btcst-farm.js +54 -0
- package/analyze-dxsale-lock.js +75 -0
- package/analyze-elephant.js +69 -0
- package/analyze-fara-rewards.js +109 -0
- package/analyze-fara-storage.js +83 -0
- package/analyze-lft-transaction.js +158 -0
- package/analyze-lock-bytecode.js +59 -0
- package/analyze-shegic.js +0 -0
- package/analyze-staking-abi.js +0 -0
- package/analyze-sxp.js +57 -0
- package/analyze-tlm.js +76 -0
- package/analyze-trumpet.js +98 -0
- package/analyze-unlimited-nft.js +108 -0
- package/analyze_elephant.sh +27 -0
- package/analyze_vault.sh +32 -0
- package/aria-bytecode.txt +1 -0
- package/aria_response.json +1 -0
- package/ark_temp/README.md +66 -0
- package/ark_temp/lib/forge-std/.gitattributes +1 -0
- package/ark_temp/lib/forge-std/.github/CODEOWNERS +1 -0
- package/ark_temp/lib/forge-std/.github/dependabot.yml +6 -0
- package/ark_temp/lib/forge-std/.github/workflows/ci.yml +125 -0
- package/ark_temp/lib/forge-std/.github/workflows/sync.yml +36 -0
- package/ark_temp/lib/forge-std/CONTRIBUTING.md +193 -0
- package/ark_temp/lib/forge-std/LICENSE-APACHE +203 -0
- package/ark_temp/lib/forge-std/LICENSE-MIT +25 -0
- package/ark_temp/lib/forge-std/README.md +314 -0
- package/ark_temp/lib/forge-std/RELEASE_CHECKLIST.md +12 -0
- package/ark_temp/lib/forge-std/package.json +16 -0
- package/ark_temp/lib/forge-std/scripts/vm.py +636 -0
- package/audits/AiFi-security-audit-20260326.md +499 -0
- package/audits/BasedAI-Brains-security-audit-20260324.md +651 -0
- package/audits/BinanceAlphaWallet-pashov-ai-audit-report-20260324-170000.md +362 -0
- package/audits/DGToken-security-audit-20260324.md +376 -0
- package/audits/DSyncStaking-audit-part1.md +161 -0
- package/audits/DSyncStaking-security-audit-20260324.md +547 -0
- package/audits/DecompiledERC20-security-audit-20260325.md +397 -0
- package/audits/DegenVC-security-audit-20260324.md +585 -0
- package/audits/DelreyInu-security-audit-20260324.md +463 -0
- package/audits/DestraNetwork-security-audit-20260324.md +705 -0
- package/audits/DomiToken-security-audit-20260324.md +514 -0
- package/audits/LendFlareToken-security-audit-20260325.md +197 -0
- package/audits/LockReleaseTokenPool-security-audit-20260324.md +482 -0
- package/audits/MOG-pashov-ai-audit-report-20260324-164900.md +229 -0
- package/audits/PAALAI-security-audit-20260324.md +475 -0
- package/audits/PAR-security-audit-20260325.md +311 -0
- package/audits/PepeCoinStaking-security-audit-20260324.md +358 -0
- package/audits/StakingPool-security-audit-20260324.md +517 -0
- package/audits/SyncToken-security-audit-20260324.md +778 -0
- package/audits/UndeadToken-decompiled-security-audit-20260324.md +485 -0
- package/audits/UnknownToken-decompiled-security-audit-20260324.md +647 -0
- package/audits/XFIStaking-security-audit-20260324.md +682 -0
- package/audits/Xfinance-security-audit-20260324.md +463 -0
- package/audits/basedAIFarm-security-audit-20260324.md +330 -0
- package/audits/pepeCoin-security-audit-20260324.md +462 -0
- package/bin/ups +232 -0
- package/binance-wallet-exploit/.env.example +2 -0
- package/binance-wallet-exploit/EXECUTIVE_SUMMARY.md +272 -0
- package/binance-wallet-exploit/EXPLOIT_SUMMARY.md +104 -0
- package/binance-wallet-exploit/FINAL_ANALYSIS.md +326 -0
- package/binance-wallet-exploit/FLASHLOAN_ATTACK.md +292 -0
- package/binance-wallet-exploit/HONEYPOT_REPORT.md +526 -0
- package/binance-wallet-exploit/INVESTIGATION_COMPLETE.md +362 -0
- package/binance-wallet-exploit/LENDFLARE_EXPLOIT.md +219 -0
- package/binance-wallet-exploit/LENDFLARE_FINAL_ATTACK.md +307 -0
- package/binance-wallet-exploit/LENDFLARE_REAL_EXPLOIT.md +286 -0
- package/binance-wallet-exploit/LENDFLARE_RUGPULL.md +269 -0
- package/binance-wallet-exploit/LFT_ANALYSIS.md +206 -0
- package/binance-wallet-exploit/QUICK_START.md +75 -0
- package/binance-wallet-exploit/README.md +195 -0
- package/binance-wallet-exploit/REAL_TX_EXPLOIT_ANALYSIS.md +271 -0
- package/binance-wallet-exploit/REMIX_INSTRUCTIONS.md +223 -0
- package/binance-wallet-exploit/TEST_RESULTS.md +203 -0
- package/binance-wallet-exploit/cache/solidity-files-cache.json +1 -0
- package/binance-wallet-exploit/cache/test-failures +1 -0
- package/binance-wallet-exploit/lib/forge-std/.gitattributes +1 -0
- package/binance-wallet-exploit/lib/forge-std/.github/CODEOWNERS +1 -0
- package/binance-wallet-exploit/lib/forge-std/.github/dependabot.yml +6 -0
- package/binance-wallet-exploit/lib/forge-std/.github/workflows/ci.yml +125 -0
- package/binance-wallet-exploit/lib/forge-std/.github/workflows/sync.yml +36 -0
- package/binance-wallet-exploit/lib/forge-std/CONTRIBUTING.md +193 -0
- package/binance-wallet-exploit/lib/forge-std/LICENSE-APACHE +203 -0
- package/binance-wallet-exploit/lib/forge-std/LICENSE-MIT +25 -0
- package/binance-wallet-exploit/lib/forge-std/README.md +314 -0
- package/binance-wallet-exploit/lib/forge-std/RELEASE_CHECKLIST.md +12 -0
- package/binance-wallet-exploit/lib/forge-std/package.json +16 -0
- package/binance-wallet-exploit/lib/forge-std/scripts/vm.py +636 -0
- package/binance-wallet-exploit/out/build-info/1e9aa7e86cf56962.json +1 -0
- package/binance-wallet-exploit/out/build-info/6f56f10e9d7b56eb.json +1 -0
- package/binance-wallet-exploit/out/build-info/7edba961ff697a24.json +1 -0
- package/binance-wallet-exploit/out/build-info/8c27fe3efea2f2e7.json +1 -0
- package/binance-wallet-exploit/out/build-info/978b680daffec63a.json +1 -0
- package/binance-wallet-exploit/out/build-info/9806b900b5672d0c.json +1 -0
- package/binance-wallet-exploit/out/build-info/b4b9ff36e9b3fc27.json +1 -0
- package/binance-wallet-exploit/out/build-info/b6f4df9ae05c0812.json +1 -0
- package/binance-wallet-exploit/out/build-info/c88dbc86551f7b5c.json +1 -0
- package/binance-wallet-exploit/out/build-info/e9657504010623db.json +1 -0
- package/cache/fuzz/failures/ARIAVerifiedFuzzTest/testFuzz_ApprovalRaceCondition +1 -0
- package/cache/fuzz/failures/HotCrossSwapFuzzTest/testFuzz_DirectTransferExploit +1 -0
- package/cache/fuzz/failures/HotCrossSwapFuzzTest/testFuzz_LargeSwapDrain +1 -0
- package/cache/fuzz/failures/LendFlareFuzz/testFuzz_ApprovalExploit +1 -0
- package/cache/fuzz/failures/LendFlareFuzz/testFuzz_BalanceManipulation +1 -0
- package/cache/fuzz/failures/LendFlareFuzz/testFuzz_RateManipulation +1 -0
- package/cache/fuzz/failures/LendFlareFuzz/testFuzz_StorageManipulation +1 -0
- package/cache/fuzz/failures/PARFuzzTest/testFuzz_OverflowTransfer +1 -0
- package/cache/fuzz/failures/PARFuzzTest/testFuzz_Transfer +1 -0
- package/cache/fuzz/failures/XFIDeepFuzz/testFuzz_FrontrunAddfunds +1 -0
- package/cache/fuzz/failures/XFIDeepFuzz/testFuzz_RewardOverflow +1 -0
- package/cache/fuzz/failures/XFIDeepFuzz/testFuzz_RoundingExploit +1 -0
- package/cache/fuzz/failures/XFIDeepFuzz/testFuzz_WithdrawLimit +1 -0
- package/cache/solidity-files-cache.json +1 -0
- package/cache/test-failures +1 -0
- package/calculate-elephant-flashloan.js +195 -0
- package/check-address-approval.js +112 -0
- package/check-alpha-proxy.js +42 -0
- package/check-arbitrage.js +155 -0
- package/check-aria-token.js +47 -0
- package/check-ark.sh +20 -0
- package/check-btcst-mining.js +75 -0
- package/check-btcst-pools.js +163 -0
- package/check-btcst.js +88 -0
- package/check-caller.js +26 -0
- package/check-ceek-lp.js +73 -0
- package/check-ceek.js +47 -0
- package/check-dxsale-address.js +35 -0
- package/check-fara-exploit-timing.js +56 -0
- package/check-fara-real-exploit.js +73 -0
- package/check-flashloan-limits.js +129 -0
- package/check-kel-cel-pool.js +91 -0
- package/check-lax-staking.js +41 -0
- package/check-lendflare.js +165 -0
- package/check-lft-accounting.js +109 -0
- package/check-lft-roles.js +165 -0
- package/check-lock-time.js +47 -0
- package/check-min-stake.js +73 -0
- package/check-mystery-contract.js +52 -0
- package/check-next-token.js +50 -0
- package/check-nora-lock.js +67 -0
- package/check-oiler-approvals.js +116 -0
- package/check-oiler-proxy.js +73 -0
- package/check-oiler-staking.js +117 -0
- package/check-proxy-simple.js +71 -0
- package/check-recent-stakes.js +54 -0
- package/check-shegic-holdings.js +67 -0
- package/check-snowcrash-ecosystem.js +83 -0
- package/check-sync-lp.js +97 -0
- package/check-sync-stake.js +42 -0
- package/check-tlm.js +37 -0
- package/check-token-pools.js +146 -0
- package/check-trunk-depeg.js +181 -0
- package/check-tusd-decimals.js +58 -0
- package/check-user-storage-deep.js +81 -0
- package/check-welephant-pools.js +130 -0
- package/check-xfi-pool.js +75 -0
- package/check-zypher.js +32 -0
- package/check_proxy.sh +36 -0
- package/compare-tlm-chains.js +90 -0
- package/contract_0x05f2.html +6025 -0
- package/contract_0x3720.html +6361 -0
- package/contract_0x928e.html +5606 -0
- package/contract_0xc42d.html +5304 -0
- package/contract_page.html +5789 -0
- package/decode-stake-tx.js +50 -0
- package/deep-analyze-lock.js +82 -0
- package/dune_uups_proxy_query.sql +42 -0
- package/dune_uups_vulnerable_query.sql +0 -0
- package/echidna/alpha-proxy.yaml +14 -0
- package/echidna/elephant.yaml +7 -0
- package/echidna/lendflare.yaml +42 -0
- package/echidna.config.yaml +12 -0
- package/elephant_raw.json +1 -0
- package/eps_raw.json +1 -0
- package/exploit/.github/workflows/test.yml +38 -0
- package/exploit/.gitmodules +3 -0
- package/exploit/README.md +66 -0
- package/exploit/foundry.lock +8 -0
- package/exploit/lib/forge-std/.gitattributes +1 -0
- package/exploit/lib/forge-std/.github/CODEOWNERS +1 -0
- package/exploit/lib/forge-std/.github/dependabot.yml +6 -0
- package/exploit/lib/forge-std/.github/workflows/ci.yml +125 -0
- package/exploit/lib/forge-std/.github/workflows/sync.yml +36 -0
- package/exploit/lib/forge-std/CONTRIBUTING.md +193 -0
- package/exploit/lib/forge-std/LICENSE-APACHE +203 -0
- package/exploit/lib/forge-std/LICENSE-MIT +25 -0
- package/exploit/lib/forge-std/README.md +314 -0
- package/exploit/lib/forge-std/RELEASE_CHECKLIST.md +12 -0
- package/exploit/lib/forge-std/package.json +16 -0
- package/exploit/lib/forge-std/scripts/vm.py +636 -0
- package/exploit_analysis.txt +51 -0
- package/extract_contract.py +21 -0
- package/extract_elephant_contracts.py +24 -0
- package/fara-staking-bytecode.txt +1 -0
- package/fara-staking-raw.txt +1 -0
- package/fetch-aria.js +46 -0
- package/fetch-contract.js +50 -0
- package/fetch-shegic-source.js +86 -0
- package/fetch-snowcrash.js +44 -0
- package/fetch-staking-source.js +53 -0
- package/fetch-tlm.js +60 -0
- package/fetch_elephant_source.py +32 -0
- package/find-ceek-staking.js +21 -0
- package/find-exploit-tx.js +88 -0
- package/find-oiler-holders.js +100 -0
- package/find-tlm-holder.js +36 -0
- package/find-vulnerable-fund.js +94 -0
- package/foundry.lock +8 -0
- package/fuzz-all.sh +53 -0
- package/get-aria-contract.py +40 -0
- package/get-lft-holders.js +89 -0
- package/get-tlm-source.sh +8 -0
- package/harvest_txs.json +1 -0
- package/lft-bytecode-raw.txt +1 -0
- package/lft-bytecode.json +1 -0
- package/lft-impl.bin +1 -0
- package/lft-implementation-bytecode.txt +1 -0
- package/lib/forge-std/.gitattributes +1 -0
- package/lib/forge-std/.github/CODEOWNERS +1 -0
- package/lib/forge-std/.github/dependabot.yml +6 -0
- package/lib/forge-std/.github/workflows/ci.yml +125 -0
- package/lib/forge-std/.github/workflows/sync.yml +36 -0
- package/lib/forge-std/CONTRIBUTING.md +193 -0
- package/lib/forge-std/LICENSE-APACHE +203 -0
- package/lib/forge-std/LICENSE-MIT +25 -0
- package/lib/forge-std/README.md +314 -0
- package/lib/forge-std/RELEASE_CHECKLIST.md +12 -0
- package/lib/forge-std/package.json +16 -0
- package/lib/forge-std/scripts/vm.py +636 -0
- package/lib/openzeppelin-contracts/.changeset/config.json +12 -0
- package/lib/openzeppelin-contracts/.codecov.yml +12 -0
- package/lib/openzeppelin-contracts/.editorconfig +21 -0
- package/lib/openzeppelin-contracts/.eslintrc +20 -0
- package/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/bug_report.md +21 -0
- package/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/config.yml +4 -0
- package/lib/openzeppelin-contracts/.github/ISSUE_TEMPLATE/feature_request.md +14 -0
- package/lib/openzeppelin-contracts/.github/PULL_REQUEST_TEMPLATE.md +20 -0
- package/lib/openzeppelin-contracts/.github/actions/gas-compare/action.yml +49 -0
- package/lib/openzeppelin-contracts/.github/actions/setup/action.yml +21 -0
- package/lib/openzeppelin-contracts/.github/actions/storage-layout/action.yml +55 -0
- package/lib/openzeppelin-contracts/.github/workflows/actionlint.yml +18 -0
- package/lib/openzeppelin-contracts/.github/workflows/changeset.yml +28 -0
- package/lib/openzeppelin-contracts/.github/workflows/checks.yml +118 -0
- package/lib/openzeppelin-contracts/.github/workflows/docs.yml +19 -0
- package/lib/openzeppelin-contracts/.github/workflows/formal-verification.yml +68 -0
- package/lib/openzeppelin-contracts/.github/workflows/release-cycle.yml +214 -0
- package/lib/openzeppelin-contracts/.github/workflows/upgradeable.yml +34 -0
- package/lib/openzeppelin-contracts/.gitmodules +7 -0
- package/lib/openzeppelin-contracts/.mocharc.js +4 -0
- package/lib/openzeppelin-contracts/.prettierrc +15 -0
- package/lib/openzeppelin-contracts/.solcover.js +13 -0
- package/lib/openzeppelin-contracts/CHANGELOG.md +972 -0
- package/lib/openzeppelin-contracts/CODE_OF_CONDUCT.md +73 -0
- package/lib/openzeppelin-contracts/CONTRIBUTING.md +36 -0
- package/lib/openzeppelin-contracts/GUIDELINES.md +148 -0
- package/lib/openzeppelin-contracts/LICENSE +22 -0
- package/lib/openzeppelin-contracts/README.md +107 -0
- package/lib/openzeppelin-contracts/RELEASING.md +45 -0
- package/lib/openzeppelin-contracts/SECURITY.md +42 -0
- package/lib/openzeppelin-contracts/audits/2017-03.md +292 -0
- package/lib/openzeppelin-contracts/audits/2018-10.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2022-10-Checkpoints.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2022-10-ERC4626.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2023-05-v4.9.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/2023-10-v5.0.pdf +0 -0
- package/lib/openzeppelin-contracts/audits/README.md +17 -0
- package/lib/openzeppelin-contracts/certora/Makefile +54 -0
- package/lib/openzeppelin-contracts/certora/README.md +60 -0
- package/lib/openzeppelin-contracts/certora/diff/access_manager_AccessManager.sol.patch +97 -0
- package/lib/openzeppelin-contracts/certora/reports/2021-10.pdf +0 -0
- package/lib/openzeppelin-contracts/certora/reports/2022-03.pdf +0 -0
- package/lib/openzeppelin-contracts/certora/reports/2022-05.pdf +0 -0
- package/lib/openzeppelin-contracts/certora/run.js +160 -0
- package/lib/openzeppelin-contracts/certora/specs/AccessControl.spec +119 -0
- package/lib/openzeppelin-contracts/certora/specs/AccessControlDefaultAdminRules.spec +464 -0
- package/lib/openzeppelin-contracts/certora/specs/DoubleEndedQueue.spec +300 -0
- package/lib/openzeppelin-contracts/certora/specs/ERC20.spec +352 -0
- package/lib/openzeppelin-contracts/certora/specs/ERC20FlashMint.spec +55 -0
- package/lib/openzeppelin-contracts/certora/specs/ERC20Wrapper.spec +198 -0
- package/lib/openzeppelin-contracts/certora/specs/ERC721.spec +679 -0
- package/lib/openzeppelin-contracts/certora/specs/EnumerableMap.spec +333 -0
- package/lib/openzeppelin-contracts/certora/specs/EnumerableSet.spec +246 -0
- package/lib/openzeppelin-contracts/certora/specs/Initializable.spec +165 -0
- package/lib/openzeppelin-contracts/certora/specs/Ownable.spec +77 -0
- package/lib/openzeppelin-contracts/certora/specs/Ownable2Step.spec +108 -0
- package/lib/openzeppelin-contracts/certora/specs/Pausable.spec +96 -0
- package/lib/openzeppelin-contracts/certora/specs/TimelockController.spec +274 -0
- package/lib/openzeppelin-contracts/certora/specs/helpers/helpers.spec +7 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IAccessControl.spec +8 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IAccessControlDefaultAdminRules.spec +36 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC20.spec +11 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC2612.spec +5 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC3156FlashBorrower.spec +3 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC3156FlashLender.spec +5 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC5313.spec +3 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC721.spec +17 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IERC721Receiver.spec +3 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IOwnable.spec +5 -0
- package/lib/openzeppelin-contracts/certora/specs/methods/IOwnable2Step.spec +7 -0
- package/lib/openzeppelin-contracts/certora/specs.json +86 -0
- package/lib/openzeppelin-contracts/contracts/access/README.adoc +43 -0
- package/lib/openzeppelin-contracts/contracts/finance/README.adoc +14 -0
- package/lib/openzeppelin-contracts/contracts/governance/README.adoc +167 -0
- package/lib/openzeppelin-contracts/contracts/interfaces/README.adoc +82 -0
- package/lib/openzeppelin-contracts/contracts/metatx/README.adoc +12 -0
- package/lib/openzeppelin-contracts/contracts/package.json +32 -0
- package/lib/openzeppelin-contracts/contracts/proxy/README.adoc +87 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC1155/README.adoc +41 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC20/README.adoc +67 -0
- package/lib/openzeppelin-contracts/contracts/token/ERC721/README.adoc +67 -0
- package/lib/openzeppelin-contracts/contracts/token/common/README.adoc +10 -0
- package/lib/openzeppelin-contracts/contracts/utils/README.adoc +88 -0
- package/lib/openzeppelin-contracts/contracts/vendor/compound/LICENSE +11 -0
- package/lib/openzeppelin-contracts/docs/README.md +16 -0
- package/lib/openzeppelin-contracts/docs/antora.yml +7 -0
- package/lib/openzeppelin-contracts/docs/config.js +21 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3a.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-3b.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack-6.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-attack.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-deposit.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-mint.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-linear.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglog.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/erc4626-rate-loglogext.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-exec.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/images/tally-vote.png +0 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/nav.adoc +23 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/access-control.adoc +204 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/backwards-compatibility.adoc +48 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/crowdsales.adoc +11 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/drafts.adoc +19 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc1155.adoc +145 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20-supply.adoc +71 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc20.adoc +77 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc4626.adoc +214 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/erc721.adoc +79 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/extending-contracts.adoc +77 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/faq.adoc +13 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/governance.adoc +240 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/index.adoc +79 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/tokens.adoc +31 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/upgradeable.adoc +77 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/utilities.adoc +185 -0
- package/lib/openzeppelin-contracts/docs/modules/ROOT/pages/wizard.adoc +15 -0
- package/lib/openzeppelin-contracts/docs/templates/contract.hbs +111 -0
- package/lib/openzeppelin-contracts/docs/templates/helpers.js +46 -0
- package/lib/openzeppelin-contracts/docs/templates/page.hbs +4 -0
- package/lib/openzeppelin-contracts/docs/templates/properties.js +64 -0
- package/lib/openzeppelin-contracts/hardhat/env-artifacts.js +24 -0
- package/lib/openzeppelin-contracts/hardhat/env-contract.js +25 -0
- package/lib/openzeppelin-contracts/hardhat/ignore-unreachable-warnings.js +45 -0
- package/lib/openzeppelin-contracts/hardhat/skip-foundry-tests.js +6 -0
- package/lib/openzeppelin-contracts/hardhat/task-test-get-files.js +25 -0
- package/lib/openzeppelin-contracts/hardhat.config.js +131 -0
- package/lib/openzeppelin-contracts/lib/erc4626-tests/LICENSE +661 -0
- package/lib/openzeppelin-contracts/lib/erc4626-tests/README.md +116 -0
- package/lib/openzeppelin-contracts/lib/forge-std/.github/workflows/ci.yml +92 -0
- package/lib/openzeppelin-contracts/lib/forge-std/.gitmodules +3 -0
- package/lib/openzeppelin-contracts/lib/forge-std/LICENSE-APACHE +203 -0
- package/lib/openzeppelin-contracts/lib/forge-std/LICENSE-MIT +25 -0
- package/lib/openzeppelin-contracts/lib/forge-std/README.md +250 -0
- package/lib/openzeppelin-contracts/lib/forge-std/package.json +16 -0
- package/lib/openzeppelin-contracts/logo.svg +15 -0
- package/lib/openzeppelin-contracts/netlify.toml +3 -0
- package/lib/openzeppelin-contracts/package-lock.json +16544 -0
- package/lib/openzeppelin-contracts/package.json +96 -0
- package/lib/openzeppelin-contracts/remappings.txt +1 -0
- package/lib/openzeppelin-contracts/renovate.json +4 -0
- package/lib/openzeppelin-contracts/requirements.txt +1 -0
- package/lib/openzeppelin-contracts/scripts/checks/compare-layout.js +20 -0
- package/lib/openzeppelin-contracts/scripts/checks/compareGasReports.js +243 -0
- package/lib/openzeppelin-contracts/scripts/checks/extract-layout.js +38 -0
- package/lib/openzeppelin-contracts/scripts/checks/generation.sh +6 -0
- package/lib/openzeppelin-contracts/scripts/checks/inheritance-ordering.js +54 -0
- package/lib/openzeppelin-contracts/scripts/gen-nav.js +41 -0
- package/lib/openzeppelin-contracts/scripts/generate/format-lines.js +16 -0
- package/lib/openzeppelin-contracts/scripts/generate/run.js +49 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.js +247 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.opts.js +17 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/Checkpoints.t.js +146 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableMap.js +283 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/EnumerableSet.js +250 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/SafeCast.js +126 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/StorageSlot.js +78 -0
- package/lib/openzeppelin-contracts/scripts/generate/templates/conversion.js +30 -0
- package/lib/openzeppelin-contracts/scripts/git-user-config.sh +6 -0
- package/lib/openzeppelin-contracts/scripts/helpers.js +37 -0
- package/lib/openzeppelin-contracts/scripts/prepack.sh +23 -0
- package/lib/openzeppelin-contracts/scripts/prepare-docs.sh +26 -0
- package/lib/openzeppelin-contracts/scripts/release/format-changelog.js +33 -0
- package/lib/openzeppelin-contracts/scripts/release/synchronize-versions.js +15 -0
- package/lib/openzeppelin-contracts/scripts/release/update-comment.js +34 -0
- package/lib/openzeppelin-contracts/scripts/release/version.sh +11 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/exit-prerelease.sh +8 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/github-release.js +48 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/integrity-check.sh +20 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/pack.sh +26 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/publish.sh +26 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/rerun.js +7 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/set-changesets-pr-title.js +17 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/start.sh +35 -0
- package/lib/openzeppelin-contracts/scripts/release/workflow/state.js +112 -0
- package/lib/openzeppelin-contracts/scripts/remove-ignored-artifacts.js +45 -0
- package/lib/openzeppelin-contracts/scripts/solhint-custom/index.js +84 -0
- package/lib/openzeppelin-contracts/scripts/solhint-custom/package.json +5 -0
- package/lib/openzeppelin-contracts/scripts/update-docs-branch.js +65 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/README.md +21 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/patch-apply.sh +19 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/patch-save.sh +18 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/transpile-onto.sh +54 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/transpile.sh +47 -0
- package/lib/openzeppelin-contracts/scripts/upgradeable/upgradeable.patch +360 -0
- package/lib/openzeppelin-contracts/slither.config.json +5 -0
- package/lib/openzeppelin-contracts/solhint.config.js +20 -0
- package/mythril-lft-output.txt +1 -0
- package/mythril-lft-symbolic.txt +18 -0
- package/mythril-lft.sh +20 -0
- package/mythril-symbolic-output.txt +1 -0
- package/mythril-symbolic.sh +42 -0
- package/out/build-info/0026b78428192979.json +1 -0
- package/out/build-info/03c4fc3b88486eba.json +1 -0
- package/out/build-info/0540afa9b9a5c5a6.json +1 -0
- package/out/build-info/081932f505bc08b9.json +1 -0
- package/out/build-info/0da104ba0d6642d5.json +1 -0
- package/out/build-info/197281971dbb5f23.json +1 -0
- package/out/build-info/197e7e332832a232.json +1 -0
- package/out/build-info/1a1cab9136eb5f94.json +1 -0
- package/out/build-info/1b320204eb162aa2.json +1 -0
- package/out/build-info/1e03f94398052674.json +1 -0
- package/out/build-info/22ac085949602937.json +1 -0
- package/out/build-info/234ef37453a9fa64.json +1 -0
- package/out/build-info/2447db7b1878fa8e.json +1 -0
- package/out/build-info/25568daeb484f5ff.json +1 -0
- package/out/build-info/27465853244c49ce.json +1 -0
- package/out/build-info/2c57a9e0f087453b.json +1 -0
- package/out/build-info/3c62ae7de8da68c4.json +1 -0
- package/out/build-info/3e771ae109e97bb3.json +1 -0
- package/out/build-info/460499bc0a3465c4.json +1 -0
- package/out/build-info/47ce37e50a4f115e.json +1 -0
- package/out/build-info/4fcce5c63cf427d6.json +1 -0
- package/out/build-info/4fd0a53fe63fddbb.json +1 -0
- package/out/build-info/50f1247db9d769cc.json +1 -0
- package/out/build-info/5317d0181a7a5e02.json +1 -0
- package/out/build-info/594df509275ceb5b.json +1 -0
- package/out/build-info/61983ac3f6141719.json +1 -0
- package/out/build-info/638c4548307122fe.json +1 -0
- package/out/build-info/67c2c43bdb7c0ded.json +1 -0
- package/out/build-info/777f42643aad37b7.json +1 -0
- package/out/build-info/7d7856f19e845354.json +1 -0
- package/out/build-info/83976260b6f71e94.json +1 -0
- package/out/build-info/83c23882000b963d.json +1 -0
- package/out/build-info/84b2cce8f70b36be.json +1 -0
- package/out/build-info/8bc13d31d7c3206a.json +1 -0
- package/out/build-info/8e183bd4d9d8cf88.json +1 -0
- package/out/build-info/94bfe1e7cafa8ff5.json +1 -0
- package/out/build-info/99ec7d5e8d8ff360.json +1 -0
- package/out/build-info/9ac044b29daa7d5e.json +1 -0
- package/out/build-info/9b203227ff5d2e63.json +1 -0
- package/out/build-info/9d18c5872c4282dd.json +1 -0
- package/out/build-info/9f77f04f33baf9a3.json +1 -0
- package/out/build-info/a6e1caf974787982.json +1 -0
- package/out/build-info/a94b6348867a62d6.json +1 -0
- package/out/build-info/ad93721947a8b195.json +1 -0
- package/out/build-info/b42daddb5aa4b19f.json +1 -0
- package/out/build-info/bf13512ae899f7e8.json +1 -0
- package/out/build-info/c39f86c20a548c4a.json +1 -0
- package/out/build-info/cb12bb975a2f4e65.json +1 -0
- package/out/build-info/d0c6788fadc2aa60.json +1 -0
- package/out/build-info/d2726bf94ed5b845.json +1 -0
- package/out/build-info/d4eb00da50cce5cb.json +1 -0
- package/out/build-info/db931924a3bc8bdd.json +1 -0
- package/out/build-info/e1a503d49bc77401.json +1 -0
- package/out/build-info/efe5396f8892ce77.json +1 -0
- package/out/build-info/f536d90ced745969.json +1 -0
- package/out/build-info/fed38823c7019b82.json +1 -0
- package/package.json +51 -0
- package/page.html +5384 -0
- package/pancakeswap-simple-tvl.sql +15 -0
- package/pancakeswap-top-pools.sql +29 -0
- package/pancakeswap-tvl-optimized.sql +57 -0
- package/pancakeswap-tvl-query.sql +60 -0
- package/pancakeswap-underflow-hunting.sql +51 -0
- package/pancakeswap-vulnerability-queries.sql +200 -0
- package/posi_page.html +6369 -0
- package/posi_response.json +29 -0
- package/proxy_page.html +500 -0
- package/run_mythril_elephant.sh +18 -0
- package/sHEGIC-bytecode.bin +6 -0
- package/sHEGIC-mythril-analysis.txt +1 -0
- package/sHEGIC-mythril-full.txt +134 -0
- package/sHEGIC_ANALYSIS.md +135 -0
- package/sHEGIC_EXPLOIT_ANALYSIS.md +317 -0
- package/sHEGIC_MYTHRIL_ANALYSIS.md +361 -0
- package/scrape-snowcrash.js +28 -0
- package/scripts/yooshi_drain.sh +154 -0
- package/shi_raw.json +1 -0
- package/temp.json +1 -0
- package/temp_harvest.json +1 -0
- package/temp_pika.json +1 -0
- package/temp_posi.json +1 -0
- package/temp_response.json +1 -0
- package/test-lft-hidden-balance.js +108 -0
- package/test-xfi-exploit.js +140 -0
- package/trunk-liquidity-rescue.js +164 -0
- package/vBABY_page.html +6153 -0
- package/vBABY_response.json +29 -0
- package/wsg_response.json +1 -0
- package/yooldo_page.html +10371 -0
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import re
|
|
2
|
+
|
|
3
|
+
# Read the main ELEPHANT contract from the web fetch
|
|
4
|
+
with open('ELEPHANT.sol', 'r') as f:
|
|
5
|
+
content = f.read()
|
|
6
|
+
|
|
7
|
+
# The contracts are embedded in the deployment
|
|
8
|
+
# Extract Graveyard contract
|
|
9
|
+
graveyard_match = re.search(r'contract ElephantGraveyard.*?(?=contract\s+\w+|$)', content, re.DOTALL)
|
|
10
|
+
if graveyard_match:
|
|
11
|
+
with open('ELEPHANT_Graveyard.sol', 'w') as f:
|
|
12
|
+
f.write("// SPDX-License-Identifier: MIT\npragma solidity ^0.6.8;\n\n")
|
|
13
|
+
f.write(graveyard_match.group(0))
|
|
14
|
+
print("Extracted Graveyard")
|
|
15
|
+
|
|
16
|
+
# Extract LiquidityDrive contract
|
|
17
|
+
liquidity_match = re.search(r'contract ElephantLiquidityDrive.*?(?=contract\s+Elephant\s|$)', content, re.DOTALL)
|
|
18
|
+
if liquidity_match:
|
|
19
|
+
with open('ELEPHANT_LiquidityDrive.sol', 'w') as f:
|
|
20
|
+
f.write("// SPDX-License-Identifier: MIT\npragma solidity ^0.6.8;\n\n")
|
|
21
|
+
f.write(liquidity_match.group(0))
|
|
22
|
+
print("Extracted LiquidityDrive")
|
|
23
|
+
|
|
24
|
+
print("Extraction complete")
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
0x608060405234801561001057600080fd5b50600436106102105760003560e01c80637ec481db11610125578063b338641f116100ad578063d21dc37c1161007c578063d21dc37c1461055c578063db2e21bc14610583578063df136d651461058b578063f2fde38b14610594578063fd1075d0146105a757600080fd5b8063b338641f1461048f578063bf8568951461052d578063bf9ec5fa14610536578063c40e77c41461054957600080fd5b806399383dd2116100f457806399383dd2146104305780639e2c8a5b14610443578063a638f2e214610456578063ac8a584a14610469578063ae169a501461047c57600080fd5b80637ec481db146103e657806386a77b95146103f95780638da5cb5b1461040c5780639870d7fe1461041d57600080fd5b80632e559d79116101a857806361b8b5dc1161017757806361b8b5dc14610386578063648795a1146103a6578063715018a6146103af57806372f702f3146103b75780637a80d22f146103de57600080fd5b80632e559d791461032b5780633f683b6a1461033457806352024b86146103415780635660000a1461037d57600080fd5b806313e7c9d8116101e457806313e7c9d81461029357806318178c5c146102c6578063222b9e3f146102d9578063240f2ec01461030457600080fd5b8062fdd58e146102155780630891b93b1461023b5780630bbd0a2a1461025057806312253a6c1461028b575b600080fd5b6102286102233660046115c6565b6105ba565b6040519081526020015b60405180910390f35b61024e6102493660046115f2565b6105e5565b005b61026361025e3660046115c6565b6105f2565b604080519586526020860194909452928401919091526060830152608082015260a001610232565b61024e6106a7565b6102b66102a136600461160b565b60016020526000908152604090205460ff1681565b6040519015158152602001610232565b6102286102d43660046115c6565b6106be565b6002546102ec906001600160a01b031681565b6040516001600160a01b039091168152602001610232565b6102ec7f00000000000000000000000057cc56cec2f2612f43cb0eaa010677766c5aeb4d81565b61022860075481565b6008546102b69060ff1681565b61036861034f3660046115f2565b600a602052600090815260409020805460019091015482565b60408051928352602083019190915201610232565b61022860035481565b61022861039436600461160b565b600b6020526000908152604090205481565b61022860045481565b61024e6107a3565b6102ec7f000000000000000000000000f4ed363144981d3a65f42e7d0dc54ff9eef559a181565b6102286107b7565b61024e6103f4366004611674565b610814565b61024e61040736600461170e565b6108c8565b6000546001600160a01b03166102ec565b61024e61042b36600461160b565b6108e1565b61022861043e3660046115c6565b610910565b61024e610451366004611750565b6109a9565b61024e610464366004611772565b610c11565b61024e61047736600461160b565b610fd5565b61024e61048a3660046115f2565b610ffe565b6104f261049d3660046115c6565b600c602052816000526040600020602052806000526040600020600091509150508060000154908060010154908060020154908060030154908060040154908060050154908060060154908060070154905088565b604080519889526020890197909752958701949094526060860192909252608085015260a084015260c083015260e082015261010001610232565b61022860055481565b6102286105443660046115f2565b611088565b61024e61055736600461160b565b6110a9565b6102ec7f00000000000000000000000000524fedebe989072803ce5f39df1d60871f6aca81565b61024e6110d3565b61022860065481565b61024e6105a236600461160b565b6111bb565b61024e6105b53660046115f2565b611234565b6001600160a01b0382166000908152600c602090815260408083208484529091529020545b92915050565b6105ed611250565b600455565b6001600160a01b0382166000908152600c602090815260408083208484528252808320815161010081018352815481526001820154938101939093526002810154918301919091526003810154606083015260048101546080830152600581015460a0830152600681015460c08301526007015460e0820152819081908190819061067d88886106be565b95506106898888610910565b815160a083015160c090930151979a91995097509095945092505050565b6106af611250565b6008805460ff19166001179055565b6001600160a01b0382166000908152600c602090815260408083208484528252808320815161010081018352815481526001820154938101939093526002810154918301919091526003810154606083015260048101546080830152600581015460a0830152600681015460c08301526007015460e0820152816107406107b7565b90508160800151811015610759576000925050506105df565b8160400151670de0b6b3a764000083608001518361077791906117b4565b846020015161078691906117c7565b61079091906117de565b61079a9190611800565b95945050505050565b6107ab611250565b6107b560006112aa565b565b60006007546000036107c95750600090565b6007546003546005546107dc90426117b4565b6107e691906117c7565b6107f890670de0b6b3a76400006117c7565b61080291906117de565b60065461080f9190611800565b905090565b61081c611250565b848314801561082a57508481145b61083357600080fd5b60005b858110156108bf576000600a600089898581811061085657610856611813565b905060200201358152602001908152602001600020905085858381811061087f5761087f611813565b602002919091013582555083838381811061089c5761089c611813565b9050602002013581600101819055505080806108b790611829565b915050610836565b50505050505050565b6108d0611250565b6108dc60098383611551565b505050565b6108e9611250565b6001600160a01b03166000908152600160208190526040909120805460ff19169091179055565b6001600160a01b0382166000908152600c602090815260408083208484528252808320815161010081018352815481526001820154938101939093526002810154918301919091526003810154606083015260048101546080830152600581015460a0830152600681015460c08301526007015460e0820152610992816112fa565b81606001516109a19190611800565b949350505050565b60085460ff16156109d55760405162461bcd60e51b81526004016109cc90611842565b60405180910390fd5b336000818152600c60209081526040808320868452909152902083906109fb8383610910565b6003820155610a086107b7565b60065542600555610a1983836106be565b60028201556006805460048301554260078301819055336000908152600c602090815260408083208a84529091529020918201541115610a9b5760405162461bcd60e51b815260206004820152601b60248201527f5374616b696e674b6e696768743a207374696c6c206c6f636b6564000000000060448201526064016109cc565b8054851115610abc5760405162461bcd60e51b81526004016109cc90611879565b84816000016000828254610ad091906117b4565b909155505080546005820154610ae69190611336565b6001820155336000908152600b602052604081208054879290610b0a9084906117b4565b92505081905550610b1f858260050154611336565b60076000828254610b3091906117b4565b90915550610b409050338761136d565b60405163a9059cbb60e01b8152336004820152602481018690527f000000000000000000000000f4ed363144981d3a65f42e7d0dc54ff9eef559a16001600160a01b03169063a9059cbb906044016020604051808303816000875af1158015610bad573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bd191906118bc565b50604051858152869033907f7fc4727e062e336010f2c282598ef5f14facb3de68cf8195c2f23e1454b2b74e9060200160405180910390a3505050505050565b60085460ff1615610c345760405162461bcd60e51b81526004016109cc90611842565b336000818152600c6020908152604080832087845290915290208490610c5a8383610910565b6003820155610c676107b7565b60065542600555610c7883836106be565b6002820155600654600482015542600780830191909155336000908152600c602090815260408083208a84529091529020908510610d115760405162461bcd60e51b815260206004820152603060248201527f5374616b696e674b6e696768743a205f6c6f636b65644d6f6e746873206d757360448201526f74206265206c657373207468616e203760801b60648201526084016109cc565b8060060154421015610d7d578060050154851015610d7d5760405162461bcd60e51b8152602060048201526024808201527f5374616b696e674b6e696768743a20696e76616c6964205f6c6f636b65644d6f6044820152636e74687360e01b60648201526084016109cc565b336000908152600b602052604081208054889290610d9c908490611800565b9091555050805486908290600090610db5908490611800565b90915550508054600090610dc99087611336565b9050808260010154600754610dde91906117b4565b610de89190611800565b6007556001820181905560058201869055610e068662278d006117c7565b610e109042611800565b826006018190555085600603610ef6576000610e2b886114c7565b90508015610ef4576000818152600a60209081526040808320815180830190925280548252600101549181018290529103610e6557600080fd5b80516020820151604051630ab714fb60e11b8152336004820152602481019290925260448201527f00000000000000000000000057cc56cec2f2612f43cb0eaa010677766c5aeb4d6001600160a01b03169063156e29f690606401600060405180830381600087803b158015610eda57600080fd5b505af1158015610eee573d6000803e3d6000fd5b50505050505b505b6040516323b872dd60e01b8152336004820152306024820152604481018890527f000000000000000000000000f4ed363144981d3a65f42e7d0dc54ff9eef559a16001600160a01b0316906323b872dd906064016020604051808303816000875af1158015610f69573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f8d91906118bc565b506040805188815260208101889052899133917fb4caaf29adda3eefee3ad552a8e85058589bf834c7466cae4ee58787f70589ed910160405180910390a35050505050505050565b610fdd611250565b6001600160a01b03166000908152600160205260409020805460ff19169055565b60085460ff16156110215760405162461bcd60e51b81526004016109cc90611842565b336000818152600c60209081526040808320858452909152902082906110478383610910565b60038201556110546107b7565b6006554260055561106583836106be565b60028201556006546004820155426007820155611082338561136d565b50505050565b6009818154811061109857600080fd5b600091825260209091200154905081565b6110b1611250565b600280546001600160a01b0319166001600160a01b0392909216919091179055565b336000908152600b602052604090205460085460ff166110f257600080fd5b600081116111125760405162461bcd60e51b81526004016109cc90611879565b336000818152600b6020526040808220919091555163a9059cbb60e01b81526004810191909152602481018290526001600160a01b037f000000000000000000000000f4ed363144981d3a65f42e7d0dc54ff9eef559a1169063a9059cbb906044016020604051808303816000875af1158015611193573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111b791906118bc565b5050565b6111c3611250565b6001600160a01b0381166112285760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016109cc565b611231816112aa565b50565b61123c611250565b6112446107b7565b60065542600555600355565b6000546001600160a01b031633146107b55760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016109cc565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6000620186a06004548360e001514261131391906117b4565b846020015161132291906117c7565b61132c91906117c7565b6105df91906117de565b60006127106101f461134884866117c7565b61135291906117c7565b61135c91906117de565b6113669084611800565b9392505050565b6001600160a01b038281166000908152600c6020908152604080832085845290915280822060028101805460038301805492869055949094559151632ff1a96760e11b81523360048201526024810183905290937f00000000000000000000000000524fedebe989072803ce5f39df1d60871f6aca1690635fe352ce90604401600060405180830381600087803b15801561140757600080fd5b505af115801561141b573d6000803e3d6000fd5b50506002546040516307b22ee360e21b8152336004820152602481018690526001600160a01b039091169250631ec8bb8c9150604401600060405180830381600087803b15801561146b57600080fd5b505af115801561147f573d6000803e3d6000fd5b505060408051858152602081018590528793503392507f812be816db82c66cd18ca8457005cd84689642d8ac4d38599cc6af444a2dc72a910160405180910390a35050505050565b6000806114dc670de0b6b3a7640000846117de565b6009549091506000906114f1906001906117b4565b90505b6009818154811061150757611507611813565b9060005260206000200154821061153f576009818154811061152b5761152b611813565b906000526020600020015492505050919050565b80611549816118de565b9150506114f4565b82805482825590600052602060002090810192821561158c579160200282015b8281111561158c578235825591602001919060010190611571565b5061159892915061159c565b5090565b5b80821115611598576000815560010161159d565b6001600160a01b038116811461123157600080fd5b600080604083850312156115d957600080fd5b82356115e4816115b1565b946020939093013593505050565b60006020828403121561160457600080fd5b5035919050565b60006020828403121561161d57600080fd5b8135611366816115b1565b60008083601f84011261163a57600080fd5b50813567ffffffffffffffff81111561165257600080fd5b6020830191508360208260051b850101111561166d57600080fd5b9250929050565b6000806000806000806060878903121561168d57600080fd5b863567ffffffffffffffff808211156116a557600080fd5b6116b18a838b01611628565b909850965060208901359150808211156116ca57600080fd5b6116d68a838b01611628565b909650945060408901359150808211156116ef57600080fd5b506116fc89828a01611628565b979a9699509497509295939492505050565b6000806020838503121561172157600080fd5b823567ffffffffffffffff81111561173857600080fd5b61174485828601611628565b90969095509350505050565b6000806040838503121561176357600080fd5b50508035926020909101359150565b60008060006060848603121561178757600080fd5b505081359360208301359350604090920135919050565b634e487b7160e01b600052601160045260246000fd5b818103818111156105df576105df61179e565b80820281158282048414176105df576105df61179e565b6000826117fb57634e487b7160e01b600052601260045260246000fd5b500490565b808201808211156105df576105df61179e565b634e487b7160e01b600052603260045260246000fd5b60006001820161183b5761183b61179e565b5060010190565b6020808252601a908201527f5374616b696e674b6e696768743a206e6f742073746f70706564000000000000604082015260600190565b60208082526023908201527f5374616b696e674b6e696768743a20696e73756666696369656e742062616c616040820152626e636560e81b606082015260800190565b6000602082840312156118ce57600080fd5b8151801515811461136657600080fd5b6000816118ed576118ed61179e565b50600019019056fea26469706673582212205d5773e13d7b0f39e380361b4b99065793b3a6e9016d55dfca68f752c424912064736f6c63430008110033
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
0x608060405234801561001057600080fd5b50600436106102105760003560e01c80637ec481db11610125578063b338641f116100ad578063d21dc37c1161007c578063d21dc37c1461055c578063db2e21bc14610583578063df136d651461058b578063f2fde38b14610594578063fd1075d0146105a757600080fd5b8063b338641f1461048f578063bf8568951461052d578063bf9ec5fa14610536578063c40e77c41461054957600080fd5b806399383dd2116100f457806399383dd2146104305780639e2c8a5b14610443578063a638f2e214610456578063ac8a584a14610469578063ae169a501461047c57600080fd5b80637ec481db146103e657806386a77b95146103f95780638da5cb5b1461040c5780639870d7fe1461041d57600080fd5b80632e559d79116101a857806361b8b5dc1161017757806361b8b5dc14610386578063648795a1146103a6578063715018a6146103af57806372f702f3146103b75780637a80d22f146103de57600080fd5b80632e559d791461032b5780633f683b6a1461033457806352024b86146103415780635660000a1461037d57600080fd5b806313e7c9d8116101e457806313e7c9d81461029357806318178c5c146102c6578063222b9e3f146102d9578063240f2ec01461030457600080fd5b8062fdd58e146102155780630891b93b1461023b5780630bbd0a2a1461025057806312253a6c1461028b575b600080fd5b6102286102233660046115c6565b6105ba565b6040519081526020015b60405180910390f35b61024e6102493660046115f2565b6105e5565b005b61026361025e3660046115c6565b6105f2565b604080519586526020860194909452928401919091526060830152608082015260a001610232565b61024e6106a7565b6102b66102a136600461160b565b60016020526000908152604090205460ff1681565b6040519015158152602001610232565b6102286102d43660046115c6565b6106be565b6002546102ec906001600160a01b031681565b6040516001600160a01b039091168152602001610232565b6102ec7f00000000000000000000000057cc56cec2f2612f43cb0eaa010677766c5aeb4d81565b61022860075481565b6008546102b69060ff1681565b61036861034f3660046115f2565b600a602052600090815260409020805460019091015482565b60408051928352602083019190915201610232565b61022860035481565b61022861039436600461160b565b600b6020526000908152604090205481565b61022860045481565b61024e6107a3565b6102ec7f000000000000000000000000f4ed363144981d3a65f42e7d0dc54ff9eef559a181565b6102286107b7565b61024e6103f4366004611674565b610814565b61024e61040736600461170e565b6108c8565b6000546001600160a01b03166102ec565b61024e61042b36600461160b565b6108e1565b61022861043e3660046115c6565b610910565b61024e610451366004611750565b6109a9565b61024e610464366004611772565b610c11565b61024e61047736600461160b565b610fd5565b61024e61048a3660046115f2565b610ffe565b6104f261049d3660046115c6565b600c602052816000526040600020602052806000526040600020600091509150508060000154908060010154908060020154908060030154908060040154908060050154908060060154908060070154905088565b604080519889526020890197909752958701949094526060860192909252608085015260a084015260c083015260e082015261010001610232565b61022860055481565b6102286105443660046115f2565b611088565b61024e61055736600461160b565b6110a9565b6102ec7f00000000000000000000000000524fedebe989072803ce5f39df1d60871f6aca81565b61024e6110d3565b61022860065481565b61024e6105a236600461160b565b6111bb565b61024e6105b53660046115f2565b611234565b6001600160a01b0382166000908152600c602090815260408083208484529091529020545b92915050565b6105ed611250565b600455565b6001600160a01b0382166000908152600c602090815260408083208484528252808320815161010081018352815481526001820154938101939093526002810154918301919091526003810154606083015260048101546080830152600581015460a0830152600681015460c08301526007015460e0820152819081908190819061067d88886106be565b95506106898888610910565b815160a083015160c090930151979a91995097509095945092505050565b6106af611250565b6008805460ff19166001179055565b6001600160a01b0382166000908152600c602090815260408083208484528252808320815161010081018352815481526001820154938101939093526002810154918301919091526003810154606083015260048101546080830152600581015460a0830152600681015460c08301526007015460e0820152816107406107b7565b90508160800151811015610759576000925050506105df565b8160400151670de0b6b3a764000083608001518361077791906117b4565b846020015161078691906117c7565b61079091906117de565b61079a9190611800565b95945050505050565b6107ab611250565b6107b560006112aa565b565b60006007546000036107c95750600090565b6007546003546005546107dc90426117b4565b6107e691906117c7565b6107f890670de0b6b3a76400006117c7565b61080291906117de565b60065461080f9190611800565b905090565b61081c611250565b848314801561082a57508481145b61083357600080fd5b60005b858110156108bf576000600a600089898581811061085657610856611813565b905060200201358152602001908152602001600020905085858381811061087f5761087f611813565b602002919091013582555083838381811061089c5761089c611813565b9050602002013581600101819055505080806108b790611829565b915050610836565b50505050505050565b6108d0611250565b6108dc60098383611551565b505050565b6108e9611250565b6001600160a01b03166000908152600160208190526040909120805460ff19169091179055565b6001600160a01b0382166000908152600c602090815260408083208484528252808320815161010081018352815481526001820154938101939093526002810154918301919091526003810154606083015260048101546080830152600581015460a0830152600681015460c08301526007015460e0820152610992816112fa565b81606001516109a19190611800565b949350505050565b60085460ff16156109d55760405162461bcd60e51b81526004016109cc90611842565b60405180910390fd5b336000818152600c60209081526040808320868452909152902083906109fb8383610910565b6003820155610a086107b7565b60065542600555610a1983836106be565b60028201556006805460048301554260078301819055336000908152600c602090815260408083208a84529091529020918201541115610a9b5760405162461bcd60e51b815260206004820152601b60248201527f5374616b696e674b6e696768743a207374696c6c206c6f636b6564000000000060448201526064016109cc565b8054851115610abc5760405162461bcd60e51b81526004016109cc90611879565b84816000016000828254610ad091906117b4565b909155505080546005820154610ae69190611336565b6001820155336000908152600b602052604081208054879290610b0a9084906117b4565b92505081905550610b1f858260050154611336565b60076000828254610b3091906117b4565b90915550610b409050338761136d565b60405163a9059cbb60e01b8152336004820152602481018690527f000000000000000000000000f4ed363144981d3a65f42e7d0dc54ff9eef559a16001600160a01b03169063a9059cbb906044016020604051808303816000875af1158015610bad573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bd191906118bc565b50604051858152869033907f7fc4727e062e336010f2c282598ef5f14facb3de68cf8195c2f23e1454b2b74e9060200160405180910390a3505050505050565b60085460ff1615610c345760405162461bcd60e51b81526004016109cc90611842565b336000818152600c6020908152604080832087845290915290208490610c5a8383610910565b6003820155610c676107b7565b60065542600555610c7883836106be565b6002820155600654600482015542600780830191909155336000908152600c602090815260408083208a84529091529020908510610d115760405162461bcd60e51b815260206004820152603060248201527f5374616b696e674b6e696768743a205f6c6f636b65644d6f6e746873206d757360448201526f74206265206c657373207468616e203760801b60648201526084016109cc565b8060060154421015610d7d578060050154851015610d7d5760405162461bcd60e51b8152602060048201526024808201527f5374616b696e674b6e696768743a20696e76616c6964205f6c6f636b65644d6f6044820152636e74687360e01b60648201526084016109cc565b336000908152600b602052604081208054889290610d9c908490611800565b9091555050805486908290600090610db5908490611800565b90915550508054600090610dc99087611336565b9050808260010154600754610dde91906117b4565b610de89190611800565b6007556001820181905560058201869055610e068662278d006117c7565b610e109042611800565b826006018190555085600603610ef6576000610e2b886114c7565b90508015610ef4576000818152600a60209081526040808320815180830190925280548252600101549181018290529103610e6557600080fd5b80516020820151604051630ab714fb60e11b8152336004820152602481019290925260448201527f00000000000000000000000057cc56cec2f2612f43cb0eaa010677766c5aeb4d6001600160a01b03169063156e29f690606401600060405180830381600087803b158015610eda57600080fd5b505af1158015610eee573d6000803e3d6000fd5b50505050505b505b6040516323b872dd60e01b8152336004820152306024820152604481018890527f000000000000000000000000f4ed363144981d3a65f42e7d0dc54ff9eef559a16001600160a01b0316906323b872dd906064016020604051808303816000875af1158015610f69573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610f8d91906118bc565b506040805188815260208101889052899133917fb4caaf29adda3eefee3ad552a8e85058589bf834c7466cae4ee58787f70589ed910160405180910390a35050505050505050565b610fdd611250565b6001600160a01b03166000908152600160205260409020805460ff19169055565b60085460ff16156110215760405162461bcd60e51b81526004016109cc90611842565b336000818152600c60209081526040808320858452909152902082906110478383610910565b60038201556110546107b7565b6006554260055561106583836106be565b60028201556006546004820155426007820155611082338561136d565b50505050565b6009818154811061109857600080fd5b600091825260209091200154905081565b6110b1611250565b600280546001600160a01b0319166001600160a01b0392909216919091179055565b336000908152600b602052604090205460085460ff166110f257600080fd5b600081116111125760405162461bcd60e51b81526004016109cc90611879565b336000818152600b6020526040808220919091555163a9059cbb60e01b81526004810191909152602481018290526001600160a01b037f000000000000000000000000f4ed363144981d3a65f42e7d0dc54ff9eef559a1169063a9059cbb906044016020604051808303816000875af1158015611193573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111b791906118bc565b5050565b6111c3611250565b6001600160a01b0381166112285760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016109cc565b611231816112aa565b50565b61123c611250565b6112446107b7565b60065542600555600355565b6000546001600160a01b031633146107b55760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016109cc565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6000620186a06004548360e001514261131391906117b4565b846020015161132291906117c7565b61132c91906117c7565b6105df91906117de565b60006127106101f461134884866117c7565b61135291906117c7565b61135c91906117de565b6113669084611800565b9392505050565b6001600160a01b038281166000908152600c6020908152604080832085845290915280822060028101805460038301805492869055949094559151632ff1a96760e11b81523360048201526024810183905290937f00000000000000000000000000524fedebe989072803ce5f39df1d60871f6aca1690635fe352ce90604401600060405180830381600087803b15801561140757600080fd5b505af115801561141b573d6000803e3d6000fd5b50506002546040516307b22ee360e21b8152336004820152602481018690526001600160a01b039091169250631ec8bb8c9150604401600060405180830381600087803b15801561146b57600080fd5b505af115801561147f573d6000803e3d6000fd5b505060408051858152602081018590528793503392507f812be816db82c66cd18ca8457005cd84689642d8ac4d38599cc6af444a2dc72a910160405180910390a35050505050565b6000806114dc670de0b6b3a7640000846117de565b6009549091506000906114f1906001906117b4565b90505b6009818154811061150757611507611813565b9060005260206000200154821061153f576009818154811061152b5761152b611813565b906000526020600020015492505050919050565b80611549816118de565b9150506114f4565b82805482825590600052602060002090810192821561158c579160200282015b8281111561158c578235825591602001919060010190611571565b5061159892915061159c565b5090565b5b80821115611598576000815560010161159d565b6001600160a01b038116811461123157600080fd5b600080604083850312156115d957600080fd5b82356115e4816115b1565b946020939093013593505050565b60006020828403121561160457600080fd5b5035919050565b60006020828403121561161d57600080fd5b8135611366816115b1565b60008083601f84011261163a57600080fd5b50813567ffffffffffffffff81111561165257600080fd5b6020830191508360208260051b850101111561166d57600080fd5b9250929050565b6000806000806000806060878903121561168d57600080fd5b863567ffffffffffffffff808211156116a557600080fd5b6116b18a838b01611628565b909850965060208901359150808211156116ca57600080fd5b6116d68a838b01611628565b909650945060408901359150808211156116ef57600080fd5b506116fc89828a01611628565b979a9699509497509295939492505050565b6000806020838503121561172157600080fd5b823567ffffffffffffffff81111561173857600080fd5b61174485828601611628565b90969095509350505050565b6000806040838503121561176357600080fd5b50508035926020909101359150565b60008060006060848603121561178757600080fd5b505081359360208301359350604090920135919050565b634e487b7160e01b600052601160045260246000fd5b818103818111156105df576105df61179e565b80820281158282048414176105df576105df61179e565b6000826117fb57634e487b7160e01b600052601260045260246000fd5b500490565b808201808211156105df576105df61179e565b634e487b7160e01b600052603260045260246000fd5b60006001820161183b5761183b61179e565b5060010190565b6020808252601a908201527f5374616b696e674b6e696768743a206e6f742073746f70706564000000000000604082015260600190565b60208082526023908201527f5374616b696e674b6e696768743a20696e73756666696369656e742062616c616040820152626e636560e81b606082015260800190565b6000602082840312156118ce57600080fd5b8151801515811461136657600080fd5b6000816118ed576118ed61179e565b50600019019056fea26469706673582212205d5773e13d7b0f39e380361b4b99065793b3a6e9016d55dfca68f752c424912064736f6c63430008110033
|
package/fetch-aria.js
ADDED
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
const https = require('https');
|
|
2
|
+
const fs = require('fs');
|
|
3
|
+
|
|
4
|
+
const address = '0x5d3a12c42e5372b2cc3264ab3cdcf660a1555238';
|
|
5
|
+
|
|
6
|
+
// Try to fetch from BSCScan using their read contract page
|
|
7
|
+
const url = `https://api.bscscan.com/api?module=contract&action=getsourcecode&address=${address}&apikey=YourApiKeyToken`;
|
|
8
|
+
|
|
9
|
+
https.get(url, (res) => {
|
|
10
|
+
let data = '';
|
|
11
|
+
res.on('data', (chunk) => data += chunk);
|
|
12
|
+
res.on('end', () => {
|
|
13
|
+
try {
|
|
14
|
+
const json = JSON.parse(data);
|
|
15
|
+
if (json.result && json.result[0] && json.result[0].SourceCode) {
|
|
16
|
+
let sourceCode = json.result[0].SourceCode;
|
|
17
|
+
|
|
18
|
+
// Handle multi-file format
|
|
19
|
+
if (sourceCode.startsWith('{{')) {
|
|
20
|
+
sourceCode = sourceCode.slice(1, -1);
|
|
21
|
+
const parsed = JSON.parse(sourceCode);
|
|
22
|
+
const sources = parsed.sources || {};
|
|
23
|
+
|
|
24
|
+
// Get the main contract file
|
|
25
|
+
const mainFile = Object.keys(sources).find(k => k.includes('ARIA') || k.includes('.sol'));
|
|
26
|
+
if (mainFile) {
|
|
27
|
+
sourceCode = sources[mainFile].content;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
fs.writeFileSync('ARIA_AI.sol', sourceCode);
|
|
32
|
+
console.log('Contract saved to ARIA_AI.sol');
|
|
33
|
+
console.log('Contract Name:', json.result[0].ContractName);
|
|
34
|
+
console.log('Compiler:', json.result[0].CompilerVersion);
|
|
35
|
+
} else {
|
|
36
|
+
console.log('No source code found or contract not verified');
|
|
37
|
+
console.log(JSON.stringify(json, null, 2));
|
|
38
|
+
}
|
|
39
|
+
} catch (e) {
|
|
40
|
+
console.error('Error:', e.message);
|
|
41
|
+
console.log('Raw response:', data);
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
}).on('error', (e) => {
|
|
45
|
+
console.error('Request error:', e.message);
|
|
46
|
+
});
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
const ethers = require('ethers');
|
|
2
|
+
|
|
3
|
+
const provider = new ethers.providers.JsonRpcProvider('https://bsc-dataseed.binance.org/');
|
|
4
|
+
|
|
5
|
+
async function fetchContract() {
|
|
6
|
+
const address = '0x79ebc9a2ce02277a4b5b3a768b1c0a4ed75bd936';
|
|
7
|
+
|
|
8
|
+
// Get bytecode
|
|
9
|
+
const code = await provider.getCode(address);
|
|
10
|
+
console.log('Contract bytecode length:', code.length);
|
|
11
|
+
|
|
12
|
+
// Try to get basic info
|
|
13
|
+
const contract = new ethers.Contract(address, [
|
|
14
|
+
'function name() view returns (string)',
|
|
15
|
+
'function symbol() view returns (string)',
|
|
16
|
+
'function decimals() view returns (uint8)',
|
|
17
|
+
'function totalSupply() view returns (uint256)',
|
|
18
|
+
'function owner() view returns (address)',
|
|
19
|
+
'function balanceOf(address) view returns (uint256)'
|
|
20
|
+
], provider);
|
|
21
|
+
|
|
22
|
+
try {
|
|
23
|
+
const name = await contract.name();
|
|
24
|
+
const symbol = await contract.symbol();
|
|
25
|
+
const decimals = await contract.decimals();
|
|
26
|
+
const totalSupply = await contract.totalSupply();
|
|
27
|
+
|
|
28
|
+
console.log('\nToken Info:');
|
|
29
|
+
console.log('Name:', name);
|
|
30
|
+
console.log('Symbol:', symbol);
|
|
31
|
+
console.log('Decimals:', decimals);
|
|
32
|
+
console.log('Total Supply:', ethers.utils.formatUnits(totalSupply, decimals));
|
|
33
|
+
|
|
34
|
+
try {
|
|
35
|
+
const owner = await contract.owner();
|
|
36
|
+
console.log('Owner:', owner);
|
|
37
|
+
} catch (e) {
|
|
38
|
+
console.log('No owner() function');
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
// Check contract's own balance
|
|
42
|
+
const contractBalance = await contract.balanceOf(address);
|
|
43
|
+
console.log('Contract balance:', ethers.utils.formatUnits(contractBalance, decimals));
|
|
44
|
+
|
|
45
|
+
} catch (error) {
|
|
46
|
+
console.error('Error fetching token info:', error.message);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
fetchContract();
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
const https = require('https');
|
|
2
|
+
const fs = require('fs');
|
|
3
|
+
|
|
4
|
+
const address = '0x6859ea44DC8E9A42222Ea1BC38ED74E8c8fe6DC7';
|
|
5
|
+
|
|
6
|
+
function fetchSource() {
|
|
7
|
+
const url = `https://api.etherscan.io/api?module=contract&action=getsourcecode&address=${address}`;
|
|
8
|
+
|
|
9
|
+
https.get(url, (res) => {
|
|
10
|
+
let data = '';
|
|
11
|
+
|
|
12
|
+
res.on('data', (chunk) => {
|
|
13
|
+
data += chunk;
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
res.on('end', () => {
|
|
17
|
+
try {
|
|
18
|
+
const json = JSON.parse(data);
|
|
19
|
+
|
|
20
|
+
if (json.status === '1' && json.result && json.result[0]) {
|
|
21
|
+
const result = json.result[0];
|
|
22
|
+
|
|
23
|
+
console.log('=== CONTRACT SOURCE CODE INFO ===\n');
|
|
24
|
+
console.log(`Contract Name: ${result.ContractName}`);
|
|
25
|
+
console.log(`Compiler Version: ${result.CompilerVersion}`);
|
|
26
|
+
console.log(`Optimization: ${result.OptimizationUsed === '1' ? 'Yes' : 'No'}`);
|
|
27
|
+
console.log(`Runs: ${result.Runs}`);
|
|
28
|
+
console.log(`License: ${result.LicenseType || 'None'}\n`);
|
|
29
|
+
|
|
30
|
+
if (result.SourceCode && result.SourceCode.length > 10) {
|
|
31
|
+
console.log('✅ Source code is verified!\n');
|
|
32
|
+
console.log(`Source code length: ${result.SourceCode.length} characters\n`);
|
|
33
|
+
|
|
34
|
+
// Save source code
|
|
35
|
+
let sourceCode = result.SourceCode;
|
|
36
|
+
|
|
37
|
+
// Handle multi-file format
|
|
38
|
+
if (sourceCode.startsWith('{{')) {
|
|
39
|
+
console.log('Multi-file source detected, extracting main contract...\n');
|
|
40
|
+
try {
|
|
41
|
+
// Remove outer braces
|
|
42
|
+
sourceCode = sourceCode.slice(1, -1);
|
|
43
|
+
const parsed = JSON.parse(sourceCode);
|
|
44
|
+
|
|
45
|
+
// Find main contract file
|
|
46
|
+
const sources = parsed.sources || {};
|
|
47
|
+
const mainFile = Object.keys(sources).find(k => k.includes(result.ContractName));
|
|
48
|
+
|
|
49
|
+
if (mainFile) {
|
|
50
|
+
sourceCode = sources[mainFile].content;
|
|
51
|
+
console.log(`Extracted from: ${mainFile}\n`);
|
|
52
|
+
} else {
|
|
53
|
+
// Just take first file
|
|
54
|
+
const firstFile = Object.keys(sources)[0];
|
|
55
|
+
sourceCode = sources[firstFile].content;
|
|
56
|
+
console.log(`Using first file: ${firstFile}\n`);
|
|
57
|
+
}
|
|
58
|
+
} catch (e) {
|
|
59
|
+
console.log('Could not parse multi-file format, using raw source\n');
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
fs.writeFileSync('sHEGIC.sol', sourceCode);
|
|
64
|
+
console.log('✅ Source code saved to sHEGIC.sol\n');
|
|
65
|
+
console.log('You can now run:');
|
|
66
|
+
console.log(' slither sHEGIC.sol');
|
|
67
|
+
console.log(' myth analyze sHEGIC.sol');
|
|
68
|
+
|
|
69
|
+
} else {
|
|
70
|
+
console.log('❌ Source code not verified on Etherscan');
|
|
71
|
+
}
|
|
72
|
+
} else {
|
|
73
|
+
console.log('❌ Error fetching source code');
|
|
74
|
+
console.log('Response:', json.message || json.result);
|
|
75
|
+
}
|
|
76
|
+
} catch (error) {
|
|
77
|
+
console.log('Error parsing response:', error.message);
|
|
78
|
+
console.log('Raw response:', data.substring(0, 500));
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
}).on('error', (error) => {
|
|
82
|
+
console.error('Request error:', error.message);
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
fetchSource();
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
const ethers = require('ethers');
|
|
2
|
+
|
|
3
|
+
const provider = new ethers.providers.JsonRpcProvider('https://bsc-dataseed.binance.org/');
|
|
4
|
+
|
|
5
|
+
async function fetchContract() {
|
|
6
|
+
const address = '0x1f39dd2bf5a27e2d4ed691dcf933077371777cb0';
|
|
7
|
+
|
|
8
|
+
// Get bytecode to verify it's a contract
|
|
9
|
+
const code = await provider.getCode(address);
|
|
10
|
+
console.log('Contract bytecode length:', code.length);
|
|
11
|
+
|
|
12
|
+
// Try to get contract info
|
|
13
|
+
const contract = new ethers.Contract(address, [
|
|
14
|
+
'function name() view returns (string)',
|
|
15
|
+
'function symbol() view returns (string)',
|
|
16
|
+
'function decimals() view returns (uint8)',
|
|
17
|
+
'function totalSupply() view returns (uint256)',
|
|
18
|
+
'function owner() view returns (address)',
|
|
19
|
+
], provider);
|
|
20
|
+
|
|
21
|
+
try {
|
|
22
|
+
const name = await contract.name();
|
|
23
|
+
const symbol = await contract.symbol();
|
|
24
|
+
const decimals = await contract.decimals();
|
|
25
|
+
const totalSupply = await contract.totalSupply();
|
|
26
|
+
|
|
27
|
+
console.log('\nToken Info:');
|
|
28
|
+
console.log('Name:', name);
|
|
29
|
+
console.log('Symbol:', symbol);
|
|
30
|
+
console.log('Decimals:', decimals);
|
|
31
|
+
console.log('Total Supply:', ethers.utils.formatUnits(totalSupply, decimals));
|
|
32
|
+
|
|
33
|
+
try {
|
|
34
|
+
const owner = await contract.owner();
|
|
35
|
+
console.log('Owner:', owner);
|
|
36
|
+
} catch (e) {
|
|
37
|
+
console.log('No owner() function');
|
|
38
|
+
}
|
|
39
|
+
} catch (error) {
|
|
40
|
+
console.error('Error fetching token info:', error.message);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
fetchContract();
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
const https = require('https');
|
|
2
|
+
const fs = require('fs');
|
|
3
|
+
|
|
4
|
+
const address = '0xe546f8f17aff17c05dac9f9b4f9957f725fab087';
|
|
5
|
+
|
|
6
|
+
// Try to fetch from Etherscan
|
|
7
|
+
const url = `https://etherscan.io/address/${address}#code`;
|
|
8
|
+
|
|
9
|
+
console.log('Fetching contract source from Etherscan...');
|
|
10
|
+
console.log(`URL: ${url}\n`);
|
|
11
|
+
|
|
12
|
+
// Since we can't easily scrape, let's try to get the bytecode and decompile
|
|
13
|
+
const { ethers } = require('ethers');
|
|
14
|
+
const provider = new ethers.providers.JsonRpcProvider('https://eth-mainnet.g.alchemy.com/v2/5IWkkFu-rS6plYHO9MLq-');
|
|
15
|
+
|
|
16
|
+
async function analyzeContract() {
|
|
17
|
+
const code = await provider.getCode(address);
|
|
18
|
+
|
|
19
|
+
console.log('Contract bytecode retrieved.');
|
|
20
|
+
console.log(`Length: ${code.length} bytes\n`);
|
|
21
|
+
|
|
22
|
+
// Check for common function signatures
|
|
23
|
+
const functionSigs = [
|
|
24
|
+
{ sig: '0x2e1a7d4d', name: 'withdraw(uint256)' },
|
|
25
|
+
{ sig: '0x3ccfd60b', name: 'withdraw()' },
|
|
26
|
+
{ sig: '0xa694fc3a', name: 'stake(uint256)' },
|
|
27
|
+
{ sig: '0x379607f5', name: 'claim()' },
|
|
28
|
+
{ sig: '0x4e71d92d', name: 'claim()' },
|
|
29
|
+
{ sig: '0x3d18b912', name: 'getReward()' },
|
|
30
|
+
{ sig: '0x441a3e70', name: 'unstake(uint256)' },
|
|
31
|
+
{ sig: '0x2def6620', name: 'unstake(uint256)' },
|
|
32
|
+
];
|
|
33
|
+
|
|
34
|
+
console.log('Checking for common staking functions:\n');
|
|
35
|
+
|
|
36
|
+
for (const func of functionSigs) {
|
|
37
|
+
if (code.includes(func.sig.slice(2))) {
|
|
38
|
+
console.log(`✓ Found: ${func.name} (${func.sig})`);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
console.log('\n=== ANALYSIS ===\n');
|
|
43
|
+
console.log('The contract holds 138,287 OIL tokens.');
|
|
44
|
+
console.log('To check for reentrancy, we need to see the source code.');
|
|
45
|
+
console.log('\nPlease manually check the contract at:');
|
|
46
|
+
console.log(`https://etherscan.io/address/${address}#code\n`);
|
|
47
|
+
console.log('Look for:');
|
|
48
|
+
console.log('1. Functions that call OIL.transfer() or OIL.transferAndCall()');
|
|
49
|
+
console.log('2. Whether state is updated BEFORE external calls (CEI pattern)');
|
|
50
|
+
console.log('3. Withdraw/unstake functions that might be vulnerable');
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
analyzeContract().catch(console.error);
|
package/fetch-tlm.js
ADDED
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
const https = require('https');
|
|
2
|
+
const fs = require('fs');
|
|
3
|
+
|
|
4
|
+
const options = {
|
|
5
|
+
hostname: 'bscscan.com',
|
|
6
|
+
path: '/address/0x2222227e22102fe3322098e4cbfe18cfebd57c95',
|
|
7
|
+
method: 'GET',
|
|
8
|
+
headers: {
|
|
9
|
+
'User-Agent': 'Mozilla/5.0'
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const req = https.request(options, (res) => {
|
|
14
|
+
let data = '';
|
|
15
|
+
res.on('data', (chunk) => { data += chunk; });
|
|
16
|
+
res.on('end', () => {
|
|
17
|
+
// Look for contract code link
|
|
18
|
+
const codeMatch = data.match(/href="([^"]*#code[^"]*)"/);
|
|
19
|
+
if (codeMatch) {
|
|
20
|
+
console.log('Found code tab, fetching...');
|
|
21
|
+
|
|
22
|
+
const codeOptions = {
|
|
23
|
+
hostname: 'bscscan.com',
|
|
24
|
+
path: '/address/0x2222227e22102fe3322098e4cbfe18cfebd57c95',
|
|
25
|
+
method: 'GET',
|
|
26
|
+
headers: {
|
|
27
|
+
'User-Agent': 'Mozilla/5.0',
|
|
28
|
+
'Accept': 'text/html'
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
https.request(codeOptions, (res2) => {
|
|
33
|
+
let html = '';
|
|
34
|
+
res2.on('data', (chunk) => { html += chunk; });
|
|
35
|
+
res2.on('end', () => {
|
|
36
|
+
// Try to extract contract source
|
|
37
|
+
const sourceMatch = html.match(/<pre[^>]*class="[^"]*js-sourcecopyarea[^"]*"[^>]*>([\s\S]*?)<\/pre>/);
|
|
38
|
+
if (sourceMatch) {
|
|
39
|
+
const source = sourceMatch[1]
|
|
40
|
+
.replace(/</g, '<')
|
|
41
|
+
.replace(/>/g, '>')
|
|
42
|
+
.replace(/&/g, '&')
|
|
43
|
+
.replace(/"/g, '"');
|
|
44
|
+
fs.writeFileSync('TLM.sol', source);
|
|
45
|
+
console.log('Contract saved to TLM.sol');
|
|
46
|
+
} else {
|
|
47
|
+
console.log('Could not find source code in HTML');
|
|
48
|
+
fs.writeFileSync('debug.html', html);
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
}).end();
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
req.on('error', (e) => {
|
|
57
|
+
console.error(e);
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
req.end();
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import re
|
|
2
|
+
|
|
3
|
+
# The source code is in the HTML we fetched
|
|
4
|
+
html_content = """
|
|
5
|
+
/**
|
|
6
|
+
|
|
7
|
+
ELEPHANT
|
|
8
|
+
|
|
9
|
+
#LIQ+#RFI+#SHIB+#DOGE+#SAFEMOON+#AUTOMATED+#FAIR+#LOCKED+#AUTOBALANCE#BANKROLL = #ELEPHANT
|
|
10
|
+
|
|
11
|
+
#ELEPHANT features:
|
|
12
|
+
1 Quadrillion Supply (that's 1 million billions; 10T = 1% of the supply)
|
|
13
|
+
5% to holders and 5% to liquidity on every transaction
|
|
14
|
+
100% automated deployer and liquidity fund raiser (no fees)
|
|
15
|
+
49% tokens sent to graveyard, 490T tokens (burn address with auto burn)
|
|
16
|
+
1% for development/marketing
|
|
17
|
+
25% to contract owned locked liquidity
|
|
18
|
+
25% to community via liquidity drive
|
|
19
|
+
100% of new liquidity is owned by the contract
|
|
20
|
+
50% of tokens autobalanced by graveyard to maintain volume for holders
|
|
21
|
+
IMMUTABLE VALUE
|
|
22
|
+
|
|
23
|
+
*/
|
|
24
|
+
|
|
25
|
+
pragma solidity ^0.6.8;
|
|
26
|
+
"""
|
|
27
|
+
|
|
28
|
+
# Write a minimal version for Slither
|
|
29
|
+
with open('ELEPHANT.sol', 'w') as f:
|
|
30
|
+
f.write(html_content)
|
|
31
|
+
|
|
32
|
+
print("Created minimal ELEPHANT.sol")
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
const { ethers } = require('ethers');
|
|
2
|
+
|
|
3
|
+
const RPC = 'https://bsc-dataseed.binance.org/';
|
|
4
|
+
const provider = new ethers.providers.JsonRpcProvider(RPC);
|
|
5
|
+
|
|
6
|
+
const CEEK_ADDRESS = '0xe0f94ac5462997d2bc57287ac3a3ae4c31345d66';
|
|
7
|
+
|
|
8
|
+
async function main() {
|
|
9
|
+
console.log('=== SEARCHING FOR CEEK STAKING CONTRACT ===\n');
|
|
10
|
+
|
|
11
|
+
// Common staking contract patterns
|
|
12
|
+
const possibleAddresses = [
|
|
13
|
+
// You need to provide the staking contract address
|
|
14
|
+
// Check CEEK's website or BSCScan for the staking contract
|
|
15
|
+
];
|
|
16
|
+
|
|
17
|
+
console.log('Please provide the CEEK staking contract address');
|
|
18
|
+
console.log('Check: https://ceek.com or BSCScan for contract interactions');
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
main().catch(console.error);
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
const { ethers } = require('ethers');
|
|
2
|
+
|
|
3
|
+
const RPC = 'https://bsc-dataseed.binance.org';
|
|
4
|
+
const provider = new ethers.providers.JsonRpcProvider(RPC);
|
|
5
|
+
|
|
6
|
+
const STAKING_CONTRACT = '0x107E5696fAc55207DFC05C071404C31CEc57d47A';
|
|
7
|
+
const REAL_USER = '0xc75124Cc9d40d7f53FB05B5f8CC13638EfD869fE';
|
|
8
|
+
const FARA_TOKEN = '0xF4Ed363144981D3A65f42e7D0DC54FF9EEf559A1';
|
|
9
|
+
|
|
10
|
+
async function findExploitTx() {
|
|
11
|
+
console.log('=== SEARCHING FOR EXPLOIT TRANSACTION ===\n');
|
|
12
|
+
|
|
13
|
+
// Search for Transfer events where user received 568 FARA
|
|
14
|
+
const targetAmount = ethers.utils.parseEther('568');
|
|
15
|
+
|
|
16
|
+
console.log('Looking for Transfer of ~568 FARA to:', REAL_USER);
|
|
17
|
+
console.log('Target amount:', targetAmount.toString());
|
|
18
|
+
|
|
19
|
+
// Get recent blocks to search
|
|
20
|
+
const currentBlock = await provider.getBlockNumber();
|
|
21
|
+
console.log('Current block:', currentBlock);
|
|
22
|
+
|
|
23
|
+
// Search backwards from current block
|
|
24
|
+
const blocksToSearch = 1000000; // Search last 1M blocks
|
|
25
|
+
const startBlock = currentBlock - blocksToSearch;
|
|
26
|
+
|
|
27
|
+
console.log(`Searching blocks ${startBlock} to ${currentBlock}...`);
|
|
28
|
+
|
|
29
|
+
// Transfer event signature
|
|
30
|
+
const transferTopic = ethers.utils.id('Transfer(address,address,uint256)');
|
|
31
|
+
|
|
32
|
+
try {
|
|
33
|
+
const logs = await provider.getLogs({
|
|
34
|
+
address: FARA_TOKEN,
|
|
35
|
+
topics: [
|
|
36
|
+
transferTopic,
|
|
37
|
+
null, // from (any)
|
|
38
|
+
ethers.utils.hexZeroPad(REAL_USER, 32) // to (real user)
|
|
39
|
+
],
|
|
40
|
+
fromBlock: startBlock,
|
|
41
|
+
toBlock: currentBlock
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
console.log(`\nFound ${logs.length} Transfer events to user`);
|
|
45
|
+
|
|
46
|
+
// Filter for ~568 FARA transfers
|
|
47
|
+
for (const log of logs) {
|
|
48
|
+
const amount = BigInt(log.data);
|
|
49
|
+
const amountEther = Number(ethers.utils.formatEther(amount));
|
|
50
|
+
|
|
51
|
+
if (amountEther > 500 && amountEther < 600) {
|
|
52
|
+
console.log('\n=== FOUND POTENTIAL EXPLOIT TX ===');
|
|
53
|
+
console.log('Block:', log.blockNumber);
|
|
54
|
+
console.log('TxHash:', log.transactionHash);
|
|
55
|
+
console.log('Amount:', amountEther, 'FARA');
|
|
56
|
+
|
|
57
|
+
// Get the full transaction
|
|
58
|
+
const tx = await provider.getTransaction(log.transactionHash);
|
|
59
|
+
console.log('\nTransaction details:');
|
|
60
|
+
console.log('From:', tx.from);
|
|
61
|
+
console.log('To:', tx.to);
|
|
62
|
+
console.log('Data:', tx.data);
|
|
63
|
+
console.log('Value:', tx.value.toString());
|
|
64
|
+
|
|
65
|
+
// Decode the function call
|
|
66
|
+
if (tx.data.length >= 10) {
|
|
67
|
+
const funcSig = tx.data.slice(0, 10);
|
|
68
|
+
console.log('Function signature:', funcSig);
|
|
69
|
+
|
|
70
|
+
// Try to decode parameters
|
|
71
|
+
if (tx.data.length > 10) {
|
|
72
|
+
const params = tx.data.slice(10);
|
|
73
|
+
console.log('Parameters (hex):', params);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
// Get block timestamp
|
|
78
|
+
const block = await provider.getBlock(log.blockNumber);
|
|
79
|
+
console.log('Block timestamp:', block.timestamp);
|
|
80
|
+
console.log('Block date:', new Date(block.timestamp * 1000).toISOString());
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
} catch (e) {
|
|
84
|
+
console.error('Error searching logs:', e.message);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
findExploitTx().catch(console.error);
|