Skip to main content
GET
/
entities
/
{id}
Obtener
curl --request GET \
  --url http://api.gu1.ai/entities/{id} \
  --header 'Authorization: Bearer <token>'
{
  "id": "<string>",
  "externalId": "<string>",
  "organizationId": "<string>",
  "type": "<string>",
  "name": "<string>",
  "taxId": "<string>",
  "countryCode": "<string>",
  "riskScore": 123,
  "riskFactors": [
    {}
  ],
  "status": "<string>",
  "kycVerified": true,
  "kycProvider": "<string>",
  "kycData": {},
  "entityData": {},
  "attributes": {},
  "currentEvaluation": {},
  "createdAt": "<string>",
  "updatedAt": "<string>",
  "deletedAt": "<string>"
}

Resumen

Recupera los detalles completos de una persona, incluyendo el estado de evaluación y la valoración de riesgo. Podés consultar una persona de tres formas:
MétodoEndpointCuándo usar
Por IDGET /entities/{id}Tenés el UUID interno de la entidad en gu1
Por external IDGET /entities/by-external-id/{externalId}Usás tu propio identificador (ej. customer_12345)
Por tax IDGET /entities/by-tax-id/{taxId}Tenés el documento fiscal (CUIT, CPF, etc.) y querés buscar la persona
Los tres devuelven el mismo objeto. El alcance de organización se aplica según tu API key.

Endpoints

Obtener por ID

GET http://api.gu1.ai/entities/{id}
id
string
required
ID único (UUID) de gu1 de la persona a recuperar

Obtener por external ID

GET http://api.gu1.ai/entities/by-external-id/{externalId}
externalId
string
required
Tu identificador externo de esta persona (el valor enviado al crear la entidad)

Obtener por tax ID

GET http://api.gu1.ai/entities/by-tax-id/{taxId}
taxId
string
required
Número de identificación fiscal (formato según país: CUIT Argentina, CPF Brasil, etc.). Debe coincidir con el tax ID almacenado de la entidad en tu organización.

Autenticación

Requiere una clave API válida en el encabezado Authorization:
Authorization: Bearer YOUR_API_KEY

Respuesta

Devuelve el objeto completo de la persona con los siguientes campos:
id
string
ID interno de entidad de gu1
externalId
string
Tu identificador externo para esta persona
organizationId
string
Tu ID de organización
type
string
Siempre “person”
name
string
Nombre para mostrar de la persona
taxId
string
Número de identificación fiscal
countryCode
string
Código de país ISO 3166-1 alpha-2
riskScore
number
Puntuación de riesgo calculada de 0 (bajo riesgo) a 100 (alto riesgo)
riskFactors
array
Array de factores de riesgo identificados que contribuyen a la puntuación de riesgo
status
string
Estado de la persona: active, inactive, under_review, approved, rejected, suspended
kycVerified
boolean
Si la verificación KYC ha sido completada
kycProvider
string
Nombre del proveedor KYC utilizado (si aplica)
kycData
object
Datos de verificación KYC del proveedor
entityData
object
Estructura de datos específica de la persona
attributes
object
Atributos personalizados como pares clave-valor
currentEvaluation
object
Resultados de evaluación de IA más recientes (null si no existe evaluación)
  • id - ID de evaluación
  • entityId - ID de entidad
  • evaluationType - Tipo de evaluación realizada
  • result - Resultado de evaluación
  • confidence - Puntuación de confianza (0-1)
  • evaluatedAt - Marca de tiempo de evaluación
createdAt
string
Marca de tiempo ISO 8601 de creación de la persona
updatedAt
string
Marca de tiempo ISO 8601 de última actualización
deletedAt
string
Marca de tiempo ISO 8601 de eliminación lógica (null si no está eliminada)

Ejemplos

Por ID (UUID)

curl -X GET http://api.gu1.ai/entities/550e8400-e29b-41d4-a716-446655440000 \
  -H "Authorization: Bearer YOUR_API_KEY"

Por external ID

curl -X GET "http://api.gu1.ai/entities/by-external-id/customer_12345" \
  -H "Authorization: Bearer YOUR_API_KEY"

Por tax ID

curl -X GET "http://api.gu1.ai/entities/by-tax-id/20-12345678-9" \
  -H "Authorization: Bearer YOUR_API_KEY"

Ejemplo de Respuesta

{
  "id": "550e8400-e29b-41d4-a716-446655440000",
  "externalId": "customer_12345",
  "organizationId": "8e2f89ab-c216-4eb4-90eb-ca5d44499aaa",
  "type": "person",
  "name": "María González",
  "taxId": "20-12345678-9",
  "countryCode": "AR",
  "riskScore": 25,
  "riskFactors": [
    {
      "factor": "new_customer",
      "impact": 15,
      "description": "Customer registered within last 30 days"
    },
    {
      "factor": "high_income_occupation",
      "impact": -10,
      "description": "Professional occupation with verified income"
    }
  ],
  "status": "active",
  "kycVerified": true,
  "kycProvider": "gueno_ai",
  "kycData": {
    "verificationDate": "2024-10-03T14:30:00Z",
    "documentsVerified": ["national_id", "proof_of_address"],
    "livenessCheck": "passed",
    "overallStatus": "approved"
  },
  "entityData": {
    "person": {
      "firstName": "María",
      "lastName": "González",
      "dateOfBirth": "1985-03-15",
      "nationality": "AR",
      "occupation": "Software Engineer",
      "income": 85000
    }
  },
  "attributes": {
    "email": "maria.gonzalez@example.com",
    "phone": "+54 11 1234-5678",
    "customerSince": "2024-01-15",
    "accountTier": "premium"
  },
  "currentEvaluation": {
    "id": "eval_abc123",
    "entityId": "550e8400-e29b-41d4-a716-446655440000",
    "evaluationType": "risk_assessment",
    "result": {
      "overallRisk": "low",
      "amlRisk": "low",
      "fraudRisk": "low",
      "complianceScore": 95,
      "recommendation": "approve"
    },
    "confidence": 0.92,
    "evaluatedAt": "2024-10-03T14:35:00Z"
  },
  "createdAt": "2024-10-03T14:30:00.000Z",
  "updatedAt": "2024-10-03T14:35:00.000Z",
  "deletedAt": null
}

Respuestas de Error

404 Not Found

{
  "error": "Entity not found"
}

401 Unauthorized

{
  "error": "Invalid or missing API key"
}

500 Internal Server Error

{
  "error": "Failed to fetch entity"
}

Casos de Uso

Verificación de KYC

Recuperar un cliente para verificar su estado KYC antes de aprobar una transacción:
const person = await fetch(`http://api.gu1.ai/entities/${customerId}`, {
  headers: { 'Authorization': 'Bearer YOUR_API_KEY' }
}).then(res => res.json());

if (person.kycVerified && person.status === 'active') {
  // Proceder con la transacción
  console.log('Customer verified, risk score:', person.riskScore);
} else {
  // Solicitar verificación adicional
  console.log('KYC verification required');
}

Monitoreo de Puntuación de Riesgo

Verificar la puntuación de riesgo actual y factores para monitoreo continuo:
person = requests.get(
    f'http://api.gu1.ai/entities/{person_id}',
    headers={'Authorization': 'Bearer YOUR_API_KEY'}
).json()

if person['riskScore'] > 70:
    # Alto riesgo - activar debida diligencia mejorada
    print(f"High risk person detected: {person['riskScore']}")
    print("Risk factors:", person['riskFactors'])
elif person['riskScore'] > 40:
    # Riesgo medio - aplicar monitoreo adicional
    print(f"Medium risk person: {person['riskScore']}")

Próximos Pasos