generated from justuser-31/mrl_v1_license
Добавление телеграм бота для регистрации
This commit is contained in:
parent
19703b2490
commit
3ba1ccf8e8
@ -78,5 +78,5 @@ def delete_account(api_url: str, api_token: str, username: str) -> dict:
|
||||
|
||||
|
||||
# print(set_quota("http://proxy.del.pw:50020", "test", "test", 1000))
|
||||
# print(delete_account("http://proxy.del.pw:50020", "test", "test"))
|
||||
# print(create_account("http://proxy.del.pw:50020", "test", "test", "test", 100))
|
||||
# print(delete_account("http://127.0.0.1:8000", "test", "test"))
|
||||
# print(create_account("http://127.0.0.1:8000", "test", "test", "test", 999))
|
||||
@ -1,2 +1,3 @@
|
||||
PyYAML
|
||||
requests
|
||||
pyTelegramBotAPI
|
||||
|
||||
1
telegram_bot/.gitignore
vendored
Normal file
1
telegram_bot/.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
||||
*.json
|
||||
82
telegram_bot/call2api.py
Normal file
82
telegram_bot/call2api.py
Normal file
@ -0,0 +1,82 @@
|
||||
import requests
|
||||
|
||||
|
||||
def create_account(
|
||||
api_url: str, api_token: str, username: str, password: str, drive_quota: int
|
||||
) -> dict:
|
||||
"""
|
||||
Call the create account API endpoint.
|
||||
|
||||
Args:
|
||||
api_url: Base URL of the API server (e.g., 'http://localhost:8000')
|
||||
api_token: Security token for API authentication
|
||||
username: Username for the new account
|
||||
password: Password for the new account
|
||||
drive_quota: Storage quota in MB
|
||||
|
||||
Returns:
|
||||
Dictionary with 'status_code' and 'message' keys
|
||||
"""
|
||||
url = f"{api_url.rstrip('/')}/create_account"
|
||||
data = {
|
||||
"token": api_token,
|
||||
"username": username,
|
||||
"password": password,
|
||||
"drive_quota": str(drive_quota),
|
||||
}
|
||||
|
||||
try:
|
||||
response = requests.post(url, data=data)
|
||||
return {"status_code": response.status_code, "message": response.text}
|
||||
except requests.RequestException as e:
|
||||
return {"status_code": -1, "message": f"Request failed: {str(e)}"}
|
||||
|
||||
|
||||
def set_quota(api_url: str, api_token: str, username: str, drive_quota: int) -> dict:
|
||||
"""
|
||||
Call the set quota API endpoint.
|
||||
|
||||
Args:
|
||||
api_url: Base URL of the API server (e.g., 'http://localhost:8000')
|
||||
api_token: Security token for API authentication
|
||||
username: Username whose quota should be updated
|
||||
drive_quota: New storage quota in MB
|
||||
|
||||
Returns:
|
||||
Dictionary with 'status_code' and 'message' keys
|
||||
"""
|
||||
url = f"{api_url.rstrip('/')}/set_quota"
|
||||
data = {"token": api_token, "username": username, "drive_quota": str(drive_quota)}
|
||||
|
||||
try:
|
||||
response = requests.post(url, data=data)
|
||||
return {"status_code": response.status_code, "message": response.text}
|
||||
except requests.RequestException as e:
|
||||
return {"status_code": -1, "message": f"Request failed: {str(e)}"}
|
||||
|
||||
|
||||
def delete_account(api_url: str, api_token: str, username: str) -> dict:
|
||||
"""
|
||||
Call the delete account API endpoint.
|
||||
|
||||
Args:
|
||||
api_url: Base URL of the API server (e.g., 'http://localhost:8000')
|
||||
api_token: Security token for API authentication
|
||||
username: Username of the account to delete
|
||||
|
||||
Returns:
|
||||
Dictionary with 'status_code' and 'message' keys
|
||||
"""
|
||||
url = f"{api_url.rstrip('/')}/delete_account"
|
||||
data = {"token": api_token, "username": username}
|
||||
|
||||
try:
|
||||
response = requests.post(url, data=data)
|
||||
return {"status_code": response.status_code, "message": response.text}
|
||||
except requests.RequestException as e:
|
||||
return {"status_code": -1, "message": f"Request failed: {str(e)}"}
|
||||
|
||||
|
||||
# print(set_quota("http://proxy.del.pw:50020", "test", "test", 1000))
|
||||
# print(delete_account("http://127.0.0.1:8000", "test", "test"))
|
||||
# print(create_account("http://127.0.0.1:8000", "test", "test", "test", 999))
|
||||
203
telegram_bot/sfs_bot.py
Normal file
203
telegram_bot/sfs_bot.py
Normal file
@ -0,0 +1,203 @@
|
||||
import json
|
||||
import os
|
||||
import random
|
||||
import string
|
||||
|
||||
import telebot
|
||||
|
||||
from call2api import create_account, delete_account
|
||||
|
||||
# Load configuration
|
||||
CONFIG_FILE = "config.json"
|
||||
if not os.path.exists(CONFIG_FILE):
|
||||
with open(CONFIG_FILE, "w") as f:
|
||||
f.write("""{
|
||||
"bot_token": "YOUR_BOT_TOKEN_HERE",
|
||||
"chat_id": 1111,
|
||||
"api_url": "http://localhost:8000",
|
||||
"api_token": "YOUR_API_TOKEN_HERE",
|
||||
"drive_quota": 100
|
||||
}""")
|
||||
raise FileNotFoundError(f"Configuration file {CONFIG_FILE} not found")
|
||||
|
||||
with open(CONFIG_FILE, "r") as f:
|
||||
config = json.load(f)
|
||||
|
||||
# Bot configuration
|
||||
BOT_TOKEN = config.get("bot_token")
|
||||
CHAT_ID = config.get("chat_id", 1111)
|
||||
API_URL = config.get("api_url")
|
||||
API_TOKEN = config.get("api_token")
|
||||
DRIVE_QUOTA = config.get("drive_quota", 100)
|
||||
|
||||
# Initialize bot
|
||||
bot = telebot.TeleBot(BOT_TOKEN)
|
||||
|
||||
|
||||
# Load user registrations
|
||||
def load_registrations():
|
||||
if os.path.exists("registrations.json"):
|
||||
with open("registrations.json", "r") as f:
|
||||
return json.load(f)
|
||||
return {}
|
||||
|
||||
|
||||
# Save user registrations
|
||||
def save_registrations(registrations):
|
||||
with open("registrations.json", "w") as f:
|
||||
json.dump(registrations, f, indent=2)
|
||||
|
||||
|
||||
# Generate random password
|
||||
def generate_password(length=20):
|
||||
characters = string.ascii_letters + string.digits
|
||||
return "".join(random.choice(characters) for _ in range(length))
|
||||
|
||||
|
||||
# Generate registration token
|
||||
def generate_registration_token(length=20):
|
||||
characters = string.ascii_letters + string.digits
|
||||
return "".join(random.choice(characters) for _ in range(length))
|
||||
|
||||
|
||||
# Store pending registrations
|
||||
global pending_registrations
|
||||
pending_registrations = {}
|
||||
|
||||
|
||||
@bot.message_handler(commands=["reg_sfs"])
|
||||
def register_user(message):
|
||||
user_id = str(message.from_user.id)
|
||||
chat_id = message.chat.id
|
||||
|
||||
# Check if this is private messages
|
||||
if message.chat.type == "private":
|
||||
complete_registration(message)
|
||||
return
|
||||
# Check if command was sent in the correct chat
|
||||
if chat_id != CHAT_ID:
|
||||
bot.reply_to(message, "Please use this command in the designated chat.")
|
||||
return
|
||||
|
||||
# Load current registrations
|
||||
registrations = load_registrations()
|
||||
|
||||
# Check if user is already registered
|
||||
if user_id in registrations:
|
||||
bot.reply_to(message, "You are already registered!")
|
||||
return
|
||||
|
||||
# Generate registration token and store it
|
||||
reg_token = generate_registration_token()
|
||||
global pending_registrations
|
||||
pending_registrations[user_id] = reg_token
|
||||
|
||||
# Send instruction to user
|
||||
instruction_msg = (
|
||||
f"To complete registration, type in bot's private messages:\n"
|
||||
f"`/reg_sfs {reg_token} YOUR_USERNAME`"
|
||||
)
|
||||
bot.reply_to(message, instruction_msg, parse_mode="Markdown")
|
||||
|
||||
|
||||
def complete_registration(message):
|
||||
global pending_registrations
|
||||
user_id = str(message.from_user.id)
|
||||
chat_type = message.chat.type
|
||||
|
||||
# Registration must happen in private chat
|
||||
if chat_type != "private":
|
||||
return
|
||||
|
||||
# Check if user has initiated registration
|
||||
if user_id not in pending_registrations:
|
||||
bot.reply_to(
|
||||
message, "Please start registration in the group chat first using /reg_sfs"
|
||||
)
|
||||
return
|
||||
|
||||
parts = message.text.split()
|
||||
if len(parts) != 3:
|
||||
bot.reply_to(
|
||||
message,
|
||||
"Invalid format. Use: `/reg_sfs TOKEN USERNAME`",
|
||||
parse_mode="Markdown",
|
||||
)
|
||||
return
|
||||
|
||||
_, provided_token, username = parts
|
||||
|
||||
# Verify token
|
||||
if pending_registrations[user_id] != provided_token:
|
||||
bot.reply_to(message, "Invalid registration token.")
|
||||
return
|
||||
|
||||
# Generate password
|
||||
password = generate_password()
|
||||
|
||||
if username == "YOUR_USERNAME":
|
||||
bot.reply_to(
|
||||
message,
|
||||
"You should use own username instead example `YOUR_USERNAME`.",
|
||||
parse_mode="Markdown",
|
||||
)
|
||||
return
|
||||
|
||||
# Create account via API
|
||||
result = create_account(API_URL, API_TOKEN, username, password, DRIVE_QUOTA)
|
||||
|
||||
if result["status_code"] == 200:
|
||||
# Save registration
|
||||
registrations = load_registrations()
|
||||
registrations[user_id] = username
|
||||
registrations[username] = user_id
|
||||
save_registrations(registrations)
|
||||
|
||||
# Remove pending registration
|
||||
del pending_registrations[user_id]
|
||||
|
||||
# Send success message
|
||||
success_msg = (
|
||||
f"Successful registration:\nUsername: `{username}`\nPassword: `{password}`"
|
||||
)
|
||||
bot.reply_to(message, success_msg, parse_mode="Markdown")
|
||||
else:
|
||||
bot.reply_to(
|
||||
message,
|
||||
f"Registration failed: <code>{result['message']}</code>",
|
||||
parse_mode="HTML",
|
||||
)
|
||||
|
||||
|
||||
@bot.message_handler(content_types=["left_chat_member"])
|
||||
def handle_user_leave(message):
|
||||
user_id = str(message.left_chat_member.id)
|
||||
|
||||
# Load registrations
|
||||
registrations = load_registrations()
|
||||
|
||||
# Check if user was registered
|
||||
if user_id in registrations:
|
||||
username = registrations[user_id]
|
||||
|
||||
# Delete account via API
|
||||
result = delete_account(API_URL, API_TOKEN, username)
|
||||
|
||||
# Remove registration
|
||||
del registrations[user_id]
|
||||
if username in registrations:
|
||||
del registrations[username]
|
||||
save_registrations(registrations)
|
||||
|
||||
# Notify in chat if deletion was successful
|
||||
if result["status_code"] == 200:
|
||||
bot.send_message(CHAT_ID, f"Account for {username} has been deleted.")
|
||||
else:
|
||||
bot.send_message(
|
||||
CHAT_ID, f"Failed to delete account for {username}: {result['message']}"
|
||||
)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
print("SFS Bot started...")
|
||||
bot.polling(none_stop=True)
|
||||
Loading…
Reference in New Issue
Block a user