|||

Django – #31 – REST API cz. 7 – Określenie z góry wartości danych

Wprowadzenie.

Często zdarza się tak, że niektóre dane powinny być zapisane z góry ustaloną wartością i na dodatek nie powinniśmy mieć możliwości podmiany takiej danej. W tym wpisie przedstawiłem, jak możemy uzyskać taką funkcjonalność.

  1. Django REST API cz. 1– Tworzenie nowego projektu 
  2. Django REST API cz. 2 – ListAPIView 
  3. Django REST API cz. 3 – Wbudowana strona logowania
  4. Django REST API cz. 4 – Widoki generyczne
  5. Django REST API cz. 5 – ListCreateAPIView i konfiguracja dostępu
  6. Django REST API cz. 6 – Uszczegóławianie odpowiedzi  
  7. Django REST API cz. 7 – Określenie z góry wartości danych ⇐
  8. Django REST API cz. 8 – RetrieveDestroyAPIView
  9. Django REST API cz. 9 – RetrieveUpdateAPIView
  10. Django REST API cz. 10 – Nadpisywanie zachowań metod przed/po operacji zapisu/usuwania
  11. Django REST API cz. 11 – Rejestracja nowego użytkownika poprzez API  
  12. Django REST API cz. 12 – Uwierzytelnianie przy pomocy Tokena 
  13. Django REST API cz. 13 – Generowanie tokena dla istniejących użytkowników

Zakres artykułu.

  • Określenie z góry wartości danych

Określenie z góry wartości danych

Załóżmy teraz, że w naszej bibliotece każdy użytkownik będzie sam sobie wypożyczał książki. W takim przypadku, po zalogowaniu się, powinniśmy mieć możliwość wyboru jedynie książki, która nas interesuje. W związku z tym wróćmy do pliku z widokami i zmodyfikujmy klasę BorrowList(), tak aby każdy użytkownik miał możliwość wypożyczania sobie książki.

Po zalogowaniu się na dowolne konto i przejściu na stronę 127.0.0.1:800/api/borrows będziemy ponownie mieli dostęp do requesta metodą POST.

Na ten moment jak możemy zobaczyć, każdy użytkownik ma możliwość wypożyczenia nie tylko sobie książki, lecz także każdej innej osobie. Zatem musimy wprowadzić kolejną modyfikację, która zablokuje taką możliwość.

Następnie w widoku w klasie BorrowList() musimy nadpisać metodę def perform_create(), która jest wywoływana przez klasę CreateModelMixin w czasie tworzenia nowej instancji obiektu. W metodzie tej, do pola user_id musimy przypisać siebie przy pomocy metody self.request.user. Więcej o tej oraz podobnych metodach możemy przeczytać na stronie pod tym linkiem.

Następnie w pliku serializers.py należy jeszcze ukryć pole user_id oraz ustawić je jedynie do odczytu, tak aby nie było możliwości zmiany wartości tego pola.

Efekt naszej pracy zamieściłem poniżej. Jak możemy zobaczyć, w formularzu dla requesta POST nie ma już pola user_id, natomiast po wysłaniu tego requesta, wypożyczenie zostało przypisane do usera, który jest aktualnie zalogowany.  

  1. Django REST API cz. 1– Tworzenie nowego projektu 
  2. Django REST API cz. 2 – ListAPIView 
  3. Django REST API cz. 3 – Wbudowana strona logowania
  4. Django REST API cz. 4 – Widoki generyczne
  5. Django REST API cz. 5 – ListCreateAPIView i konfiguracja dostępu
  6. Django REST API cz. 6 – Uszczegóławianie odpowiedzi  
  7. Django REST API cz. 7 – Określenie z góry wartości danych ⇐
  8. Django REST API cz. 8 – RetrieveDestroyAPIView
  9. Django REST API cz. 9 – RetrieveUpdateAPIView
  10. Django REST API cz. 10 – Nadpisywanie zachowań metod przed/po operacji zapisu/usuwania
  11. Django REST API cz. 11 – Rejestracja nowego użytkownika poprzez API  
  12. Django REST API cz. 12 – Uwierzytelnianie przy pomocy Tokena 
  13. Django REST API cz. 13 – Generowanie tokena dla istniejących użytkowników

Autor artykułu
Dominik Bednarski

Podobne wpisy

Dodaj komentarz

Twój adres e-mail nie zostanie opublikowany. Wymagane pola są oznaczone *