added set admin function
This commit is contained in:
parent
2ed419713b
commit
03c02aaabc
@ -37,6 +37,7 @@ class API_Handler:
|
||||
set_portfolio(user_id, portfolio): sets the portfolio of the user
|
||||
delete_portfolio(user_id, portfolio): deletes the portfolio of the user
|
||||
set_cron_interval(user_id, interval): sets the cron interval of the user
|
||||
set_admin(email, is_admin): sets the admin status of the user with the given email
|
||||
"""
|
||||
|
||||
|
||||
@ -334,6 +335,22 @@ class API_Handler:
|
||||
return req.status_code
|
||||
|
||||
|
||||
def set_admin(self, email, is_admin):
|
||||
"""sets the admin of the user
|
||||
|
||||
Args:
|
||||
email (string): email of the user
|
||||
is_admin (String): "true" if user should be Admin, "false" if not
|
||||
|
||||
Returns:
|
||||
int: status code
|
||||
"""
|
||||
with r.Session() as s:
|
||||
headers = {'Authorization': 'Bearer ' + self.token} # only bot token is needed, user is chosen by email
|
||||
req = s.put(self.db_adress + "/user/setAdmin", json={"admin": str(is_admin),"email": str(email)})
|
||||
return req.status_code
|
||||
|
||||
|
||||
if __name__ == "__main__": # editable, just for basic on the go testing of new functions
|
||||
|
||||
print("This is a module for the telegram bot. It is not intended to be run directly.")
|
||||
@ -346,6 +363,8 @@ if __name__ == "__main__": # editable, just for basic on the go testing of new f
|
||||
user = handler.get_user(user_id = 1709356058)
|
||||
print(user)
|
||||
all_users = handler.get_all_users()
|
||||
admin_status = handler.set_admin("test@test.com", "true")
|
||||
print(admin_status)
|
||||
print(all_users)
|
||||
print(shares)
|
||||
sys.exit(1)
|
@ -97,7 +97,7 @@ def send_version(message):
|
||||
|
||||
|
||||
@bot.message_handler(commands=['help', 'Help']) # /help -> sending all functions
|
||||
def send_welcome(message):
|
||||
def send_help(message):
|
||||
|
||||
""" Send all functions
|
||||
:type message: message object bot
|
||||
@ -133,16 +133,57 @@ def send_all_users(message):
|
||||
bot.send_message(chat_id=user_id, text="There are " + str(user_count) + " users in the database:")
|
||||
|
||||
for user in user_list:
|
||||
|
||||
|
||||
username = user['username']
|
||||
email = user['email']
|
||||
user_id = user['telegram_user_id']
|
||||
id = user['telegram_user_id']
|
||||
cron = user['cron']
|
||||
admin = user['admin']
|
||||
|
||||
bot.send_message(chat_id=user_id, text=f'Username: {username}\nEmail: {email}\nID: {user_id}\nCron: {cron}\nAdmin: {admin}') # format user data into readable message text
|
||||
bot.send_message(chat_id=user_id, text=f'Username: {username}\nEmail: {email}\nID: {id}\nCron: {cron}\nAdmin: {admin}') # format user data into readable message text
|
||||
|
||||
|
||||
@bot.message_handler(commands=['setAdmin', 'SetAdmin']) # set admin rights to user
|
||||
def set_admin(message):
|
||||
|
||||
""" Set admin rights to user
|
||||
:type message: message object bot
|
||||
:param message: message that was reacted to, in this case always containing '/setAdmin'
|
||||
|
||||
:raises: none
|
||||
|
||||
:rtype: none
|
||||
"""
|
||||
user_id = int(message.from_user.id)
|
||||
user_data = api_handler.get_user(user_id)
|
||||
|
||||
if(user_data["admin"] == False): # check if user has admin rights
|
||||
bot.reply_to(message, "You have to be an admin to use this command")
|
||||
return
|
||||
|
||||
bot.send_message(chat_id=user_id, text='send email and "true" if this account should have admin rights, else "false"\n in format: <email>,<is_admin>') # ask for email and admin rights to set
|
||||
bot.register_next_step_handler(message, set_admin_step)
|
||||
|
||||
def set_admin_step(message):
|
||||
str_message = str(message.text)
|
||||
args_message = str_message.split(',') # split message into email and admin rights
|
||||
|
||||
if len(args_message) != 2: # make sure 2 args (email,is_admin) are given
|
||||
|
||||
bot.reply_to(message, "exactly 2 arguments (<email>,<is_admin>) required, try again")
|
||||
return
|
||||
|
||||
email = args_message[0]
|
||||
is_admin = args_message[1]
|
||||
status = api_handler.set_admin(email, is_admin) # set admin in db
|
||||
|
||||
if(status == 200):
|
||||
bot.reply_to(message, "Admin rights set")
|
||||
|
||||
else:
|
||||
bot.reply_to(message, f"Admin rights could not be set ({status})")
|
||||
|
||||
|
||||
@bot.message_handler(commands=['me', 'Me']) # /me -> sending user info
|
||||
def send_user(message):
|
||||
""" Send user data
|
||||
|
Loading…
Reference in New Issue
Block a user