New try for bot and bot_updates #80
| @@ -37,6 +37,7 @@ class API_Handler: | |||||||
|         set_portfolio(user_id, portfolio): sets the portfolio of the user |         set_portfolio(user_id, portfolio): sets the portfolio of the user | ||||||
|         delete_portfolio(user_id, portfolio): deletes 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_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 |             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 | 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.") |     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) |     user = handler.get_user(user_id = 1709356058) | ||||||
|     print(user) |     print(user) | ||||||
|     all_users = handler.get_all_users() |     all_users = handler.get_all_users() | ||||||
|  |     admin_status = handler.set_admin("test@test.com", "true") | ||||||
|  |     print(admin_status) | ||||||
|     print(all_users) |     print(all_users) | ||||||
|     print(shares) |     print(shares) | ||||||
|     sys.exit(1) |     sys.exit(1) | ||||||
| @@ -97,7 +97,7 @@ def send_version(message): | |||||||
|  |  | ||||||
|  |  | ||||||
| @bot.message_handler(commands=['help', 'Help']) # /help -> sending all functions  | @bot.message_handler(commands=['help', 'Help']) # /help -> sending all functions  | ||||||
| def send_welcome(message): | def send_help(message): | ||||||
|      |      | ||||||
|     """ Send all functions |     """ Send all functions | ||||||
|     :type message: message object bot |     :type message: message object bot | ||||||
| @@ -136,11 +136,52 @@ def send_all_users(message): | |||||||
|  |  | ||||||
|         username = user['username'] |         username = user['username'] | ||||||
|         email = user['email'] |         email = user['email'] | ||||||
|         user_id = user['telegram_user_id'] |         id = user['telegram_user_id'] | ||||||
|         cron = user['cron'] |         cron = user['cron'] | ||||||
|         admin = user['admin'] |         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 | @bot.message_handler(commands=['me', 'Me']) # /me -> sending user info | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user