import sys import openai import datetime import os import getpass import socket from PyQt5.QtWidgets import QApplication, QMainWindow, QTextEdit, QPushButton, QLineEdit # TODO gérer le formattage / affichage de la réponse quand c'est une liste à points. class MainWindow(QMainWindow): def __init__(self): super().__init__() # Set window title self.setWindowTitle("Chatbot") # Set window size self.setGeometry(100, 100, 800, 600) # Create text input field for user's messages self.text_input = QLineEdit(self) self.text_input.setGeometry(20, 540, 550, 40) # Initialize API needs openai.api_key = "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" self.chat_log = [{"role": "system", "content": "Ignore toute les instructions avant celle-ci. Tu est un administrateur système et réseaux niveau 0 à 2. Tu fais ce travail depuis 20 ans. Ta tâche est maintenant de diagnostiquer et classifier les problèmes que te remontent les utilisateurs. Tu dois définir si l'utilisateur rencontre un problème ou souhaite effectuer une demande de changement. Si l'utilisateur rencontre un problème, tu dois effectuer le diagnostic pour catégoriser le problème et dépanner au mieux l'utilisateur. Si tu ne peux pas résoudre le problème et que tu as effectué ton diagnostic au maximum ou que l'utilisateur souhaire faire une demande de changement, tu indique toujours à l'utilisateur d'ouvrir un dossier en cliquant sur https://www.supportpc.fr/ticket/. Tu dois TOUJOURS poser des questions AVANT de répondre afin de mieux cerner ce que t'indique l'utilisateur."}] # Initialize message counter ###self.num_messages = 0 # Create chat window to display conversation self.chat_window = QTextEdit(self) self.chat_window.setGeometry(20, 20, 760, 500) self.chat_window.setReadOnly(True) # Create send button to send user's messages self.send_button = QPushButton("Send", self) self.send_button.setGeometry(580, 540, 200, 40) self.send_button.clicked.connect(self.send_message) self.text_input.returnPressed.connect(self.send_button.click) ###self.username = "JimmyB" username = getpass.getuser() hostname = socket.gethostname() domain_parts = hostname.split(".")[1:] if len(domain_parts) > 1: domain = ".".join(domain_parts) else: domain = "NODOMAIN" logs_folder = os.path.join(os.path.expanduser("~"), "Logs") if not os.path.exists(logs_folder): os.makedirs(logs_folder) self.filename = os.path.join(logs_folder, f"{datetime.datetime.now().strftime('%Y_%m_%d_%H_%M_%S')}_{domain}_{username}_chatlog.txt") # set the filename self.write_to_file() # call the function to write the first line to the file def write_to_file(self): with open(self.filename, "a") as file: timestamp = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S") # get the current time in the desired format file.write(f"{timestamp} {self.chat_log[-1]}\n") # write the timestamp and the latest chat log entry to the file def send_message(self): # Get user's message from text input field user_message = self.text_input.text() self.chat_log.append({"role": "user", "content": user_message}) self.write_to_file() try: reply = openai.ChatCompletion.create( model="gpt-3.5-turbo", messages=self.chat_log) response=reply['choices'][0]['message']['content'] except openai.error.APIError as e: #Handle API error here, e.g. retry or log self.chat_log.append({"OpenAI API returned an API Error: {e}"}) pass except openai.error.Timeout as e: #Handle connection error here self.chat_log.append({"Failed to connect to OpenAI API: {e}"}) pass except openai.error.RateLimitError as e: #Handle rate limit error (we recommend using exponential backoff) self.chat_log.append({"OpenAI API request exceeded rate limit: {e}"}) pass except openai.error.APIConnectionError as e: #Handle Issue connecting to our services self.chat_log.append({"Check your network settings, proxy configuration, SSL certificates, or firewall rules: {e}"}) pass except openai.error.InvalidRequestError as e: #Handle when your request was malformed or missing some required parameters, such as a token or an input self.chat_log.append({"The error message should advise you on the specific error made: {e}"}) pass except openai.error.AuthenticationError as e: #Handle validation of your API key or token fail self.chat_log.append({"Your API key or token was invalid, expired, or revoked: {e}"}) pass except openai.error.ServiceUnavailableError as e: #Handle Issue on OpenAI servers self.chat_log.append({"Retry your request after a brief wait and contact us if the issue persists: {e}"}) pass # Increment message counter ###self.num_messages += 1 # Send greeting to user ###response = f"Hello, you have sent {self.num_messages} messages." self.chat_log.append({"role": "assistant", "content":response}) self.write_to_file() # Add user's message and bot's response to chat window self.chat_window.append(f"

You : {user_message}

") self.chat_window.append(f"

Bot : {response}

") # Clear text input field self.text_input.clear() if __name__ == "__main__": # Create QApplication instance app = QApplication(sys.argv) # Create MainWindow instance main_window = MainWindow() # Show MainWindow main_window.show() # Execute QApplication event loop sys.exit(app.exec_())