Ací es mostren les diferències entre la revisió seleccionada i la versió actual de la pàgina.
Següent revisió | Revisió prèvia | ||
django_ninja [2025/02/05 22:15] enric_mieza_sanchez creat |
django_ninja [2025/03/21 16:18] (actual) enric_mieza_sanchez [Autenticació] |
||
---|---|---|---|
Línia 24: | Línia 24: | ||
Destaquem dos mètodes d' | Destaquem dos mètodes d' | ||
- | * Basic Authentication | + | |
- | * Token Authentication | + | |
Es poden implementar les dues amb aquest codi: | Es poden implementar les dues amb aquest codi: | ||
- | <code api.py | + | < |
+ | from django.contrib.auth import authenticate as django_authenticate | ||
+ | from ninja import NinjaAPI, Schema | ||
+ | from ninja.security import HttpBasicAuth, | ||
+ | from typing import List, Optional | ||
+ | from .models import * | ||
+ | import secrets | ||
+ | api = NinjaAPI() | ||
+ | |||
+ | # Autenticació bàsica | ||
+ | class BasicAuth(HttpBasicAuth): | ||
+ | def authenticate(self, | ||
+ | user = django_authenticate(username=username, | ||
+ | if user: | ||
+ | # Genera un token simple | ||
+ | token = secrets.token_hex(16) | ||
+ | user.auth_token = token | ||
+ | user.save() | ||
+ | return token | ||
+ | return None | ||
+ | |||
+ | # Autenticació per Token Bearer | ||
+ | class AuthBearer(HttpBearer): | ||
+ | def authenticate(self, | ||
+ | try: | ||
+ | user = Usuari.objects.get(auth_token=token) | ||
+ | return user | ||
+ | except Usuari.DoesNotExist: | ||
+ | return None | ||
+ | |||
+ | # Endpoint per obtenir un token, accés amb BasicAuth | ||
+ | # amb o sense " | ||
+ | @api.get("/ | ||
+ | @api.get("/ | ||
+ | def obtenir_token(request): | ||
+ | return {" | ||
+ | |||
+ | # Exemple d' | ||
+ | class LlibreOut(Schema): | ||
+ | id: int | ||
+ | titol: str | ||
+ | editorial: Optional[str] | ||
+ | |||
+ | @api.get("/ | ||
+ | def get_llibres(request): | ||
+ | qs = Llibre.objects.all() | ||
+ | return qs | ||
</ | </ | ||
+ | |||
+ | A part, també caldrà afegir la columna '' | ||
+ | |||
+ | <code python models.py> | ||
+ | from django.contrib.auth.models import AbstractUser | ||
+ | |||
+ | class Usuari(AbstractUser): | ||
+ | auth_token = models.CharField(max_length=32, | ||
+ | # + altres atributs que es vulguin afegir... | ||
+ | </ | ||
+ | |||
+ | I a '' | ||
+ | |||
+ | <code python settings.py> | ||
+ | AUTH_USER_MODEL = ' | ||
+ | </ | ||
+ | |||
+ | Per tal que els canvis es guardin a la base de dades caldrà crear i executar les migracions adequades: | ||
+ | |||
+ | (env) $ ./manage.py makemigrations | ||
+ | (env) $ ./manage.py migrate | ||
+ | |||
+ | <WRAP important> | ||
+ | Afegir canvis en el model d' | ||
+ | |||
+ | Si no tenim dades de producció, el més fàcil és esborrar la base de dades, esborrar tots els arxius de migració, i tornar a crear-los amb: | ||
+ | |||
+ | (env) $ ./manage.py makemigrations < | ||
+ | |||
+ | Una possible alternativa, | ||
+ | </ | ||
\\ | \\ | ||
+ | |||
+ | ===== Mes curl ===== | ||
+ | |||
+ | El típic exemple de request amb Basic Authentication seria: | ||
+ | curl -u admin: | ||
+ | |||
+ | De vegades ens pot interessar una alternativa enviant les dades codificades en base64 en els // | ||
+ | curl -H ' | ||
+ | |||
+ | Per obtenir el //hash// en base64 es pot fer: | ||
+ | echo -n " | ||
+ | |||
+ | Per aconseguir un //pretty print// del JSON es pot fer amb la [[https:// | ||
+ | curl -u admin: | ||
+ | |||
+ | Per instal·lar jq es pot fer: | ||
+ | sudo apt install jq | ||