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:
committed by
GitHub
parent
47ea00c822
commit
ed92991872
@@ -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.
|
||||
Reference in New Issue
Block a user