forked from manuelwils/Astra
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathadd.py
284 lines (268 loc) · 10.3 KB
/
add.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
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
'''
=============SON OF GENISYS=====================
Astra members adding script
Coded by a dumbass kid- github.com/Cryptonian007
Apologies if anything in the code is dumb :)
Copy with credits
************************************************
'''
# import libraries
from telethon.sync import TelegramClient
from telethon.tl.types import InputPeerChannel
from telethon.errors.rpcerrorlist import PeerFloodError, UserPrivacyRestrictedError, PhoneNumberBannedError, ChatAdminRequiredError
from telethon.errors.rpcerrorlist import ChatWriteForbiddenError, UserBannedInChannelError, UserAlreadyParticipantError, FloodWaitError
from telethon.tl.functions.channels import InviteToChannelRequest
import sys
from telethon.tl.functions.messages import ImportChatInviteRequest, AddChatUserRequest
from telethon.tl.functions.channels import JoinChannelRequest
from telethon.tl.types import UserStatusRecently
import time
import random
from colorama import init, Fore
import os
import pickle
init()
r = Fore.RED
lg = Fore.GREEN
rs = Fore.RESET
w = Fore.WHITE
grey = '\033[97m'
cy = Fore.CYAN
ye = Fore.YELLOW
colors = [r, lg, w, ye, cy]
info = lg + '[' + w + 'i' + lg + ']' + rs
error = lg + '[' + r + '!' + lg + ']' + rs
success = w + '[' + lg + '*' + w + ']' + rs
INPUT = lg + '[' + cy + '~' + lg + ']' + rs
plus = w + '[' + lg + '+' + w + ']' + rs
minus = w + '[' + lg + '-' + w + ']' + rs
def banner():
# fancy logo
b = [
' _____ __',
' / _ \ _______/ |_____________',
' / /_\ \ / ___/\ __\_ __ \__ \\',
'/ | \ \___ \ | | | | \// __ \_',
'\____|__ /____ > |__| |__| (____ /',
' \/ \/ \/'
]
for char in b:
print(f'{random.choice(colors)}{char}{rs}')
#print('=============SON OF GENISYS==============')
print(f'{lg} Version: {w}1.2{lg} | Author: {w}Cryptonian{rs}\n')
# function to clear screen
def clr():
if os.name == 'nt':
os.system('cls')
else:
os.system('clear')
accounts = []
f = open('vars.txt', 'rb')
while True:
try:
accounts.append(pickle.load(f))
except EOFError:
break
# create sessions(if any) and check for any banned accounts
# TODO: Remove code input(just to check if an account is banned)
print('\n' + info + lg + ' Checking for banned accounts...' + rs)
for a in accounts:
phn = a[0]
print(f'{plus}{grey} Checking {lg}{phn}')
clnt = TelegramClient(f'sessions/{phn}', 3910389, '86f861352f0ab76a251866059a6adbd6')
clnt.connect()
banned = []
if not clnt.is_user_authorized():
try:
clnt.send_code_request(phn)
print('OK')
except PhoneNumberBannedError:
print(f'{error} {w}{phn} {r}is banned!{rs}')
banned.append(a)
for z in banned:
accounts.remove(z)
print(info+lg+' Banned account removed[Remove permanently using manager.py]'+rs)
time.sleep(0.5)
clnt.disconnect()
print(info+' Sessions created!')
clr()
banner()
# func to log scraping details(link of the grp to scrape
# and current index) in order to resume later
def log_status(scraped, index):
with open('status.dat', 'wb') as f:
pickle.dump([scraped, int(index)], f)
f.close()
print(f'{info}{lg} Session stored in {w}status.dat{lg}')
def exit_window():
input(f'\n{cy} Press enter to exit...')
clr()
banner()
sys.exit()
# read user details
try:
# rquest to resume adding
with open('status.dat', 'rb') as f:
status = pickle.load(f)
f.close()
lol = input(f'{INPUT}{cy} Resume scraping members from {w}{status[0]}{lg}? [y/n]: {r}')
if 'y' in lol:
scraped_grp = status[0] ; index = int(status[1])
else:
if os.name == 'nt':
os.system('del status.dat')
else:
os.system('rm status.dat')
scraped_grp = input(f'{INPUT}{cy} Public/Private group link to scrape members: {r}')
index = 0
except:
scraped_grp = input(f'{INPUT}{cy} Public/Private group link to scrape members: {r}')
index = 0
# load all the accounts(phonenumbers)
accounts = []
f = open('vars.txt', 'rb')
while True:
try:
accounts.append(pickle.load(f))
except EOFError:
break
print(f'{info}{lg} Total accounts: {w}{len(accounts)}')
number_of_accs = int(input(f'{INPUT}{cy} Enter number of accounts to use: {r}'))
print(f'{info}{cy} Choose an option{lg}')
print(f'{cy}[0]{lg} Add to public group')
print(f'{cy}[1]{lg} Add to private group')
choice = int(input(f'{INPUT}{cy} Enter choice: {r}'))
if choice == 0:
target = str(input(f'{INPUT}{cy} Enter public group link: {r}'))
else:
target = str(input(f'{INPUT}{cy} Enter private group link: {r}'))
print(f'{grey}_'*50)
#status_choice = str(input(f'{INPUT}{cy} Do you wanna add active members?[y/n]: {r}'))
to_use = [x for x in accounts[:number_of_accs]]
for l in to_use: accounts.remove(l)
with open('vars.txt', 'wb') as f:
for a in accounts:
pickle.dump(a, f)
for ab in to_use:
pickle.dump(ab, f)
f.close()
sleep_time = int(input(f'{INPUT}{cy} Enter delay time per request{w}[{lg}0 for None{w}]: {r}'))
#print(f'{info}{lg} Joining group from {w}{number_of_accs} accounts...')
#print(f'{grey}-'*50)
print(f'{success}{lg} -- Adding members from {w}{len(to_use)}{lg} account(s) --')
adding_status = 0
approx_members_count = 0
for acc in to_use:
stop = index + 60
c = TelegramClient(f'sessions/{acc[0]}', 3910389 , '86f861352f0ab76a251866059a6adbd6')
print(f'{plus}{grey} User: {cy}{acc[0]}{lg} -- {cy}Starting session... ')
c.start(acc[0])
acc_name = c.get_me().first_name
try:
if '/joinchat/' in scraped_grp:
g_hash = scraped_grp.split('/joinchat/')[1]
try:
c(ImportChatInviteRequest(g_hash))
print(f'{plus}{grey} User: {cy}{acc_name}{lg} -- Joined group to scrape')
except UserAlreadyParticipantError:
pass
else:
c(JoinChannelRequest(scraped_grp))
print(f'{plus}{grey} User: {cy}{acc_name}{lg} -- Joined group to scrape')
scraped_grp_entity = c.get_entity(scraped_grp)
if choice == 0:
c(JoinChannelRequest(target))
print(f'{plus}{grey} User: {cy}{acc_name}{lg} -- Joined group to add')
target_entity = c.get_entity(target)
target_details = InputPeerChannel(target_entity.id, target_entity.access_hash)
else:
try:
grp_hash = target.split('/joinchat/')[1]
c(ImportChatInviteRequest(grp_hash))
print(f'{plus}{grey} User: {cy}{acc_name}{lg} -- Joined group to add')
except UserAlreadyParticipantError:
pass
target_entity = c.get_entity(target)
target_details = target_entity
except Exception as e:
print(f'{error}{r} User: {cy}{acc_name}{lg} -- Failed to join group')
print(f'{error} {r}{e}')
continue
print(f'{plus}{grey} User: {cy}{acc_name}{lg} -- {cy}Retrieving entities...')
#c.get_dialogs()
try:
members = []
members = c.get_participants(scraped_grp_entity, aggressive=True)
except Exception as e:
print(f'{error}{r} Couldn\'t scrape members')
print(f'{error}{r} {e}')
continue
approx_members_count = len(members)
assert approx_members_count != 0
if index >= approx_members_count:
print(f'{error}{lg} No members to add!')
continue
print(f'{info}{lg} Start: {w}{index}')
#adding_status = 0
peer_flood_status = 0
for user in members[index:stop]:
index += 1
if peer_flood_status == 10:
print(f'{error}{r} Too many Peer Flood Errors! Closing session...')
break
try:
if choice == 0:
c(InviteToChannelRequest(target_details, [user]))
else:
c(AddChatUserRequest(target_details.id, user, 42))
user_id = user.first_name
target_title = target_entity.title
print(f'{plus}{grey} User: {cy}{acc_name}{lg} -- {cy}{user_id} {lg}--> {cy}{target_title}')
#print(f'{info}{grey} User: {cy}{acc_name}{lg} -- Sleep 1 second')
adding_status += 1
print(f'{info}{grey} User: {cy}{acc_name}{lg} -- Sleep {w}{sleep_time} {lg}second(s)')
time.sleep(sleep_time)
except UserPrivacyRestrictedError:
print(f'{minus}{grey} User: {cy}{acc_name}{lg} -- {r}User Privacy Restricted Error')
continue
except PeerFloodError:
print(f'{error}{grey} User: {cy}{acc_name}{lg} -- {r}Peer Flood Error.')
peer_flood_status += 1
continue
except ChatWriteForbiddenError:
print(f'{error}{r} Can\'t add to group. Contact group admin to enable members adding')
if index < approx_members_count:
log_status(scraped_grp, index)
exit_window()
except UserBannedInChannelError:
print(f'{error}{grey} User: {cy}{acc_name}{lg} -- {r}Banned from writing in groups')
break
except ChatAdminRequiredError:
print(f'{error}{grey} User: {cy}{acc_name}{lg} -- {r}Chat Admin rights needed to add')
break
except UserAlreadyParticipantError:
print(f'{minus}{grey} User: {cy}{acc_name}{lg} -- {r}User is already a participant')
continue
except FloodWaitError as e:
print(f'{error}{r} {e}')
break
except ValueError:
print(f'{error}{r} Error in Entity')
continue
except KeyboardInterrupt:
print(f'{error}{r} ---- Adding Terminated ----')
if index < len(members):
log_status(scraped_grp, index)
exit_window()
except Exception as e:
print(f'{error} {e}')
continue
#global adding_status, approx_members_count
if adding_status != 0:
print(f"\n{info}{lg} Adding session ended")
try:
if index < approx_members_count:
log_status(scraped_grp, index)
exit_window()
except:
exit_window()