Create a person automatically with enrichment
API Reference
Create a person automatically with enrichment
Automatically create person with enriched data from registries — for person entities in the gu1 KYC and risk analysis platform, with examples for create.
POST
Create a person automatically with enrichment
Overview
The automatic person creation endpoint allows you to create persons by providing minimal information (tax ID and country). The system automatically:- Fetches person data from official registries
- Enriches the person with additional information
- Executes enrichments automatically
Endpoint
Authentication
Requires a valid API key in the Authorization header:Request Body
Tax identification number of the person (e.g., CPF for Brazil, CURP for Mexico, CUIT for Argentina)
ISO 3166-1 alpha-2 country code (e.g., “BR”, “MX”, “AR”, “CL”)
Must be set to
personYour unique identifier for this person (optional, will be auto-generated if not provided)
Mark this person as a client/customer for tracking purposes
One or more risk matrix UUIDs (legacy: a single UUID string). After creation, active rules tied to those matrices run (unless
skipRulesExecution is true).Preferred for multiple matrices: ordered UUID list. Takes precedence over
riskMatrixId when non-empty.Skip automatic rules execution after person creation
Initial status for the person
Optional main entity operational hours (
timezone + weekly). Persisted on automatic creation the same as manual entity creation. Not applied to shareholders or relationships created via depth.Depth of relationship extraction (0-5). Controls how many levels of relationships to automatically fetch and create.
0: No relationships (only main entity)1: Direct relationships only2: Relationships + their relationships3-5: Additional levels (use with caution - can create many entities)
Configure automatic execution of integrations for the main person entity. See Provider Codes Reference for available codes.Type: Example:
object (optional)Properties:executeAllActiveEnrichments(boolean, optional, default:false) - Execute all active enrichment integrationsenrichments(array, optional, default:[]) - Array of specific enrichment provider codes to executeenrichmentGroupRefs(array of strings, optional) - Marketplace enrichment group slugs (enrichments only). WithexecuteAllActiveEnrichments: false, groups are resolved and merged with explicitenrichments. WithexecuteAllActiveEnrichments: true, group refs are ignored (not resolved); explicitenrichmentsmay still append after the active set.
Configure automatic execution of integrations for discovered relationships. Useful when using Example:
depth > 0. See Provider Codes Reference for available codes.Type: object (optional)Properties:executeAllActiveEnrichments(boolean, optional, default:false) - Execute all active enrichments on related entitiesenrichments(object, optional) - Specific enrichments by entity typecompany(array, default:[]) - Enrichments for company relationshipsperson(array, default:[]) - Enrichments for person relationships
enrichmentGroupRefs(array of strings, optional) - Same slugs as on the main object; applied to bothcompanyandpersonwhenexecuteAllActiveEnrichmentsisfalse. WhenexecuteAllActiveEnrichmentsistrueon this object, group refs are ignored; explicit per-typeenrichmentsmay still append after each side’s active set.
Required Enrichment Codes by Country
Brazil (BR)
| Scenario | Required Enrichment Code(s) | Description |
|---|---|---|
| Main entity | br_bdc_basic_data_enrichment | Fetches person data via BDC/CPF (full name, date of birth, address, etc.) |
Relationships (depth > 0) | br_bdc_related_companies_enrichment AND br_bdc_related_persons_enrichment | Both required in autoExecuteIntegrations.enrichments. Fetches companies and persons related to the individual |
The relationship enrichments must be included in the main entity’s
autoExecuteIntegrations.enrichments array (not in autoExecuteIntegrationsShareholders), because the system needs to run them on the main person to discover the relationships. The autoExecuteIntegrationsShareholders field controls what enrichments to run on each related entity after they are created.Argentina (AR)
| Scenario | Required Enrichment Code | Description |
|---|---|---|
| Main entity | ar_nosis_extended_verification_enrichment | Fetches person data from Nosis |
Optional — Client values for the main person that must not be replaced by enrichments. Full reference (root vs
entityData): Automatic entity creation.Fields: name, email, phone, birthDate → entityData.person.dateOfBirth, address → entityData.person.address, gender (enum: M | F | male | female | other | unknown — use other for non-binary; see Create entity).Example:Optional - Custom attributes as key-value pairs for the created entity.Applied only to the main entity (the person created), not to relationships/shareholders. Useful for business segments, tags, internal IDs, or any metadata you want to associate at creation time.Structure: object with string keys and values of any type (string, number, boolean, array, etc.).Example:
Response
Indicates if the person was created successfully
Complete information about the creation:
entity(object) - The person created with all datasummary(object) - Creation summaryerrors(object, optional) - Details of any errors
Result of rules execution (only present when rules ran, e.g. when skipRulesExecution is
false and a risk matrix is configured via riskMatrixId or riskMatrixIds), or null. When present, includes:- success (boolean) - Whether rules executed successfully
- rulesTriggered (number) - Number of rules that were triggered
- alerts (array) - Alerts generated by rules
- riskScore (number) - Final calculated risk score
- decision (string) - Final decision (APPROVE, REJECT, HOLD, REVIEW_REQUIRED)
- rulesExecutionSummary (object) - Present when rules ran. See below for structure.
At the root of the response (same as transactions API). Same value as
rulesResult.rulesExecutionSummary. Only present when rules ran (e.g. skipRulesExecution is false and risk matrix was executed). Summary of which rules matched (hit) vs did not match (no hit), executed actions, and total score. Omitted when rules did not run. See Rules Execution Summary for the full structure and a complete example.- rulesHit (array) - Rules whose conditions were met. Each item: name, description, score, priority, category, status (e.g.
active,shadow), conditions (array of{ field, value, operator? }), actions (alerts, suggestion, status, assignedUser). - rulesNoHit (array) - Rules that were evaluated but conditions were not met. Same structure as rulesHit (includes configured actions, not executed).
- actionsExecuted (object) - Aggregated executed actions across all rules that hit: alerts, suggestion (
BLOCK|SUSPEND|FLAG, highest weight), status (entity status applied, if any), assignedUser ({ userId }, if any), customKeys (array of strings, optional) — custom action keys from matched rules; for integrations/workflows. - totalScore (number) - Sum of score of all rules that hit and are not in
shadowstatus.
Examples
Create Person with All Active Integrations
Create Person with Specific Integrations
Response Example
Error Responses
400 Bad Request - Invalid Tax ID
404 Not Found - Person Not Found in Registry
409 Conflict - Person Already Exists
Best Practices
- Error handling: Always check the
successfield in the response - Rate limiting: Be mindful of rate limits when creating multiple persons
- Integration selection: Choose specific integrations for better control over cost and performance
Next Steps
- Get Person - Retrieve person details
- Create Person Manually - Create persons with your own data
- Create KYC Validation - Start identity verification