import base64 from flask import abort from mysql.connector import Error from app.extensions import db_connection class ProductService: @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: return {"Failed": f"Failed to fetch products. Reason: {e}"}, 400 @staticmethod def get_name(product_id: int): db_cursor.execute(f"select name from product where product.id = {product_id}") if db_cursor.rowcount != 1: return abort(404) result = db_cursor.fetchone() return result['name'] @staticmethod def get_manufacturer(product_id: int): db_cursor.execute(f"select user.displayname as seller from product inner join user on product.seller_id = user.id where product.id = {product_id}") if db_cursor.rowcount != 1: return abort(404) result = db_cursor.fetchone() return result['seller'] @staticmethod def get_price(product_id: int): db_cursor.execute(f"select price_pc from product where product.id = {product_id}") if db_cursor.rowcount != 1: return abort(404) result = db_cursor.fetchone() return result['price_pc'] @staticmethod def get_image(product_id: int): db_cursor.execute(f"select image from product where product.id = {product_id}") if db_cursor.rowcount != 1: return abort(404) result = db_cursor.fetchone() return base64.b64encode(result['image']).decode('utf-8') @staticmethod def get_image_name(product_id: int): db_cursor.execute(f"select image_name from product where product.id = {product_id}") if db_cursor.rowcount != 1: return abort(404) result = db_cursor.fetchone() return result['image_name'] @staticmethod def get_all_info(product_id: int): db_cursor.execute(f"select name, user.displayname as seller, price_pc, image_name, image from product inner join user on product.seller_id = user.id where product.id = {product_id}") if db_cursor.rowcount != 1: return abort(404) result = db_cursor.fetchone() return { "name": result['name'], "seller": result['seller'], "price": result['price_pc'], "image_name": result['image_name'], "image": base64.b64encode(result['image']).decode('utf-8') } @staticmethod 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