cleanings to make code more compact and readable
This commit is contained in:
		
							
								
								
									
										41
									
								
								bot.py
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								bot.py
									
									
									
									
									
								
							| @@ -8,9 +8,9 @@ from telegram import ReplyKeyboardRemove | |||||||
| from utils import logs as _log | from utils import logs as _log | ||||||
|  |  | ||||||
| from entities import arena as _arena | from entities import arena as _arena | ||||||
| from bot_libs import special_commands as _bot_special_cmd | from bot_libs import special_commands as _scmd | ||||||
| from bot_libs import syms as _botsyms | from bot_libs import syms as _botsyms | ||||||
| from bot_libs import commands_handling as _bot_commands | from bot_libs import commands_handling as _cmd | ||||||
|  |  | ||||||
|  |  | ||||||
| async def bot_start(update, context): | async def bot_start(update, context): | ||||||
| @@ -41,34 +41,39 @@ async def bot_commands(update, context): | |||||||
|  |  | ||||||
|   _log.log_info(f'bot_command: {chat_id} - text received: {text}') |   _log.log_info(f'bot_command: {chat_id} - text received: {text}') | ||||||
|  |  | ||||||
|  |   # init or restart the game | ||||||
|   if text == 'Init/Restart': |   if text == 'Init/Restart': | ||||||
|     return await bot_start(update, context) |     return await bot_start(update, context) | ||||||
|    |    | ||||||
|  |   # player game commands | ||||||
|   if text == 'Add Player': |   if text == 'Add Player': | ||||||
|     return await _bot_commands.bot_command_add_player(context, update, chat_id) |     return await _cmd.cmd_add_player(context, update, chat_id) | ||||||
|   if text == 'Get Players': |   if text == 'Get Players': | ||||||
|     return await _bot_commands.bot_command_get_players(context, update, chat_id) |     return await _cmd.cmd_get_players(context, update, chat_id) | ||||||
|   if text == 'Get Alive Players': |   if text == 'Get Alive Players': | ||||||
|     return await _bot_commands.bot_command_get_alive_players(context, update, chat_id) |     return await _cmd.cmd_get_alive_players(context, update, chat_id) | ||||||
|   if text == 'Get Death Players': |   if text == 'Get Death Players': | ||||||
|     return await _bot_commands.bot_command_get_death_players(context, update, chat_id) |     return await _cmd.cmd_get_death_players(context, update, chat_id) | ||||||
|   if text == 'Get Ranking Players': |   if text == 'Get Ranking Players': | ||||||
|     return await _bot_commands.bot_command_get_ranking_players(context, update, chat_id) |     return await _cmd.cmd_get_ranking_players(context, update, chat_id) | ||||||
|   if text == 'Simulate Day': |   if text == 'Simulate Day': | ||||||
|     return await _bot_commands.bot_command_simulate_day(context, update, chat_id) |     return await _cmd.cmd_simulate_day(context, update, chat_id) | ||||||
|   if text == 'Run Periodically': |   if text == 'Run Periodically': | ||||||
|     return await _bot_commands.bot_command_simulate_day_cron(context, update, chat_id) |     return await _cmd.cmd_simulate_day_cron(context, update, chat_id) | ||||||
|  |   if text == 'Add random Players': | ||||||
|  |     return await _cmd.cmd_add_random_players(context, update, chat_id) | ||||||
|  |   if text == 'Add random color Players': | ||||||
|  |     return await _cmd.cmd_add_random_color_players(context, update, chat_id) | ||||||
|    |    | ||||||
|   waiting_for_name= context.application.bot_data.get('ask_name') |   # special commands | ||||||
|   if waiting_for_name or text in ['Add random Players', 'Add random color Players']: |   if text == 'upstart': return await _scmd.update_bot(update, context) | ||||||
|     return await _bot_commands.get_name_from_input(context, update, chat_id, text) |   if text == 'logs': return await _scmd.show_logs(update, context) | ||||||
|    |    | ||||||
|   waiting_for_seconds= context.application.bot_data.get('ask_seconds') |   # get user input | ||||||
|   if waiting_for_seconds: |   if context.application.bot_data.get('ask_name'): | ||||||
|     return await _bot_commands.get_seconds_from_input(context, update, chat_id, text) |     return await _cmd.cmd_get_player_name(context, update, chat_id, text) | ||||||
|  |   if context.application.bot_data.get('ask_seconds'): | ||||||
|   if text == 'upstart': return await _bot_special_cmd.update_bot(update, context) |     return await _cmd.cmd_get_cron_time(context, update, chat_id, text) | ||||||
|   if text == 'logs': return await _bot_special_cmd.show_logs(update, context) |  | ||||||
|  |  | ||||||
|   _log.log_debug(f'bot_command: {chat_id} - sent this text: {text}') |   _log.log_debug(f'bot_command: {chat_id} - sent this text: {text}') | ||||||
|   await update.message.reply_text(_botsyms.WIP_MSG) |   await update.message.reply_text(_botsyms.WIP_MSG) | ||||||
|   | |||||||
| @@ -5,27 +5,24 @@ from bot_libs import repeating as _bot_repeat | |||||||
|  |  | ||||||
| ### parse user input | ### parse user input | ||||||
|  |  | ||||||
| async def get_name_from_input(context, update, chat_id, text): | async def _cmd_list_of_players(context, update, chat_id): | ||||||
|   _log.log_info(f'bot_command: {chat_id} - Collected Player Name {text}') |  | ||||||
|   if 'ask_name' in context.application.bot_data: |  | ||||||
|     del(context.application.bot_data['ask_name']) |  | ||||||
|     players= text.split(',') |  | ||||||
|     for player in players: |  | ||||||
|       await _bot_player.add_player(update, context, chat_id, player.strip()) |  | ||||||
|  |  | ||||||
|   elif text == 'Add random Players': |  | ||||||
|     await _bot_player.add_random_players(update, context, chat_id, colors_names= False) |  | ||||||
|  |  | ||||||
|   elif text == 'Add random color Players': |  | ||||||
|     await _bot_player.add_random_players(update, context, chat_id, colors_names= True) |  | ||||||
|  |  | ||||||
|   Arena= context.application.bot_data['arena'] |   Arena= context.application.bot_data['arena'] | ||||||
|   players= [p.get_name_and_stats() for p in Arena.get_players()] |   players= [p.get_name_and_stats() for p in Arena.get_players()] | ||||||
|   players_str= '\n'.join(players) |   players_str= '\n'.join(players) | ||||||
|   return await update.message.reply_text(f'Ecco i {len(players)} giocatori presenti nel mondo do gioco: \n{players_str}') |   return await update.message.reply_text(f'Ecco i {len(players)} giocatori presenti nel mondo do gioco: \n{players_str}') | ||||||
|  |  | ||||||
| async def get_seconds_from_input(context, update, chat_id, text): | async def cmd_get_player_name(context, update, chat_id, text): | ||||||
|   _log.log_info(f'bot_command: {chat_id} - User Wants to auto-run the game every {text} seconds') |   _log.log_info(f'cmd_get_player_name: {chat_id} - Collected Player Name {text}') | ||||||
|  |   if not 'ask_name' in context.application.bot_data: return | ||||||
|  |  | ||||||
|  |   del(context.application.bot_data['ask_name']) | ||||||
|  |   players= text.split(',') | ||||||
|  |   for player in players: | ||||||
|  |     await _bot_player.add_player(update, context, chat_id, player.strip()) | ||||||
|  |   return await _cmd_list_of_players(context, update, chat_id) | ||||||
|  |  | ||||||
|  | async def cmd_get_cron_time(context, update, chat_id, text): | ||||||
|  |   _log.log_info(f'cmd_get_cron_time: {chat_id} - User Wants to auto-run the game every {text} seconds') | ||||||
|   try: text= int(text) |   try: text= int(text) | ||||||
|   except: return |   except: return | ||||||
|   seconds= max(1, text) |   seconds= max(1, text) | ||||||
| @@ -35,28 +32,36 @@ async def get_seconds_from_input(context, update, chat_id, text): | |||||||
|  |  | ||||||
| ### basic commands handling | ### basic commands handling | ||||||
|  |  | ||||||
| async def bot_command_add_player(context, update, chat_id): | async def cmd_add_random_players(context, update, chat_id): | ||||||
|  |   await _bot_player.add_random_players(update, context, chat_id, colors_names= False) | ||||||
|  |   return await _cmd_list_of_players(context, update, chat_id) | ||||||
|  |  | ||||||
|  | async def cmd_add_random_color_players(context, update, chat_id): | ||||||
|  |   await _bot_player.add_random_players(update, context, chat_id, colors_names= True) | ||||||
|  |   return await _cmd_list_of_players(context, update, chat_id) | ||||||
|  |  | ||||||
|  | async def cmd_add_player(context, update, chat_id): | ||||||
|   context.application.bot_data['ask_name'] = 1 |   context.application.bot_data['ask_name'] = 1 | ||||||
|   if 'ask_seconds' in context.application.bot_data: |   if 'ask_seconds' in context.application.bot_data: | ||||||
|     del(context.application.bot_data['ask_seconds']) |     del(context.application.bot_data['ask_seconds']) | ||||||
|   return await update.message.reply_text('Inserisci il Nome del giocatore (o piu\' nomi separati da virgola)') |   return await update.message.reply_text('Inserisci il Nome del giocatore (o piu\' nomi separati da virgola)') | ||||||
|  |  | ||||||
| async def bot_command_get_players(context, update, chat_id): | async def cmd_get_players(context, update, chat_id): | ||||||
|   return await _bot_player.get_players(update, context, chat_id) |   return await _bot_player.get_players(update, context, chat_id) | ||||||
|  |  | ||||||
| async def bot_command_get_alive_players(context, update, chat_id): | async def cmd_get_alive_players(context, update, chat_id): | ||||||
|   return await _bot_player.get_alive_players(update, context, chat_id) |   return await _bot_player.get_alive_players(update, context, chat_id) | ||||||
|  |  | ||||||
| async def bot_command_get_death_players(context, update, chat_id): | async def cmd_get_death_players(context, update, chat_id): | ||||||
|   return await _bot_player.get_death_players(update, context, chat_id) |   return await _bot_player.get_death_players(update, context, chat_id) | ||||||
|  |  | ||||||
| async def bot_command_get_ranking_players(context, update, chat_id): | async def cmd_get_ranking_players(context, update, chat_id): | ||||||
|   return await _bot_player.get_ranking_players(update, context, chat_id) |   return await _bot_player.get_ranking_players(update, context, chat_id) | ||||||
|  |  | ||||||
| async def bot_command_simulate_day(context, update, chat_id): | async def cmd_simulate_day(context, update, chat_id): | ||||||
|   return await _bot_simulation.simulate_day(context, chat_id) |   return await _bot_simulation.simulate_day(context, chat_id) | ||||||
|  |  | ||||||
| async def bot_command_simulate_day_cron(context, update, chat_id): | async def cmd_simulate_day_cron(context, update, chat_id): | ||||||
|   context.application.bot_data['ask_seconds'] = 1 |   context.application.bot_data['ask_seconds'] = 1 | ||||||
|   if 'ask_name' in context.application.bot_data: |   if 'ask_name' in context.application.bot_data: | ||||||
|     del(context.application.bot_data['ask_name']) |     del(context.application.bot_data['ask_name']) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 andrea
					andrea