forked from czbag/zksync
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.py
154 lines (127 loc) · 6 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
import random
import sys
import questionary
from loguru import logger
from questionary import Choice
from config import ACCOUNTS, PROXIES
from utils.helpers import get_run_accounts, update_run_accounts
from settings import USE_PROXY, RANDOM_WALLET, SLEEP_FROM, SLEEP_TO, QUANTITY_RUN_ACCOUNTS
from modules_settings import *
def get_module():
result = questionary.select(
"Select a method to get started",
choices=[
Choice("1) Make bridge ZkSync", bridge_zksync),
Choice("2) Make withdraw from ZkSync", withdraw_zksync),
Choice("3) Make bridge on Orbiter", bridge_orbiter),
Choice("4) Wrap ETH", wrap_eth),
Choice("5) Unwrap ETH", unwrap_eth),
Choice("6) Make swap on SyncSwap", swap_syncswap),
Choice("7) Add liquidity on SyncSwap", liquidity_syncswap),
Choice("8) Make swap on Mute", swap_mute),
Choice("9) Make swap on Space.fi", swap_spacefi),
Choice("10) Add liquidity on Space.fi", liquidity_spacefi),
Choice("11) Make swap on PancakeSwap", swap_pancake),
Choice("12) Make swap on WooFi", swap_woofi),
Choice("13) Make swap on Odos", swap_odos),
Choice("14) Make swap on ZkSwap", swap_zkswap),
Choice("15) Make swap on XYSwap", swap_xyswap),
Choice("16) Make swap on OpenOcean", swap_openocean),
Choice("17) Make swap on 1inch", swap_inch),
Choice("18) Make swap on Maverick", swap_maverick),
Choice("19) Make swap on VeSync", swap_vesync),
Choice("20) Make bungee refuel", bungee_refuel),
Choice("21) Stargate bridge MAV", stargate_bridge),
Choice("22) Deposit Eralend", deposit_eralend),
Choice("23) Withdraw Eralend", withdraw_erlaned),
Choice("24) Enable collateral on Eralend", enable_collateral_eralend),
Choice("25) Disable collateral on Eralend", disable_collateral_eralend),
Choice("26) Deposit Basilisk", deposit_basilisk),
Choice("27) Withdraw Basilisk", withdraw_basilisk),
Choice("28) Enable collateral on Basilisk", enable_collateral_basilisk),
Choice("29) Disable collateral on Basilisk", disable_collateral_basilisk),
Choice("30) Deposit ReactorFusion", deposit_reactorfusion),
Choice("31) Withdraw ReactorFusion", withdraw_reactorfusion),
Choice("32) Enable collateral on ReactorFusion", enable_collateral_reactorfusion),
Choice("33) Disable collateral on ReactorFusion", disable_collateral_reactorfusion),
Choice("34) Deposit ZeroLend", deposit_zerolend),
Choice("35) Withdraw ZeroLend", withdraw_zerolend),
Choice("36) Create NFT collection on Omnisea", create_omnisea),
Choice("37) Mint and bridge NFT L2Telegraph", bridge_nft),
Choice("38) Mint Tavaera ID + NFT", mint_tavaera),
Choice("39) Mint MailZero NFT", mint_mailzero_nft),
Choice("40) Mint NFT on NFTS2ME", mint_nft),
Choice("41) Mint ZKS Domain", mint_zks_domain),
Choice("42) Mint Era Domain", mint_era_domain),
Choice("43) Send message L2Telegraph", send_message),
Choice("44) Dmail sending mail", send_mail),
Choice("45) Create gnosis safe", create_safe),
Choice("46) Swap tokens to ETH", swap_tokens),
Choice("47) MultiSwap", swap_multiswap),
Choice("48) Use custom routes", custom_routes),
Choice("49) MultiApprove", multi_approve),
Choice("50) Check transaction count", "tx_checker"),
Choice("51) Exit", "exit"),
],
qmark="⚙️ ",
pointer="✅ "
).ask()
if result == "exit":
print("\n❤️ Subscribe to me – https://t.me/sybilwave\n")
print("🤑 Donate me: 0x00000b0ddce0bfda4531542ad1f2f5fad7b9cde9")
sys.exit()
return result
def get_wallets():
if USE_PROXY:
account_with_proxy = dict(zip(ACCOUNTS, PROXIES))
wallets = [
{
"id": _id,
"key": key,
"proxy": account_with_proxy[key]
} for _id, key in enumerate(account_with_proxy, start=1)
]
else:
wallets = [
{
"id": _id,
"key": key,
"proxy": None
} for _id, key in enumerate(ACCOUNTS, start=1)
]
return wallets
async def run_module(module, account_id, key, proxy, sleep_time, start_id):
if start_id != 1:
await asyncio.sleep(sleep_time)
while True:
run_accounts = get_run_accounts()
if len(run_accounts["accounts"]) < QUANTITY_RUN_ACCOUNTS:
update_run_accounts(account_id, "add")
await module(account_id, key, proxy)
update_run_accounts(account_id, "remove")
break
else:
logger.info(f'Current run accounts: {len(run_accounts["accounts"])}')
await asyncio.sleep(60)
async def main(module):
wallets = get_wallets()
tasks = []
if RANDOM_WALLET:
random.shuffle(wallets)
sleep_time = random.randint(SLEEP_FROM, SLEEP_TO)
for _, account in enumerate(wallets, start=1):
tasks.append(asyncio.create_task(
run_module(module, account["id"], account["key"], account["proxy"], sleep_time, _)
))
sleep_time += random.randint(SLEEP_FROM, SLEEP_TO)
await asyncio.gather(*tasks)
if __name__ == '__main__':
print("❤️ Subscribe to me – https://t.me/sybilwave\n")
update_run_accounts(0, "new")
module = get_module()
if module == "tx_checker":
get_tx_count()
else:
asyncio.run(main(module))
print("\n❤️ Subscribe to me – https://t.me/sybilwave\n")
print("🤑 Donate me: 0x00000b0ddce0bfda4531542ad1f2f5fad7b9cde9")