flask react app

hi guys, can help please to solve this issue in my flask-react app.

the issue is when i try to send data to the backend first time when
i click submit it’s work but when i try for the second time give me an issue
sqlalchemy.exc.IntegrityError: (…

hi guys, can help please to solve this issue in my flask-react app.

the issue is when i try to send data to the backend first time when
i click submit it’s work but when i try for the second time give me an issue
sqlalchemy.exc.IntegrityError: (sqlite3.IntegrityError) UNIQUE constraint failed: user.id

but when i refresh my flask code work again and so on.

from enum import unique
from bcrypt import hashpw
from flask import Flask, request, session, json, url_for, redirect, jsonify
from  datetime import datetime
from flask_cors import CORS, cross_origin
from sqlalchemy.exc import DontWrapMixin
import os
from uuid import uuid4
from flask_sqlalchemy import SQLAlchemy
from flask_bcrypt import Bcrypt
from flask_session import Session
import redis

app = Flask(__name__)
CORS(app, supports_credentials=True)
db = SQLAlchemy(app)
bcrypt = Bcrypt(app)
app.secret_key = os.urandom(24)
app.config["SQLALCHEMY_DATABASE_URI"] = "sqlite:///UserInfo.db"
app.config['SESSION_TYPE'] = 'filesystem'
app.config['SESSION_PERMANENT'] = True
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
server_session = Session(app)

####/////////////////////
class User(db.Model):
    id = db.Column(db.String(40), primary_key = True, default=uuid4().hex)
    email = db.Column(db.String(200),  unique=True,  nullable = False)
    fullname = db.Column(db.String(30), nullable = False)
    password = db.Column(db.String(200), nullable = False)
    birthday = db.Column(db.String(10),  nullable = False)
    def __str__(self):
        return f"{self.id} {self.fullname} {self.birthday} {self.email} {self.password}"

def user_serializer(user):
    return{
        "id":user.id,
        "email":user.email,
        "birthday":user.birthday,
        "fullname" : user.fullname,
        "password" : user.password
    }

@app.route("/api", methods=['GET'])
def home():
    return jsonify([*map(user_serializer, User.query.all())])

class Product_info(db.Model):
    id = db.Column(db.String(40), primary_key=True, default=uuid4().hex)
    title = db.Column(db.String(), nullable = False)

    def __str__(self):
        return f'{self.id}{self.title}'
def productInfo_serializer(info):
    return{
        "id":info.id,
        "title":info.title,
    }
@app.route("/products", methods=["POST"])
def products():
    request_data = json.loads(request.data)
    newproducts = Product_info(
        title = request_data["title"]
    )
    db.session.add(newproducts)
    db.session.commit()
    return{"201":"login succsufl"}

@app.route("/productsinfo", methods=['GET'])
def productsinfo():
    return jsonify([*map(productInfo_serializer, Product_info.query.all())])

class Orders(db.Model):
    id = db.Column(db.String(40), primary_key=True, default=uuid4().hex)
    date = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)
    fullname = db.Column(db.String, nullable=False)
    email = db.Column(db.String(30), unique=True)
    address = db.Column(db.String, nullable=False)
    city = db.Column(db.String, nullable=False)
    countery = db.Column(db.String, nullable=False)
    state = db.Column(db.String, nullable=False)
    zipcode = db.Column(db.String, nullable=False)
    products = db.Column(db.PickleType, nullable=False)

    def __str__(self):      
        return f'{self.id}{self.date} {self.fullname} {self.email} {self.address} {self.countery} {self.city} {self.state} {self.zipcode} {self.products}'

def orders_serializer(order):
    return{
        "id":order.id,
        "date":order.date,
        "fullname":order.fullname,
        "email":order.email,
        "address":order.address,
        "countery":order.countery,
        "city":order.city,
        "state":order.state,
        "zipcode":order.zipcode,
        "products":order.products,
    }


    ###//////////////////////////////////////////

@app.route("/orders",methods = ["POST"])
def orders():
    request_data = json.loads(request.data) #covert data to python dectionerie;
    userorder = Orders(
                    fullname = request_data["fullname"],
                    email = request_data["email"],
                    address = request_data["address"],
                    countery = request_data["countery"],
                    city = request_data["city"],
                    state = request_data["state"],
                    zipcode = request_data["zipcode"],
                    products= request_data["products"]   
                )
    db.session.add(userorder)
    db.session.commit()
    return {"201":"login succesfuly"}

@app.route("/info", methods=['GET'])
def info():
    return jsonify([*map(orders_serializer, Orders.query.all())])


@app.route("/register", methods=["POST"])
def register():
    request_data = json.loads(request.data)
    email = request_data["email"]
    password = request_data["password"]
    user_exist = User.query.filter_by(email = email).first()
    if user_exist is not None:
        return {"409":"the user already exist"}

    hashed_password = bcrypt.generate_password_hash(password)
    new_user = User(
        fullname = request_data["fullname"],
        email = request_data["email"],
        password = hashed_password,
        birthday = request_data["birthday"]      
    )

    db.session.add(new_user)
    db.session.commit()
    session["user_id"] = new_user.id
    return {"201":"login succesfuly"}

@app.route("/login",methods=["POST"])
def login():
    request_data = json.loads(request.data) #covert data to python dectionerie
    email = request_data["email"]
    password = request_data["password"]
    user = User.query.filter_by(email = email).first()
    if user is None:
        return {"error":401},401
    if not bcrypt.check_password_hash(user.password, password):
        return {"error":401},401
    session["user_id"] = user.id
    return{
        "201":"logging succesful",
        "id": user.id,
        "email":user.email
        }

@app.route("/profile", methods=["GET"])
def profile():
    user_id = session.get("user_id")
    if not user_id:
        return jsonify({"error":"antorizedt"})
    user = User.query.filter_by(id = user_id).first()
    return jsonify({
        "id": user.id,
        "email": user.email
    })

@app.route("/logout", methods =["GET"])
def logout_user():
    session.pop("user_id")

if __name__ =="__main":
    app.run(debug=True)




Print Share Comment Cite Upload Translate
APA
ouabi1999 | Sciencx (2024-03-29T14:53:53+00:00) » flask react app. Retrieved from https://www.scien.cx/2022/02/02/flask-react-app/.
MLA
" » flask react app." ouabi1999 | Sciencx - Wednesday February 2, 2022, https://www.scien.cx/2022/02/02/flask-react-app/
HARVARD
ouabi1999 | Sciencx Wednesday February 2, 2022 » flask react app., viewed 2024-03-29T14:53:53+00:00,<https://www.scien.cx/2022/02/02/flask-react-app/>
VANCOUVER
ouabi1999 | Sciencx - » flask react app. [Internet]. [Accessed 2024-03-29T14:53:53+00:00]. Available from: https://www.scien.cx/2022/02/02/flask-react-app/
CHICAGO
" » flask react app." ouabi1999 | Sciencx - Accessed 2024-03-29T14:53:53+00:00. https://www.scien.cx/2022/02/02/flask-react-app/
IEEE
" » flask react app." ouabi1999 | Sciencx [Online]. Available: https://www.scien.cx/2022/02/02/flask-react-app/. [Accessed: 2024-03-29T14:53:53+00:00]
rf:citation
» flask react app | ouabi1999 | Sciencx | https://www.scien.cx/2022/02/02/flask-react-app/ | 2024-03-29T14:53:53+00:00
https://github.com/addpipe/simple-recorderjs-demo