from abc import ABCMeta from commands.command_base import AbstractCommand from json import loads from urllib.parse import urlencode import requests import docker_utility import config import os import praxis_logging praxis_logger_obj = praxis_logging.praxis_logger() praxis_logger_obj.init(os.path.basename(__file__)) praxis_logger_obj.log("\n -Starting Logs: " + os.path.basename(__file__)) class Command_tts_v2(AbstractCommand, metaclass=ABCMeta): """ this is the test command. """ command = "!tts" def __init__(self): super().__init__(Command_tts_v2.command, n_args=1, command_type=AbstractCommand.CommandType.Ver2) self.help = ["This command allows you to do tts.", "\nExample:","tts \"TEXT\""] self.isCommandEnabled = True def do_command(self, source = AbstractCommand.CommandSource.default, user:str = "User", command = "", rest = "", bonusData = None): returnString = "" praxis_logger_obj.log("\n Command>: " + command + rest) for name in config.allowedCommandsList_TwitchPowerUsers: print(name) tempName = user.lower() if name == tempName: self.send_TTS(user, rest) return returnString def send_Lights_Command(self, username, light_group, command, rest): # todo need to url-escape command and rest params = urlencode({'user_name': username, 'light_group': light_group, 'command': command, 'rest':rest}) #standalone_lights url = "http://%s:42069/api/v1/exec_lights?%s" % docker_utility.ifNotDockerUseLocalhost("standalone_lights"), params resp = requests.get(url) if resp.status_code == 200: print("Got the following message: %s" % resp.text) data = loads(resp.text) msg = data['message'] if msg is not None: return msg # todo send to logger and other relevent services else: # todo handle failed requests return None def send_TTS(self, username, message): params = urlencode({'tts_sender': username, 'tts_text': message}) #standalone_tts_core url = "http://%s:60809/api/v1/tts/send_text?%s" % docker_utility.ifNotDockerUseLocalhost("standalone_tts_core"), params resp = requests.get(url) if resp.status_code == 200: print("Got the following message: %s" % resp.text) data = loads(resp.text) msg = data['message'] if msg is not None: return msg # todo send to logger and other relevent services else: # todo handle failed requests pass def get_help(self): return self.help