moved files into layer dir

uebung_entities
Felix Jan Michael Mucha 2024-11-30 18:05:58 +01:00
parent 84b3e9ff95
commit 938fee1a4e
6 changed files with 35 additions and 27 deletions

View File

@ -3,8 +3,26 @@
** Master MDS HSMA **
Clean Architecture - Architekturstil am praktischen Beispiel z.B. in Python.
run python script as a module e.g.: python -m framework_driver.db.db_cart
# Layer: Framework Driver Database
- Implemented a small sqllite3 database for a online shop
## Layers
- entities
- cart_item.py
- cart.py
- product.py
- use_cases
- cart_reporsitory_interface.py
- view_cart.py
- interfaces_adapters
- cart_database_interface.py
- cart_repository.py
- framework_driver
- db
- db_cart.py
- db_product.py
- db_setup.py
- db_user.py
- shop.db
- ui
- coming soon ...

View File

@ -1,6 +1,8 @@
import sqlite3
from typing import Optional, List
from interface_adapters.cart_database_interface import CartDatabaseInterface
class CartDatabase:
class CartDatabase(CartDatabaseInterface):
def __init__(self, db_file):
"""Initialize the CartDatabase with a connection to the SQLite database."""
self.conn = sqlite3.connect(db_file)
@ -16,16 +18,17 @@ class CartDatabase:
except sqlite3.Error as e:
print(e)
def get_cart_for_user(self, user_id):
"""Retrieve the cart items for a specific user."""
def fetch_cart_items(self, user_id: int) -> Optional[List[dict]]:
"""Fetch cart items from the database for a given user ID."""
sql = "SELECT * FROM cart WHERE user_id = ?"
try:
c = self.conn.cursor()
c.execute(sql, (user_id,))
return c.fetchall()
rows = c.fetchall()
return [{"id": row[0], "user_id": row[1], "product_id": row[2], "quantity": row[3]} for row in rows]
except sqlite3.Error as e:
print(e)
return []
return None
def update_cart_item(self, user_id, product_id, quantity):
"""Update the quantity of a specific cart item based on user_id and product_id."""
@ -57,19 +60,9 @@ class CartDatabase:
except sqlite3.Error as e:
print(e)
def get_cart_total(self, user_id):
"""Calculate the total cost of all items in a user's cart."""
sql = "SELECT SUM(products.price * cart.quantity) FROM cart JOIN products ON cart.product_id = products.id WHERE cart.user_id = ?"
try:
c = self.conn.cursor()
c.execute(sql, (user_id,))
return c.fetchone()[0]
except sqlite3.Error as e:
print(e)
return 0
def main():
database = "db/shop.db"
database = "framework_driver/db/shop.db"
cart_db = CartDatabase(database)
@ -81,14 +74,11 @@ def main():
# user id, product id, quantity
cart_db.add_to_cart(ex_user_id, 1, 2)
cart_db.add_to_cart(ex_user_id, 3, 5)
print(f"Cart items for user {ex_user_id}:", cart_db.get_cart_for_user(ex_user_id))
print(f"Total cost for user {ex_user_id}:", cart_db.get_cart_total(ex_user_id))
print(f"Cart items for user {ex_user_id}:", cart_db.fetch_cart_items(ex_user_id))
# user id, product id, quantity
cart_db.update_cart_item(ex_user_id, 3, 3)
print(f"Cart items for user {ex_user_id}:", cart_db.get_cart_for_user(ex_user_id))
print(f"Total cost for user {ex_user_id}:", cart_db.get_cart_total(ex_user_id))
print(f"Cart items for user {ex_user_id}:", cart_db.fetch_cart_items(ex_user_id))
if __name__ == "__main__":
main()

View File

@ -59,7 +59,7 @@ class ProductDatabase:
print(e)
def main():
database = "db/shop.db"
database = "framework_driver/db/shop.db"
product_db = ProductDatabase(database)

View File

@ -29,7 +29,7 @@ def delete_table(conn, table_name):
print(e)
def main():
database = "db/shop.db"
database = "framework_driver/db/shop.db"
sql_user_table = """CREATE TABLE IF NOT EXISTS users (
id INTEGER PRIMARY KEY,

View File

@ -60,7 +60,7 @@ class UserDatabase:
return []
def main():
database = "db/shop.db"
database = "framework_driver/db/shop.db"
user_db = UserDatabase(database)