docs: add full documentation for all functions in tienda/views.py

Agent-Logs-Url: https://github.com/dsaub/proyecto-final/sessions/49df17c8-213a-4e23-adfe-465a0104f6a3

Co-authored-by: dsaub <54474838+dsaub@users.noreply.github.com>
This commit is contained in:
copilot-swe-agent[bot]
2026-04-09 10:35:28 +00:00
committed by GitHub
parent 47ea00c822
commit ed92991872
66 changed files with 2580 additions and 0 deletions
+55
View File
@@ -0,0 +1,55 @@
# `create_checkout_session`
**Archivo:** `tienda/views.py`
**URL:** `/tienda/crear-sesion-pago/`
**Tipo:** Vista privada (requiere autenticación)
**Método HTTP:** Solo `POST`
**Decoradores:** `@login_required`, `@csrf_exempt`
## Descripción
Crea una sesión de pago en Stripe Checkout y devuelve el ID de sesión al frontend. Es llamada por JavaScript para iniciar el flujo de pago con tarjeta.
El proceso es:
1. Obtiene y valida la dirección de envío seleccionada.
2. Verifica que el carrito no esté vacío y que no haya problemas de stock.
3. Crea una reserva de stock atómica para bloquear el inventario.
4. Construye los `line_items` con precios IVA incluido.
5. Crea la sesión en Stripe con URLs de retorno y cancelación.
6. Guarda el ID de sesión, la dirección y la reserva en la sesión HTTP.
## Firma
```python
def create_checkout_session(request: HttpRequest):
```
## Parámetros
| Nombre | Tipo | Descripción |
|-----------|---------------|-----------------------|
| `request` | `HttpRequest` | Petición HTTP de Django. |
## Cuerpo de la petición (JSON o form-data)
| Campo | Descripción |
|------------------------|-------------------------------------------|
| `shipping_address_id` | ID de la dirección de envío seleccionada. |
## Respuesta exitosa
```json
{ "sessionId": "cs_live_..." }
```
## Respuestas de error
| Código | Descripción |
|--------|--------------------------------------------------|
| 400 | Carrito vacío, stock insuficiente, sin dirección. |
| 405 | Método no permitido. |
| 500 | Error interno al crear la sesión en Stripe. |
> [!IMPORTANT]
> La reserva de stock creada expira en `STOCK_RESERVATION_MINUTES` minutos. Si el usuario no completa el pago en ese tiempo, el stock queda liberado automáticamente.