FEAT: Added automated email bot after authentication
This commit is contained in:
@@ -3,6 +3,7 @@ from werkzeug.security import generate_password_hash, check_password_hash
|
||||
from flask_cors import cross_origin
|
||||
from database.database import Database
|
||||
from blueprints.utils import login_required, sanitizer
|
||||
from blueprints.email import send_email
|
||||
from utils.user_utils import get_user_id
|
||||
from secrets import token_hex
|
||||
|
||||
@@ -99,6 +100,7 @@ def signup():
|
||||
session["username"] = username
|
||||
session["user_id"] = get_user_id(username)
|
||||
print(f"Logged in as {username}. session: {session.get('username')}. user_id: {session.get('user_id')}", flush=True)
|
||||
# send_email(username)
|
||||
|
||||
return jsonify({
|
||||
"account_created": True,
|
||||
@@ -114,6 +116,7 @@ def signup():
|
||||
|
||||
finally:
|
||||
db.close_connection()
|
||||
|
||||
|
||||
|
||||
@auth_bp.route("/login", methods=["POST"])
|
||||
|
||||
@@ -1,33 +1,46 @@
|
||||
from flask import Blueprint
|
||||
from flask import Blueprint, session
|
||||
from database.database import Database
|
||||
|
||||
import smtplib
|
||||
from email.mime.text import MIMEText
|
||||
|
||||
from os import getenv
|
||||
from random import randrange
|
||||
from dotenv import load_dotenv
|
||||
|
||||
load_dotenv()
|
||||
|
||||
email_bp = Blueprint("email", __name__)
|
||||
|
||||
def send_email(user_email) -> None:
|
||||
def send_email(username) -> None:
|
||||
"""
|
||||
Send a verification email to the user.
|
||||
"""
|
||||
|
||||
# Setup the sender email details
|
||||
SMTP_SERVER = "smtp.gmail.com"
|
||||
SMTP_PORT = 587
|
||||
SMTP_EMAIL = getenv("EMAIL")
|
||||
SMTP_PASSWORD = getenv("EMAIL_PASSWORD")
|
||||
|
||||
user_email = get_user_email(username)
|
||||
|
||||
# Setup up the receiver details
|
||||
login_code = randrange(100000, 1000000)
|
||||
body = f"Here is your login code: {login_code}" # Make this better
|
||||
msg = MIMEText(body)
|
||||
body = f"""
|
||||
<html>
|
||||
<head></head>
|
||||
<body>
|
||||
<b>Thank you for choosing Gander</b>
|
||||
<p>Your Gander login code is: {login_code}</p>
|
||||
</body>
|
||||
</html>
|
||||
"""
|
||||
msg = MIMEText(body, "html")
|
||||
msg["Subject"] = "Reset Gander Login"
|
||||
msg["From"] = SMTP_EMAIL
|
||||
msg["To"] = user_email
|
||||
|
||||
|
||||
# Send the email using smtplib
|
||||
with smtplib.SMTP(SMTP_SERVER, SMTP_PORT) as smtp:
|
||||
try:
|
||||
@@ -40,4 +53,20 @@ def send_email(user_email) -> None:
|
||||
print("Server timed out")
|
||||
|
||||
except Exception as e:
|
||||
print("Error: ", e)
|
||||
print("Error: ", e)
|
||||
|
||||
def get_user_email(username):
|
||||
"""
|
||||
Get the users email address.
|
||||
"""
|
||||
|
||||
db = Database()
|
||||
db.create_connection()
|
||||
|
||||
user_email = db.fetchone("""SELECT email
|
||||
FROM users
|
||||
WHERE username = ?;""",
|
||||
(username,))
|
||||
email = user_email["email"]
|
||||
db.close_connection()
|
||||
return email
|
||||
Reference in New Issue
Block a user