forked from Cryz/battle_royale_sim
		
	
		
			
				
	
	
		
			131 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			131 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import os as _os
 | |
| 
 | |
| from utils import logs as _log
 | |
| 
 | |
| from telegram.ext import Application
 | |
| from telegram.ext import CommandHandler
 | |
| from telegram.ext import MessageHandler
 | |
| from telegram.ext import filters
 | |
| from telegram import ReplyKeyboardMarkup
 | |
| from telegram import ReplyKeyboardRemove
 | |
| 
 | |
| from entities import arena as _arena
 | |
| from bot_libs import player_handling as _bot_player
 | |
| from bot_libs import simulation as _bot_sim
 | |
| from bot_libs import repeating as _bot_repeat
 | |
| from bot_libs import syms as _botsyms
 | |
| 
 | |
| 
 | |
| async def bot_start(update, context):
 | |
|   await update.message.reply_text(_botsyms.START_MSG)
 | |
| 
 | |
|   keyboard = [
 | |
|       ['Init/Restart'],
 | |
|       ['Add Player', 'Add random Players', 'Add random color Players'],
 | |
|       ['Get Players', 'Get Alive Players', 'Get Death Players', 'Get Ranking Players',],
 | |
|       ['Simulate Day', 'Run Periodically']
 | |
|   ]
 | |
|   reply_markup= ReplyKeyboardMarkup(keyboard, one_time_keyboard=False, resize_keyboard=True)
 | |
| 
 | |
|   chat_id = update.effective_chat.id
 | |
|   _log.log_debug(f'{chat_id}: I\'m building the world\'s game...')
 | |
|   Arena= _arena.BrSimArena()
 | |
| 
 | |
|   await update.message.reply_text('Ho creato il mondo di gioco', reply_markup=reply_markup)
 | |
|   context.application.bot_data['arena'] = Arena
 | |
| 
 | |
| async def update_bot(update, context):
 | |
|   await update.message.reply_text('Sto aggiornando il Bot...')
 | |
|   chat_id = update.effective_chat.id
 | |
|   if update.message.chat.id not in _botsyms.SUPER_USERS: return _log.log_warning(f'update_bot: user {chat_id} not allowed')
 | |
|   _log.log_debug(f'update_bot: {chat_id} bot is updating...')
 | |
|   err= _os.system(f'cd {_botsyms.BOT_PATH}; /usr/bin/git pull')
 | |
|   if err:
 | |
|     _log.log_error(f'update_bot: {chat_id} error {err} while trying to update the app')
 | |
|     return await update.message.reply_text('Errore durante l\'aggiornamento del Bot')
 | |
|   err= _os.system('/usr/bin/systemctl --user restart battle_royale.service')
 | |
|   if err:
 | |
|     _log.log_error(f'update_bot: {chat_id} error {err} while trying to upstart the app')
 | |
|     return await update.message.reply_text('Errore durante il riavvio del Bot')
 | |
|   _log.log_debug(f'update_bot: {chat_id} bot successfully updated')
 | |
|   await update.message.reply_text('Bot aggiornato e riavviato!')
 | |
| 
 | |
| async def bot_commands(update, context):
 | |
|   text= update.message.text
 | |
|   chat_id = update.effective_chat.id
 | |
| 
 | |
|   if text == 'upstart': return await update_bot(update, context)
 | |
| 
 | |
|   if text == 'Init/Restart':
 | |
|     _log.log_info(f'bot_command: {chat_id} Init/Restart')
 | |
|     return await bot_start(update, context)
 | |
| 
 | |
|   if text == 'Add Player':
 | |
|     _log.log_info(f'bot_command: {chat_id} Add Player')
 | |
|     context.application.bot_data['ask_name'] = 1
 | |
|     if 'ask_seconds' in context.application.bot_data:
 | |
|       del(context.application.bot_data['ask_seconds'])
 | |
|     return await update.message.reply_text('Inserisci il Nome del giocatore (o piu\' nomi separati da virgola)')
 | |
|   if text == 'Get Players':
 | |
|     _log.log_info(f'bot_command: {chat_id} Get Players')
 | |
|     return await _bot_player.get_players(update, context)
 | |
|   if text == 'Get Alive Players':
 | |
|     _log.log_info(f'bot_command: {chat_id} Get Alive Players')
 | |
|     return await _bot_player.get_alive_players(update, context)
 | |
|   if text == 'Get Death Players':
 | |
|     _log.log_info(f'bot_command: {chat_id} Get Death Players')
 | |
|     return await _bot_player.get_death_players(update, context)
 | |
|   if text == 'Get Ranking Players':
 | |
|     _log.log_info(f'bot_command: {chat_id} Get Ranking Players')
 | |
|     return await _bot_player.get_ranking_players(update, context)
 | |
|   if text == 'Simulate Day':
 | |
|     _log.log_info(f'bot_command: {chat_id} Simulate Day')
 | |
|     return await _bot_sim.simulate_day(context, chat_id)
 | |
|   if text == 'Run Periodically':
 | |
|     _log.log_info(f'bot_command: {chat_id} Run Periodically')
 | |
|     context.application.bot_data['ask_seconds'] = 1
 | |
|     if 'ask_name' in context.application.bot_data:
 | |
|       del(context.application.bot_data['ask_name'])
 | |
|     return await update.message.reply_text('Inserisci il numero di secondi, ad esempio \n(60 = 1 minuto)(600 = 10 minuti)\n(3600 = 1 ora)\n(86400 = 1 giorno)')
 | |
| 
 | |
|   waiting_for_name= context.application.bot_data.get('ask_name')
 | |
|   if waiting_for_name or text in ['Add random Players', 'Add random color Players']:
 | |
|     _log.log_debug(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, player.strip())
 | |
|     elif text == 'Add random Players':
 | |
|       await _bot_player.add_random_players(update, context, colors_names= False)
 | |
|     elif text == 'Add random color Players':
 | |
|       await _bot_player.add_random_players(update, context, colors_names= True)
 | |
| 
 | |
|     Arena= context.application.bot_data['arena']
 | |
|     players= [p.get_name_and_stats() for p in Arena.get_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}')
 | |
| 
 | |
|   waiting_for_seconds= context.application.bot_data.get('ask_seconds')
 | |
|   if waiting_for_seconds:
 | |
|     _log.log_debug(f'bot_command: {chat_id} User Wants to auto-run the game every {text} seconds')
 | |
|     try: text= int(text)
 | |
|     except: return
 | |
|     seconds= max(1, text)
 | |
|     return await _bot_repeat.start_loop_game(update, context, seconds)
 | |
| 
 | |
|   _log.log_debug(f'bot_command: {chat_id} sent this text: {text}')
 | |
|   await update.message.reply_text(_botsyms.WIP_MSG)
 | |
| 
 | |
| def main():
 | |
|   application = Application.builder().token(_botsyms.TOKEN).build()
 | |
| 
 | |
|   application.add_handler(CommandHandler('start', bot_start))
 | |
|   application.add_handler(MessageHandler(filters.TEXT & ~filters.COMMAND, bot_commands))
 | |
| 
 | |
|   _log.log_debug('Bot is running...')
 | |
|   application.run_polling()
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|   main()
 | 
