Portfolio / app.py
simar007's picture
Upload 9 files
1106e39 verified
from flask import Flask, render_template, request, redirect, url_for, session, flash
from werkzeug.security import generate_password_hash, check_password_hash
app = Flask(__name__)
app.secret_key = "supersecretkey" # change this in production!
# Simple in-memory "database"
users = {}
@app.route("/")
def home():
if "user" in session:
return redirect(url_for("dashboard"))
return redirect(url_for("login"))
@app.route("/signup", methods=["GET", "POST"])
def signup():
if request.method == "POST":
username = request.form["username"]
password = request.form["password"]
confirm_password = request.form.get("confirmPassword")
if password != confirm_password:
flash("Passwords do not match.", "danger")
return redirect(url_for("signup"))
if username in users:
flash("Username already exists!", "danger")
return redirect(url_for("signup"))
users[username] = generate_password_hash(password)
flash("Signup successful! Please login.", "success")
return redirect(url_for("login"))
return render_template("signup.html")
@app.route("/login", methods=["GET", "POST"])
def login():
if request.method == "POST":
username = request.form["username"]
password = request.form["password"]
if username in users and check_password_hash(users[username], password):
session["user"] = username
return redirect(url_for("dashboard"))
else:
flash("Invalid username or password", "danger")
return render_template("login.html")
@app.route("/dashboard")
def dashboard():
if "user" not in session:
return redirect(url_for("login"))
return render_template("dashboard.html", username=session["user"])
@app.route("/portfolio")
def portfolio():
if "user" not in session:
return redirect(url_for("login"))
return render_template("portfolio.html")
@app.route("/logout")
def logout():
session.pop("user", None)
flash("Logged out successfully.", "info")
return redirect(url_for("login"))
if __name__ == "__main__":
app.run(host="0.0.0.0", port=7860, debug=True)