Skip to main content
PATCH
/
transactions
/
{id}
Actualizar transacción
curl --request PATCH \
  --url http://api.gu1.ai/transactions/{id} \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '
{
  "metadata": {},
  "deviceDetails": {},
  "channel": {},
  "reason": "<string>"
}
'

Documentation Index

Fetch the complete documentation index at: https://docs.gu1.ai/llms.txt

Use this file to discover all available pages before exploring further.

Resumen

Usá este endpoint para enriquecer o corregir una transacción después del alta: metadata, deviceDetails, channel o reason. No modifica monto, estado, contrapartes u otros campos núcleo (para estado usá Cambiar estado).
Merge superficial en metadata y deviceDetails: solo se pisan las claves que enviés; el resto se conserva. Los objetos anidados (p. ej. metadata.tags) se reemplazan enteros si mandás esa clave. Para limpiar channel, mandá "channel": null.

Endpoints

MétodoEndpointCuándo
Por IDPATCH /transactions/{id}Tenés el UUID interno de gu1
Por external IDPATCH /transactions/external/{externalId}Solo tenés tu externalId del create
Mismo body y misma respuesta en ambos.
PATCH https://api.gu1.ai/transactions/{id}
PATCH https://api.gu1.ai/transactions/external/{externalId}

Autenticación

Requiere transactions:edit:
Authorization: Bearer YOUR_API_KEY

Parámetros de consulta

executeRules
boolean
default:"false"
Con true, re-ejecuta reglas KYT con trigger transaction_updated después del patch. Default: false.

Body

Al menos un campo es obligatorio.
metadata
object
Merge superficial sobre el metadata existente. Las claves omitidas no se borran.
deviceDetails
object
Merge superficial sobre deviceDetails existente (columna device_details). Para agregar o corregir contexto de dispositivo post-alta: ipAddress, deviceId, osName, manufacturer, model, flags (isVpn, isEmulator, …). Mismo esquema que Crear transacción. Las reglas usan rutas como deviceDetails.ipAddress.
channel
string | null
Canal de la transacción (máx. 50 caracteres). null para limpiar.
reason
string
Motivo de resultado/rechazo. Ver Enum reason.

Ejemplo

{
  "metadata": {
    "clientReference": "INV-2026-0042",
    "tags": { "segment": "retail" }
  },
  "deviceDetails": {
    "ipAddress": "203.0.113.10",
    "deviceId": "dev-abc-123",
    "osName": "iOS",
    "osVersion": "17.0",
    "manufacturer": "Apple",
    "model": "iPhone"
  },
  "channel": "mobile",
  "reason": "FRAUD_SUSPECTED"
}

Respuesta (200 OK)

Devuelve success, el subconjunto actualizado en transaction (id, externalId, channel, reason, metadata, deviceDetails, updatedAt) y opcionalmente rulesExecutionSummary si executeRules=true.

Errores

EstadoCódigoCuándo
400VALIDATION_ERRORBody inválido
400NO_CHANGESLos valores ya coinciden con lo guardado
404NOT_FOUNDTransacción inexistente en tu org
403Sin permiso transactions:edit

Efectos secundarios

  • Auditoría: evento transaction_updated en la línea de tiempo (changes puede incluir metadata, deviceDetails, channel, reason).
  • Webhook: transaction.updated (incluye mapa changes y deviceDetails actual cuando aplica).
  • Reglas: solo con executeRules=true.

Ejemplo

curl -X PATCH "https://api.gu1.ai/transactions/external/tx_12345" \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{"metadata":{"note":"Corregido post callback"},"channel":"api"}'

Relacionado

Obtener transacción

Leer la transacción completa

Cambiar estado

Actualizar status

Crear transacción

Metadata en el alta

Enum reason

Valores de reason