forked from czbag/scroll
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.py
121 lines (99 loc) · 3.67 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
import random
import sys
import time
from concurrent.futures import ThreadPoolExecutor
import questionary
from loguru import logger
from questionary import Choice
from config import ACCOUNTS
from settings import (
RANDOM_WALLET,
SLEEP_TO,
SLEEP_FROM,
QUANTITY_THREADS,
THREAD_SLEEP_FROM,
THREAD_SLEEP_TO, REMOVE_WALLET
)
from modules_settings import *
from utils.helpers import remove_wallet
from utils.sleeping import sleep
def get_module():
result = questionary.select(
"Select a method to get started",
choices=[
Choice("1) Deposit to Scroll", deposit_scroll),
Choice("2) Withdraw from Scroll", withdraw_scroll),
Choice("3) Bridge Orbiter", bridge_orbiter),
Choice("4) Bridge Layerswap", bridge_layerswap),
Choice("5) Wrap ETH", wrap_eth),
Choice("6) Unwrap ETH", unwrap_eth),
Choice("7) Swap on Skydrome", swap_skydrome),
Choice("8) Swap on Zebra", swap_zebra),
Choice("9) Swap on SyncSwap", swap_syncswap),
Choice("10) Deposit LayerBank", deposit_layerbank),
Choice("11) Withdraw LayerBank", withdraw_layerbank),
Choice("12) Deposit RocketSam", deposit_rocketsam),
Choice("13) Withdraw RocketSam", withdraw_rocketsam),
Choice("14) Mint and Bridge Zerius NFT", mint_zerius),
Choice("15) Mint ZkStars NFT", mint_zkstars),
Choice("16) Create NFT collection on Omnisea", create_omnisea),
Choice("17) Mint NFT on NFTS2ME", mint_nft),
Choice("18) Mint Scroll Origins NFT", nft_origins),
Choice("19) Dmail send email", send_mail),
Choice("20) Create gnosis safe", create_safe),
Choice("21) Deploy contract", deploy_contract),
Choice("22) Swap tokens to ETH", swap_tokens),
Choice("23) Use Multiswap", swap_multiswap),
Choice("24) Use custom routes", custom_routes),
Choice("25) Check transaction count", "tx_checker"),
Choice("26) 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():
wallets = [
{
"id": _id,
"key": key,
} for _id, key in enumerate(ACCOUNTS, start=1)
]
return wallets
async def run_module(module, account_id, key):
try:
await module(account_id, key)
except Exception as e:
logger.error(e)
if REMOVE_WALLET:
remove_wallet(key)
await sleep(SLEEP_FROM, SLEEP_TO)
def _async_run_module(module, account_id, key):
asyncio.run(run_module(module, account_id, key))
def main(module):
wallets = get_wallets()
if RANDOM_WALLET:
random.shuffle(wallets)
with ThreadPoolExecutor(max_workers=QUANTITY_THREADS) as executor:
for _, account in enumerate(wallets, start=1):
executor.submit(
_async_run_module,
module,
account.get("id"),
account.get("key"),
)
time.sleep(random.randint(THREAD_SLEEP_FROM, THREAD_SLEEP_TO))
if __name__ == '__main__':
print("❤️ Subscribe to me – https://t.me/sybilwave\n")
logger.add("logging.log")
module = get_module()
if module == "tx_checker":
get_tx_count()
else:
main(module)
print("\n❤️ Subscribe to me – https://t.me/sybilwave\n")
print("🤑 Donate me: 0x00000b0ddce0bfda4531542ad1f2f5fad7b9cde9")