summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCaine <caine@jihakuz.xyz>2026-04-02 16:33:31 +0100
committerCaine <caine@jihakuz.xyz>2026-04-02 16:33:31 +0100
commitfe00286f7558d379d392f8a46d10a4689f95d472 (patch)
tree23a27fc7b8c97b56e30d9a7bd9135a921be83209
parent487bf469795d70fb2bfdbee882d00f0c5e726a9a (diff)
Add API: URLs, token auth, what-can-i-cook endpoint, log-cook with pantry deduction, browsable API
-rw-r--r--food_project/settings.py12
-rw-r--r--food_project/urls.py4
-rw-r--r--kitchen/urls.py22
-rw-r--r--kitchen/views.py8
4 files changed, 43 insertions, 3 deletions
diff --git a/food_project/settings.py b/food_project/settings.py
index 43a0ede..5e3dcee 100644
--- a/food_project/settings.py
+++ b/food_project/settings.py
@@ -38,9 +38,21 @@ INSTALLED_APPS = [
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework',
+ 'rest_framework.authtoken',
'kitchen',
]
+# Django REST Framework
+REST_FRAMEWORK = {
+ 'DEFAULT_AUTHENTICATION_CLASSES': [
+ 'rest_framework.authentication.TokenAuthentication',
+ 'rest_framework.authentication.SessionAuthentication', # for admin/browsable API
+ ],
+ 'DEFAULT_PERMISSION_CLASSES': [
+ 'rest_framework.permissions.IsAuthenticated',
+ ],
+}
+
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
diff --git a/food_project/urls.py b/food_project/urls.py
index ab55255..8acbe51 100644
--- a/food_project/urls.py
+++ b/food_project/urls.py
@@ -15,8 +15,10 @@ Including another URLconf
2. Add a URL to urlpatterns: path('blog/', include('blog.urls'))
"""
from django.contrib import admin
-from django.urls import path
+from django.urls import path, include
urlpatterns = [
path('admin/', admin.site.urls),
+ path('api/', include('kitchen.urls')),
+ path('api-auth/', include('rest_framework.urls')), # browsable API login
]
diff --git a/kitchen/urls.py b/kitchen/urls.py
new file mode 100644
index 0000000..7dedb7a
--- /dev/null
+++ b/kitchen/urls.py
@@ -0,0 +1,22 @@
+from django.urls import path, include
+from rest_framework.routers import DefaultRouter
+from . import views
+
+router = DefaultRouter()
+router.register(r"tags", views.TagViewSet)
+router.register(r"ingredients", views.IngredientViewSet)
+router.register(r"pantry", views.PantryItemViewSet)
+router.register(r"meta-recipes", views.MetaRecipeViewSet)
+router.register(r"slots", views.SlotViewSet)
+router.register(r"slot-options", views.SlotOptionViewSet)
+router.register(r"meta-recipe-bases", views.MetaRecipeBaseViewSet)
+router.register(r"recipes", views.RecipeViewSet)
+router.register(r"recipe-ingredients", views.RecipeIngredientViewSet)
+router.register(r"cook-log", views.CookLogViewSet)
+router.register(r"shopping-list", views.ShoppingListItemViewSet)
+
+urlpatterns = [
+ path("", include(router.urls)),
+ path("what-can-i-cook/", views.what_can_i_cook, name="what-can-i-cook"),
+ path("log-cook/", views.log_cook, name="log-cook"),
+]
diff --git a/kitchen/views.py b/kitchen/views.py
index 7521e50..58685ab 100644
--- a/kitchen/views.py
+++ b/kitchen/views.py
@@ -205,8 +205,12 @@ def what_can_i_cook(request):
warnings = get_pantry_warnings(base.ingredient_id)
if available < needed:
- if base.ingredient.is_staple_ingredient:
- # Staples like oil/salt — assume always available even if tracking says 0
+ # Check if this ingredient is tracked as a staple in the pantry
+ is_staple = PantryItem.objects.filter(
+ ingredient=base.ingredient, is_staple=True
+ ).exists()
+ if is_staple:
+ # Staples like oil/salt — assume always available
pass
else:
recipe_result["base_missing"].append({