diff options
| author | Caine <caine@jihakuz.xyz> | 2026-04-02 16:33:31 +0100 |
|---|---|---|
| committer | Caine <caine@jihakuz.xyz> | 2026-04-02 16:33:31 +0100 |
| commit | fe00286f7558d379d392f8a46d10a4689f95d472 (patch) | |
| tree | 23a27fc7b8c97b56e30d9a7bd9135a921be83209 | |
| parent | 487bf469795d70fb2bfdbee882d00f0c5e726a9a (diff) | |
Add API: URLs, token auth, what-can-i-cook endpoint, log-cook with pantry deduction, browsable API
| -rw-r--r-- | food_project/settings.py | 12 | ||||
| -rw-r--r-- | food_project/urls.py | 4 | ||||
| -rw-r--r-- | kitchen/urls.py | 22 | ||||
| -rw-r--r-- | kitchen/views.py | 8 |
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({ |
