Added simple code documentation

This commit is contained in:
Thastertyn 2024-03-10 23:10:41 +01:00
parent afc9db32e4
commit 2a2783fd09
2 changed files with 81 additions and 0 deletions

View File

@ -7,6 +7,17 @@ class CartService:
@staticmethod @staticmethod
def add_to_cart(user_id: str, product_id: int, count: int) -> Tuple[Union[dict, str], int]: def add_to_cart(user_id: str, product_id: int, count: int) -> Tuple[Union[dict, str], int]:
"""
Adds a product to a user's cart.
:param user_id: User ID.
:type user_id: str
:param product_id: ID of product to be added.
:type product_id: int
:return: Tuple containing a dictionary with a token and an HTTP status code.
:rtype: Tuple[Union[dict, str], int]
"""
try: try:
with db_connection.cursor(dictionary=True) as cursor: with db_connection.cursor(dictionary=True) as cursor:
cursor.execute("select count from cart_item where cart_id = %s and product_id = %s", (user_id, product_id)) cursor.execute("select count from cart_item where cart_id = %s and product_id = %s", (user_id, product_id))
@ -26,6 +37,19 @@ class CartService:
@staticmethod @staticmethod
def update_count(user_id: str, product_id: int, count: int) -> Tuple[Union[dict, str], int]: def update_count(user_id: str, product_id: int, count: int) -> Tuple[Union[dict, str], int]:
"""
Updates count of products in user's cart
:param user_id: User ID.
:type user_id: str
:param product_id: ID of product to be updated.
:type product_id: int
:param count: New count of products
:type count: int
:return: Tuple containing a dictionary with a token and an HTTP status code.
:rtype: Tuple[Union[dict, str], int]
"""
try: try:
if count <= 0: if count <= 0:
return CartService.delete_from_cart(user_id, product_id) return CartService.delete_from_cart(user_id, product_id)
@ -41,6 +65,18 @@ class CartService:
@staticmethod @staticmethod
def delete_from_cart(user_id: str, product_id: int) -> Tuple[Union[dict, str], int]: def delete_from_cart(user_id: str, product_id: int) -> Tuple[Union[dict, str], int]:
"""
Completely deletes an item from a user's cart
:param user_id: User ID.
:type user_id: str
:param product_id: ID of product to be updated.
:type product_id: int
:return: Tuple containing a dictionary with a token and an HTTP status code.
:rtype: Tuple[Union[dict, str], int]
"""
try: try:
with db_connection.cursor() as cursor: with db_connection.cursor() as cursor:
cursor.execute("delete from cart_item where cart_id = %s and product_id = %s", (user_id, product_id)) cursor.execute("delete from cart_item where cart_id = %s and product_id = %s", (user_id, product_id))
@ -53,6 +89,15 @@ class CartService:
@staticmethod @staticmethod
def show_cart(user_id: str) -> Tuple[Union[dict, str], int]: def show_cart(user_id: str) -> Tuple[Union[dict, str], int]:
"""
Gives the user the content of their cart
:param user_id: User ID.
:type user_id: str
:return: Tuple containing a dictionary with a token and an HTTP status code.
:rtype: Tuple[Union[dict, str], int]
"""
try: try:
with db_connection.cursor(dictionary=True) as cursor: with db_connection.cursor(dictionary=True) as cursor:
cursor.execute("select product.name as product_name, count, price_subtotal, date_added from cart_item inner join product on cart_item.product_id = product.id where cart_item.cart_id = %s", (user_id,)) cursor.execute("select product.name as product_name, count, price_subtotal, date_added from cart_item inner join product on cart_item.product_id = product.id where cart_item.cart_id = %s", (user_id,))
@ -78,6 +123,15 @@ class CartService:
@staticmethod @staticmethod
def purchase(user_id: str) -> Tuple[Union[dict, str], int]: def purchase(user_id: str) -> Tuple[Union[dict, str], int]:
"""
"Purchases" the contents of user's cart
:param user_id: User ID.
:type user_id: str
:return: Tuple containing a dictionary with a token and an HTTP status code.
:rtype: Tuple[Union[dict, str], int]
"""
try: try:
with db_connection.cursor(dictionary=True) as cursor: with db_connection.cursor(dictionary=True) as cursor:
# get all cart items # get all cart items

View File

@ -11,6 +11,13 @@ class ProductService:
@staticmethod @staticmethod
def get_products(page: int): def get_products(page: int):
"""
Fetches 10 products
:param page: Page, aka offset of fetching
:type page: int
"""
try: try:
with db_connection.cursor(dictionary=True) as cursor: with db_connection.cursor(dictionary=True) as cursor:
@ -39,6 +46,15 @@ class ProductService:
@staticmethod @staticmethod
def get_product_info(fields: list[str], product_id: int): def get_product_info(fields: list[str], product_id: int):
"""
Fetches specific product info
:param fields: array of fields that can be fetched
:type fields: list[str]
:param product_id: ID of product to be updated.
:type product_id: int
"""
try: try:
with db_connection.cursor(dictionary=True) as cursor: with db_connection.cursor(dictionary=True) as cursor:
fields_to_sql = { fields_to_sql = {
@ -79,6 +95,17 @@ class ProductService:
@staticmethod @staticmethod
def create_listing(seller_id: str, name: str, price: float): def create_listing(seller_id: str, name: str, price: float):
"""
Creates a new product listing
:param seller_id: User ID
:type seller_id: str
:param name: New product's name
:type name: str
:param price: New product's price
:type price: float
"""
try: try:
with db_connection.cursor() as cursor: with db_connection.cursor() as cursor:
rounded_price = round(price, 2) rounded_price = round(price, 2)