2024-03-05 16:01:26 +01:00
import base64
2024-03-08 14:05:22 +01:00
from flask import abort
from mysql . connector import Error
from app . extensions import db_connection
2024-03-05 16:01:26 +01:00
class ProductService :
2024-03-10 17:11:26 +01:00
@staticmethod
def get_products ( page : int ) :
try :
with db_connection . cursor ( dictionary = True ) as cursor :
offset = 10 * page
cursor . execute ( " select product.id, user.displayname as seller, product.name, product.price_pc from product inner join user on user.id = product.seller_id order by product.id limit 10 offset %s " , ( offset , ) )
results = cursor . fetchall ( )
if len ( results ) < 1 :
return { " Failed " : " Failed to fetch products. You ' ve probably selected too far with pages " } , 400
result_obj = [ ]
for row in results :
mid_result = {
" id " : row [ ' id ' ] ,
" seller " : row [ ' seller ' ] ,
" name " : row [ ' name ' ] ,
" price " : row [ ' price_pc ' ]
}
result_obj . append ( mid_result )
return result_obj , 200
except Error as e :
2024-03-10 21:19:34 +01:00
return { " Failed " : f " Failed to fetch products. Error: { e } " } , 500
2024-03-10 17:11:26 +01:00
2024-03-05 16:01:26 +01:00
@staticmethod
2024-03-10 21:19:34 +01:00
def get_product_info ( fields : list [ str ] , product_id : int ) :
try :
with db_connection . cursor ( dictionary = True ) as cursor :
fields_to_sql = {
" name " : " product.name " ,
" price " : " product.price_pc as price " ,
" image " : " product.image " ,
" image_name " : " product.image_name " ,
" seller " : " user.displayname as seller "
}
field_sql = [ ]
2024-03-05 16:01:26 +01:00
2024-03-10 21:19:34 +01:00
for field in fields :
field_sql . append ( fields_to_sql [ field ] )
2024-03-08 14:05:22 +01:00
2024-03-10 21:19:34 +01:00
select_params = " , " . join ( field_sql )
2024-03-08 14:05:22 +01:00
2024-03-10 21:19:34 +01:00
if " seller " in fields :
cursor . execute ( f " select { select_params } from product inner join user on user.id = product.seller_id where product.id = %s " , ( product_id , ) )
else :
cursor . execute ( f " select { select_params } from product where id = %s " , ( product_id , ) )
2024-03-05 16:01:26 +01:00
2024-03-10 21:19:34 +01:00
result = cursor . fetchone ( )
2024-03-05 16:01:26 +01:00
2024-03-10 21:19:34 +01:00
if cursor . rowcount != 1 :
return { " Failed " : " Failed to fetch product. Product likely doesn ' t exist " } , 400
result_obj = { }
2024-03-08 14:05:22 +01:00
2024-03-10 21:19:34 +01:00
for field in fields :
if field == " image " : # Encode image into base64
result_obj [ field ] = base64 . b64encode ( result [ field ] ) . decode ( ' utf-8 ' )
else :
result_obj [ field ] = result [ field ]
2024-03-05 16:01:26 +01:00
2024-03-10 21:19:34 +01:00
return result_obj , 200
except Error as e :
return { " Failed " : f " Failed to fetch product info. Error: { e } " } , 500
2024-03-07 22:16:29 +01:00
@staticmethod
2024-03-08 14:05:22 +01:00
def create_listing ( name : str , seller_id : str , price : float , image_name : str , image ) :
try :
db_cursor . execute ( " insert into product(seller_id, name, price_pc, image, image_name) values ( %s , %s , %s , %s , %s ) " , ( seller_id , name , price , image , image_name ) )
db_connection . commit ( )
except Error as e :
return { " Failed " : f " Failed to create product. { e } " } , 400
return { " Success " , " Successfully created new product listing " } , 200