This commit is contained in:
Kevin William Olarte Braun 2025-02-04 19:49:29 +01:00
parent 848043007f
commit dc9e679298
3 changed files with 254 additions and 127 deletions

137
Main.py
View File

@ -1,46 +1,117 @@
import smtplib import poplib
from email.mime.multipart import MIMEMultipart import email
from email.mime.text import MIMEText import pymongo
from datetime import datetime from email.utils import parsedate_to_datetime
# Configuración del servidor SMTP (Sin SSL) # Configuración del servidor POP3 (Sin SSL)
SMTP_SERVER = "192.168.120.103" POP3_SERVER = "192.168.120.103"
SMTP_PORT = 25 # También puedes probar 587 si 25 no funciona POP3_PORT = 110 # Puerto POP3 estándar sin SSL
EMAIL_USER = "pruebas@psp.ieslamar.org" EMAIL_USER = "kevin@psp.ieslamar.org"
EMAIL_PASS = "1234" EMAIL_PASS = "1234"
def enviar_correo(destinatario, asunto, mensaje): # Configuración de la base de datos MongoDB
MONGO_CLIENT = "mongodb://localhost:27017/"
DB_NAME = "correo_db"
COLLECTION_NAME = "correos"
# Conectar a MongoDB
client = pymongo.MongoClient(MONGO_CLIENT)
db = client[DB_NAME]
collection = db[COLLECTION_NAME]
def correo_existe(remitente, asunto, fecha):
""" Verifica si un correo ya existe en la base de datos. """
return collection.find_one({"remitente": remitente, "asunto": asunto, "fecha": fecha}) is not None
def guardar_correo(remitente, asunto, fecha, cuerpo):
""" Guarda un correo en la base de datos si no existe. """
if correo_existe(remitente, asunto, fecha):
print("⚠️ Correo ya guardado, se omite.")
return
correo = {
"remitente": remitente,
"asunto": asunto,
"fecha": fecha,
"cuerpo": cuerpo
}
collection.insert_one(correo)
print("✅ Correo guardado en la base de datos.")
def descargar_correos():
""" Descarga correos desde el servidor y solo guarda los nuevos. """
try: try:
# Obtener la fecha y hora actual print("📡 Conectando al servidor POP3 para descargar correos...\n")
fecha_envio = datetime.now().strftime("%Y-%m-%d %H:%M:%S") mail = poplib.POP3(POP3_SERVER, POP3_PORT)
mail.user(EMAIL_USER)
mail.pass_(EMAIL_PASS)
# Crear mensaje con la fecha incluida num_mensajes = len(mail.list()[1])
msg = MIMEMultipart() print(f"📩 Se encontraron {num_mensajes} correos en la bandeja de entrada.\n")
msg["From"] = EMAIL_USER
msg["To"] = destinatario
msg["Subject"] = asunto
msg["Date"] = fecha_envio # Agregar la fecha en la cabecera del correo
# Formato del mensaje con la fecha en el cuerpo for i in range(1, num_mensajes + 1):
mensaje_completo = f""" response, lines, octets = mail.retr(i)
asdasdsad raw_email = b"\n".join(lines)
msg = email.message_from_bytes(raw_email)
{mensaje} remitente = msg["From"]
""" asunto = msg["Subject"]
fecha = msg["Date"]
msg.attach(MIMEText(mensaje_completo, "plain")) # Mensaje en texto plano if fecha:
try:
fecha = parsedate_to_datetime(fecha).strftime("%Y-%m-%d %H:%M:%S")
except Exception:
pass
# Conectar al servidor SMTP SIN SSL cuerpo = ""
server = smtplib.SMTP(SMTP_SERVER, SMTP_PORT) if msg.is_multipart():
server.ehlo() for part in msg.walk():
server.login(EMAIL_USER, EMAIL_PASS) # Iniciar sesión if part.get_content_type() == "text/plain":
server.sendmail(EMAIL_USER, destinatario, msg.as_string()) cuerpo = part.get_payload(decode=True).decode(errors="ignore")
server.quit() break
else:
cuerpo = msg.get_payload(decode=True).decode(errors="ignore")
print(f"Correo enviado a {destinatario} el {fecha_envio}") guardar_correo(remitente, asunto, fecha, cuerpo.strip())
mail.quit()
print("✅ Descarga de correos completada.\n")
except Exception as e: except Exception as e:
print(f"Error enviando correo: {e}") print(f"❌ Error al descargar correos: {e}")
# Uso del script def mostrar_correos():
enviar_correo("kevin@psp.ieslamar.org", "Prueba de Correo", "Este es un mensaje de prueba sin SSL.") """ Muestra todos los correos almacenados en MongoDB. """
print("📂 Mostrando correos almacenados en la base de datos...\n")
correos = collection.find()
for correo in correos:
print(f"📅 Fecha: {correo['fecha']}")
print(f"🔹 Remitente: {correo['remitente']}")
print(f"📌 Asunto: {correo['asunto']}")
print(f"📝 Mensaje:\n{correo['cuerpo']}")
print("-" * 40)
def menu():
""" Menú interactivo para ejecutar las opciones del programa. """
while True:
print("\n📬 MENÚ:")
print("1. Descargar correos nuevos")
print("2. Mostrar correos almacenados")
print("3. Salir")
opcion = input("Seleccione una opción: ")
if opcion == "1":
descargar_correos()
elif opcion == "2":
mostrar_correos()
elif opcion == "3":
print("👋 Saliendo...")
break
else:
print("❌ Opción no válida, intente de nuevo.")
# Ejecutar el menú interactivo
menu()

127
Main2.py
View File

@ -1,107 +1,46 @@
import poplib import smtplib
import email from email.mime.multipart import MIMEMultipart
import pymongo from email.mime.text import MIMEText
import threading from datetime import datetime
from email.utils import parsedate_to_datetime
# Configuración del servidor POP3 (Sin SSL) # Configuración del servidor SMTP (Sin SSL)
POP3_SERVER = "192.168.120.103" SMTP_SERVER = "192.168.120.103"
POP3_PORT = 110 # Puerto POP3 estándar sin SSL SMTP_PORT = 25 # También puedes probar 587 si 25 no funciona
EMAIL_USER = "kevin@psp.ieslamar.org" EMAIL_USER = "pruebas@psp.ieslamar.org"
EMAIL_PASS = "1234" EMAIL_PASS = "1234"
# Configuración de la base de datos MongoDB def enviar_correo(destinatario, asunto, mensaje):
MONGO_CLIENT = "mongodb://localhost:27017/"
DB_NAME = "correo_db"
COLLECTION_NAME = "correos"
# Conectar a MongoDB
client = pymongo.MongoClient(MONGO_CLIENT)
db = client[DB_NAME]
collection = db[COLLECTION_NAME]
def guardar_correo(remitente, asunto, fecha, cuerpo):
""" Guarda un correo en la base de datos si no existe. """
if collection.find_one({"remitente": remitente, "asunto": asunto, "fecha": fecha}):
print("⚠️ Correo ya guardado, se omite.")
return
correo = {
"remitente": remitente,
"asunto": asunto,
"fecha": fecha,
"cuerpo": cuerpo
}
collection.insert_one(correo)
print("✅ Correo guardado en la base de datos.")
def descargar_correos():
""" Descarga correos en un hilo separado y los guarda en MongoDB. """
try: try:
print("📡 Conectando al servidor POP3 para descargar correos...\n") # Obtener la fecha y hora actual
mail = poplib.POP3(POP3_SERVER, POP3_PORT) fecha_envio = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
mail.user(EMAIL_USER)
mail.pass_(EMAIL_PASS)
num_mensajes = len(mail.list()) # Crear mensaje con la fecha incluida
print(f"📩 Se encontraron {num_mensajes} correos en la bandeja de entrada.\n") msg = MIMEMultipart()
msg["From"] = EMAIL_USER
msg["To"] = destinatario
msg["Subject"] = asunto
msg["Date"] = fecha_envio # Agregar la fecha en la cabecera del correo
for i in range(max(1, num_mensajes - 4), num_mensajes + 1): # Formato del mensaje con la fecha en el cuerpo
response, lines, octets = mail.retr(i) mensaje_completo = f"""
raw_email = b"\n".join(lines) asdasdsad
msg = email.message_from_bytes(raw_email)
remitente = msg["From"] {mensaje}
asunto = msg["Subject"] """
fecha = msg["Date"]
if fecha: msg.attach(MIMEText(mensaje_completo, "plain")) # Mensaje en texto plano
try:
fecha = parsedate_to_datetime(fecha).strftime("%Y-%m-%d %H:%M:%S")
except Exception:
pass
cuerpo = "" # Conectar al servidor SMTP SIN SSL
if msg.is_multipart(): server = smtplib.SMTP(SMTP_SERVER, SMTP_PORT)
for part in msg.walk(): server.ehlo()
if part.get_content_type() == "text/plain": server.login(EMAIL_USER, EMAIL_PASS) # Iniciar sesión
cuerpo = part.get_payload(decode=True).decode(errors="ignore") server.sendmail(EMAIL_USER, destinatario, msg.as_string())
break server.quit()
else:
cuerpo = msg.get_payload(decode=True).decode(errors="ignore")
guardar_correo(remitente, asunto, fecha, cuerpo.strip()) print(f"Correo enviado a {destinatario} el {fecha_envio}")
mail.quit()
print("✅ Descarga de correos completada.\n")
except Exception as e: except Exception as e:
print(f"❌ Error al descargar correos: {e}") print(f"Error enviando correo: {e}")
def consultar_correos(): # Uso del script
""" Consulta los correos almacenados en MongoDB y los muestra en otro hilo. """ enviar_correo("kevin@psp.ieslamar.org", "Prueba de Correo", "Este es un mensaje de prueba sin SSL.")
print("📂 Consultando correos en la base de datos...\n")
correos = collection.find()
for correo in correos:
print(f"📅 Fecha: {correo['fecha']}")
print(f"🔹 Remitente: {correo['remitente']}")
print(f"📌 Asunto: {correo['asunto']}")
print(f"📝 Mensaje:\n{correo['cuerpo']}")
print("-" * 40)
def ejecutar_en_hilos():
""" Ejecuta la descarga y consulta de correos en hilos separados para mayor eficiencia. """
hilo_descarga = threading.Thread(target=descargar_correos)
hilo_consulta = threading.Thread(target=consultar_correos)
# Iniciar hilos
hilo_descarga.start()
hilo_consulta.start()
# Esperar a que terminen
hilo_descarga.join()
hilo_consulta.join()
# Ejecutar el programa con hilos
ejecutar_en_hilos()

117
Main3.py
View File

@ -0,0 +1,117 @@
import poplib
import email
import pymongo
from email.utils import parsedate_to_datetime
# Configuración del servidor POP3 (Sin SSL)
POP3_SERVER = "192.168.120.103"
POP3_PORT = 110 # Puerto POP3 estándar sin SSL
EMAIL_USER = "kevin@psp.ieslamar.org"
EMAIL_PASS = "1234"
# Configuración de la base de datos MongoDB
MONGO_CLIENT = "mongodb://localhost:27017/"
DB_NAME = "correo_db"
COLLECTION_NAME = "correos"
# Conectar a MongoDB
client = pymongo.MongoClient(MONGO_CLIENT)
db = client[DB_NAME]
collection = db[COLLECTION_NAME]
def correo_existe(remitente, asunto, fecha):
""" Verifica si un correo ya existe en la base de datos. """
return collection.find_one({"remitente": remitente, "asunto": asunto, "fecha": fecha}) is not None
def guardar_correo(remitente, asunto, fecha, cuerpo):
""" Guarda un correo en la base de datos si no existe. """
if correo_existe(remitente, asunto, fecha):
print("⚠️ Correo ya guardado, se omite.")
return
correo = {
"remitente": remitente,
"asunto": asunto,
"fecha": fecha,
"cuerpo": cuerpo
}
collection.insert_one(correo)
print("✅ Correo guardado en la base de datos.")
def descargar_correos():
""" Descarga correos desde el servidor y solo guarda los nuevos. """
try:
print("📡 Conectando al servidor POP3 para descargar correos...\n")
mail = poplib.POP3(POP3_SERVER, POP3_PORT)
mail.user(EMAIL_USER)
mail.pass_(EMAIL_PASS)
num_mensajes = len(mail.list()[1])
print(f"📩 Se encontraron {num_mensajes} correos en la bandeja de entrada.\n")
for i in range(1, num_mensajes + 1):
response, lines, octets = mail.retr(i)
raw_email = b"\n".join(lines)
msg = email.message_from_bytes(raw_email)
remitente = msg["From"]
asunto = msg["Subject"]
fecha = msg["Date"]
if fecha:
try:
fecha = parsedate_to_datetime(fecha).strftime("%Y-%m-%d %H:%M:%S")
except Exception:
pass
cuerpo = ""
if msg.is_multipart():
for part in msg.walk():
if part.get_content_type() == "text/plain":
cuerpo = part.get_payload(decode=True).decode(errors="ignore")
break
else:
cuerpo = msg.get_payload(decode=True).decode(errors="ignore")
guardar_correo(remitente, asunto, fecha, cuerpo.strip())
mail.quit()
print("✅ Descarga de correos completada.\n")
except Exception as e:
print(f"❌ Error al descargar correos: {e}")
def mostrar_correos():
""" Muestra todos los correos almacenados en MongoDB. """
print("📂 Mostrando correos almacenados en la base de datos...\n")
correos = collection.find()
for correo in correos:
print(f"📅 Fecha: {correo['fecha']}")
print(f"🔹 Remitente: {correo['remitente']}")
print(f"📌 Asunto: {correo['asunto']}")
print(f"📝 Mensaje:\n{correo['cuerpo']}")
print("-" * 40)
def menu():
""" Menú interactivo para ejecutar las opciones del programa. """
while True:
print("\n📬 MENÚ:")
print("1. Descargar correos nuevos")
print("2. Mostrar correos almacenados")
print("3. Salir")
opcion = input("Seleccione una opción: ")
if opcion == "1":
descargar_correos()
elif opcion == "2":
mostrar_correos()
elif opcion == "3":
print("👋 Saliendo...")
break
else:
print("❌ Opción no válida, intente de nuevo.")
# Ejecutar el menú interactivo
menu()