Correos funcional correctamente

This commit is contained in:
Santi 2025-02-04 18:30:45 +01:00
parent bf73b52d12
commit c80721e33e
5 changed files with 32 additions and 91 deletions

View File

@ -18,19 +18,16 @@ from solapas.SQLQueryExecutor import SQLQueryExecutor
from solapas.TicTacToe import TicTacToe
from solapas.WebScraperToDB import WebScraperToDB
# Configuración del servidor de correos
smtp_server = "192.168.120.103"
smtp_port = 465
imap_server = "192.168.120.103"
imap_port = 993
username = "tu_usuario@psp.ieslamar.org"
password = "tu_contraseña"
SMTP_SERVER = "192.168.120.103"
SMTP_PORT = 587 # Usar SSL para mayor seguridad
# Clave de API de OpenWeatherMap
API_KEY = "1fa8fd05b650773bbc3f2130657e808a"
# Crear cliente de correo
mail_client = MailClient(smtp_server, smtp_port, imap_server, imap_port, username, password)
mail_client = MailClient(SMTP_SERVER, SMTP_PORT)
def update_time(status_bar):
"""Función que actualiza la hora y el día de la semana en un label"""
@ -154,35 +151,35 @@ notebook.pack(fill="both", expand=True)
# Crear la Solapa 1 y añadir el downloader
tab1 = ttk.Frame(notebook)
notebook.add(tab1, text="Solapa 1", padding=4)
notebook.add(tab1, text="Downloader", padding=4)
# Añadir el downloader a la Solapa 1
music_downloader = MusicDownloader(tab1)
# Crear la Solapa 2 y añadir los gráficos
tab2 = ttk.Frame(notebook)
notebook.add(tab2, text="Solapa 2", padding=4)
notebook.add(tab2, text="Graphics", padding=4)
# Añadir los gráficos de economía mundial y Bitcoin a la Solapa 2
economy_bitcoin_chart = EconomyBitcoinChart(tab2)
# Crear la Solapa 3 y añadir el Tic Tac Toe
tab3 = ttk.Frame(notebook)
notebook.add(tab3, text="Solapa 3", padding=4)
notebook.add(tab3, text="Tic Tac Toe", padding=4)
# Añadir el juego de Tic Tac Toe a la Solapa 3
tic_tac_toe = TicTacToe(tab3)
# Crear la Solapa 4 y añadir el SQL Query Executor
tab4 = ttk.Frame(notebook)
notebook.add(tab4, text="Solapa 4", padding=4)
notebook.add(tab4, text="SQL Querys", padding=4)
# Añadir el ejecutor de consultas SQL a la Solapa 4
sql_query_executor = SQLQueryExecutor(tab4)
# Crear la Solapa 5 y añadir el Web Scraper
tab5 = ttk.Frame(notebook)
notebook.add(tab5, text="Solapa 5", padding=4)
notebook.add(tab5, text="Web Scraper", padding=4)
# Añadir el widget de Web Scraper a la Solapa 5
web_scraper = WebScraperToDB(tab5)

View File

@ -3,14 +3,14 @@ from tkinter import ttk, messagebox
import threading
class MailTab:
def __init__(self, notebook, mail_client):
def __init__(self, parent, mail_client):
self.mail_client = mail_client
# Crear el frame de la pestaña dentro del Notebook
self.frame = ttk.Frame(notebook)
notebook.add(self.frame, text="Correo") # ← Ahora esto es correcto
# Crear el frame de la pestaña
self.frame = ttk.Frame(parent)
parent.add(self.frame, text="Correo")
# Campos de entrada para credenciales
# Campos de entrada para enviar correo
ttk.Label(self.frame, text="Correo electrónico:").grid(row=0, column=0, sticky="e", padx=5, pady=5)
self.entry_email = ttk.Entry(self.frame, width=40)
self.entry_email.grid(row=0, column=1, padx=5, pady=5)
@ -19,62 +19,30 @@ class MailTab:
self.entry_password = ttk.Entry(self.frame, show="*", width=40)
self.entry_password.grid(row=1, column=1, padx=5, pady=5)
self.login_button = ttk.Button(self.frame, text="Iniciar Sesión", command=self.login)
self.login_button.grid(row=2, column=1, padx=5, pady=5, sticky="e")
# Campos para enviar correo
ttk.Label(self.frame, text="Destinatario:").grid(row=3, column=0, padx=5, pady=5, sticky="e")
ttk.Label(self.frame, text="Destinatario:").grid(row=2, column=0, sticky="e", padx=5, pady=5)
self.recipient_entry = ttk.Entry(self.frame, width=40)
self.recipient_entry.grid(row=3, column=1, padx=5, pady=5)
self.recipient_entry.grid(row=2, column=1, padx=5, pady=5)
ttk.Label(self.frame, text="Asunto:").grid(row=4, column=0, padx=5, pady=5, sticky="e")
ttk.Label(self.frame, text="Asunto:").grid(row=3, column=0, sticky="e", padx=5, pady=5)
self.subject_entry = ttk.Entry(self.frame, width=40)
self.subject_entry.grid(row=4, column=1, padx=5, pady=5)
self.subject_entry.grid(row=3, column=1, padx=5, pady=5)
ttk.Label(self.frame, text="Mensaje:").grid(row=5, column=0, padx=5, pady=5, sticky="ne")
ttk.Label(self.frame, text="Mensaje:").grid(row=4, column=0, sticky="ne", padx=5, pady=5)
self.body_text = tk.Text(self.frame, width=50, height=10)
self.body_text.grid(row=5, column=1, padx=5, pady=5)
self.body_text.grid(row=4, column=1, padx=5, pady=5)
self.send_button = ttk.Button(self.frame, text="Enviar", command=self.send_email_thread)
self.send_button.grid(row=6, column=1, padx=5, pady=5, sticky="e")
# Widgets para recibir correos
self.receive_button = ttk.Button(self.frame, text="Recibir Correos", command=self.fetch_emails_thread)
self.receive_button.grid(row=7, column=1, padx=5, pady=5, sticky="e")
self.emails_listbox = tk.Listbox(self.frame, height=10, width=80)
self.emails_listbox.grid(row=8, column=0, columnspan=2, padx=5, pady=5)
def login(self):
email = self.entry_email.get()
password = self.entry_password.get()
result = self.mail_client.login(email, password)
if result:
messagebox.showinfo("Inicio de Sesión", "Inicio de sesión exitoso")
else:
messagebox.showerror("Error", "Credenciales incorrectas")
self.send_button.grid(row=5, column=1, padx=5, pady=5, sticky="e")
def send_email_thread(self):
threading.Thread(target=self.send_email).start()
def send_email(self):
sender_email = self.entry_email.get()
sender_password = self.entry_password.get()
recipient = self.recipient_entry.get()
subject = self.subject_entry.get()
body = self.body_text.get("1.0", tk.END).strip()
result = self.mail_client.send_email(recipient, subject, body)
result = self.mail_client.send_email(sender_email, sender_password, recipient, subject, body)
messagebox.showinfo("Resultado", result)
def fetch_emails_thread(self):
threading.Thread(target=self.fetch_emails).start()
def fetch_emails(self):
try:
result = self.mail_client.fetch_emails()
if isinstance(result, list):
self.emails_listbox.delete(0, tk.END)
for email in result:
self.emails_listbox.insert(tk.END, email[:100]) # Mostrar los primeros 100 caracteres
else:
messagebox.showerror("Error", result)
except Exception as e:
print(f"Error al recibir correos: {e}")

View File

@ -1,41 +1,17 @@
import smtplib
import imaplib
class MailClient:
def __init__(self, smtp_server, smtp_port, imap_server, imap_port, username, password):
def __init__(self, smtp_server, smtp_port):
self.smtp_server = smtp_server
self.smtp_port = smtp_port
self.imap_server = imap_server
self.imap_port = imap_port
self.username = username
self.password = password
def send_email(self, recipient, subject, body):
"""Envía un correo utilizando el servidor SMTP."""
def send_email(self, sender_email, sender_password, recipient, subject, body):
"""Envía un correo utilizando el servidor SMTP con SSL."""
try:
with smtplib.SMTP_SSL(self.smtp_server, self.smtp_port) as server:
server.login(self.username, self.password)
message = f"Subject: {subject}\\n\\n{body}"
server.sendmail(self.username, recipient, message)
with smtplib.SMTP(self.smtp_server, self.smtp_port) as server:
server.login(sender_email, sender_password)
message = f"Subject: {subject}\n\n{body}"
server.sendmail(sender_email, recipient, message)
return "Correo enviado correctamente"
except Exception as e:
return f"Error al enviar el correo: {str(e)}"
def fetch_emails(self):
"""Obtiene los correos más recientes utilizando el servidor IMAP."""
try:
with imaplib.IMAP4_SSL(self.imap_server, self.imap_port) as server:
server.login(self.username, self.password)
server.select("inbox")
status, messages = server.search(None, "ALL")
email_ids = messages[0].split()
emails = []
for email_id in email_ids[-5:]: # Obtener los últimos 5 correos
status, msg_data = server.fetch(email_id, "(RFC822)")
for response_part in msg_data:
if isinstance(response_part, tuple):
emails.append(response_part[1].decode())
return emails
except Exception as e:
return f"Error al recibir correos: {str(e)}"