Saltearse al contenido

Assert / Upsert

Los endpoints de tipo assert ofrecen semántica idempotente de creación o actualización (upsert). Si existe un registro coincidente, se actualiza; de lo contrario, se crea uno nuevo. Esto permite invocarlos repetidamente sin generar duplicados.


Assert Contact

PUT /contacts/assert

Crea o actualiza un contacto individual. La coincidencia se busca primero por work_email y, si no se encuentra, por linkedin_url.

Requiere list_id y al menos una clave de coincidencia (work_email o linkedin_url).

Cuerpo de la solicitud

CampoTipoRequeridoDescripción
list_idintegerID de la lista de destino
work_emailstringNo*Correo corporativo (clave de coincidencia principal)
linkedin_urlstringNo*URL de LinkedIn (clave de coincidencia alternativa)
first_namestringNoNombre
last_namestringNoApellido
job_titlestringNoCargo
company_domainstringNoDominio de la empresa
Cualquier otro campo de contacto

*Se requiere al menos uno de work_email o linkedin_url.

Ejemplo

Ventana de terminal
curl -X PUT "https://api.graph8.com/api/v1/contacts/assert" \
-H "Authorization: Bearer $API_KEY" \
-H "Content-Type: application/json" \
-d '{
"list_id": 5,
"work_email": "[email protected]",
"first_name": "Jane",
"last_name": "Doe",
"job_title": "VP of Sales"
}'

Respuesta

{
"data": {
"action": "created",
"count": 1
}
}

El campo action indica el resultado: "created" para un registro nuevo y "updated" para una coincidencia existente.


Batch Assert Contacts

PUT /contacts/assert/batch

Crea o actualiza hasta 100 contactos a la vez. Cada contacto debe incluir work_email o linkedin_url como clave de coincidencia.

Cuerpo de la solicitud

CampoTipoRequeridoDescripción
list_idintegerID de la lista de destino
contactsobject[]Hasta 100 objetos de contacto

Ejemplo

Ventana de terminal
curl -X PUT "https://api.graph8.com/api/v1/contacts/assert/batch" \
-H "Authorization: Bearer $API_KEY" \
-H "Content-Type: application/json" \
-d '{
"list_id": 5,
"contacts": [
{"work_email": "[email protected]", "first_name": "Jane"},
{"work_email": "[email protected]", "first_name": "Bob"}
]
}'

Respuesta

{
"data": {
"total": 2,
"created": 2,
"updated": 0,
"errors": []
}
}

Assert Company

PUT /companies/assert

Crea o actualiza una empresa. La coincidencia se busca primero por domain y, si no se encuentra, por linkedin_url.

Cuerpo de la solicitud

CampoTipoRequeridoDescripción
list_idintegerID de la lista de destino
domainstringNo*Dominio de la empresa (clave de coincidencia principal)
linkedin_urlstringNo*URL de LinkedIn (clave de coincidencia alternativa)
namestringNoNombre de la empresa
industrystringNoIndustria
employee_countintegerNoNúmero de empleados
Cualquier otro campo de empresa

*Se requiere al menos uno de domain o linkedin_url.

Ejemplo

Ventana de terminal
curl -X PUT "https://api.graph8.com/api/v1/companies/assert" \
-H "Authorization: Bearer $API_KEY" \
-H "Content-Type: application/json" \
-d '{
"list_id": 5,
"domain": "acme.com",
"name": "Acme Inc",
"industry": "Technology"
}'

Respuesta

{
"data": {
"action": "created",
"count": 1
}
}

Batch Assert Companies

PUT /companies/assert/batch

Crea o actualiza hasta 100 empresas a la vez.

Cuerpo de la solicitud

CampoTipoRequeridoDescripción
list_idintegerID de la lista de destino
companiesobject[]Hasta 100 objetos de empresa

Assert Deal

PUT /deals/assert

Crea o actualiza una oportunidad. La coincidencia se realiza por name + company_id.

Cuerpo de la solicitud

CampoTipoRequeridoDescripción
namestringNombre de la oportunidad (clave de coincidencia)
company_idstringNoID de la empresa (clave de coincidencia, combinada con el nombre)
amountnumberNoValor monetario
currencystringNoCódigo de moneda
stage_idstringNoID de la etapa del pipeline
pipeline_idstringNoID del pipeline
descriptionstringNoDescripción de la oportunidad
close_datestringNoFecha estimada de cierre (ISO 8601)

Ejemplo

Ventana de terminal
curl -X PUT "https://api.graph8.com/api/v1/deals/assert" \
-H "Authorization: Bearer $API_KEY" \
-H "Content-Type: application/json" \
-d '{
"name": "Enterprise Deal",
"amount": 50000,
"company_id": "comp-123"
}'

Respuesta

{
"data": {
"action": "created",
"deal_id": "deal-new-abc"
}
}

Assert Deal-Contact Association

PUT /contacts/{contact_id}/deals/assert

Vincula un contacto con una oportunidad. Es idempotente: si la asociación ya existe, devuelve "exists" sin error.

Cuerpo de la solicitud

CampoTipoRequeridoDescripción
deal_idstringID de la oportunidad por asociar

Ejemplo

Ventana de terminal
curl -X PUT "https://api.graph8.com/api/v1/contacts/12345/deals/assert" \
-H "Authorization: Bearer $API_KEY" \
-H "Content-Type: application/json" \
-d '{"deal_id": "deal-abc"}'

Respuesta

{
"data": {
"action": "created",
"deal_id": "deal-abc",
"contact_id": 12345
}
}

El campo action devuelve "created" para un vínculo nuevo, o "exists" si la asociación ya existía.