How it’s designed
Every KYC is designed as a process that has five fundamental properties:code: A unique identifier for the process.status: As the name implies, this is the status of the process.verification: An object describing how the process should be completed, including who is responsible for verification, how the process is driven, and any dependencies on other processes.input: The input is data provided by the user when prompted to complete the process.output: The output is data that came out from verifying the input data provided by the user.
Statuses
Thestatus field can have the following values:
exempt: The process is exempt from verification.pending: The process is pending information from the user.processing: The process is currently being verified.ok: The process has been successfully verified.failed: The process has failed verification.
Verification
Every KYC process exposes averification object that describes how it must be completed for the current user and organization:
model: who is responsible for verifying the data.uphold-verified: Uphold always produces theoutput. Depending on the process, verification is either driven by a third-party provider session (no explicit update possible) or byinputsubmitted by your organization.partner-verified: Your organization always produces bothinputandoutput, performing the verification directly and typically resulting in immediateokstatus.
method: whether the process requires explicit input or advances automatically.manual: requires explicit input from the user or your organization (e.g., form answers, documents, or direct data submission).automatic: Uphold runs this without user input, triggered automatically when the processes listed intriggerscomplete.
triggers: the list of processes whose completion causes this process to run automatically. Only present whenmethodisautomaticand at least one trigger is defined.dependencies: the list of processes that must be completed before this process can be submitted. Only present when the process has at least one prerequisite.
KYC processes
List of processes
email: Process associated with updating the user’s email.phone: Process associated with updating the user’s phone number.profile: Process associated with updating the user’s basic information, such as name, date of birth and citizenship.address: Process associated with updating the user’s address of residence.identity: Process associated with updating the user’s identity, usually through a government-issued ID.proofOfAddress: Process associated with updating the user’s proof-of-address, usually through a utility bill or bank statement.customerDueDiligence: Process associated with performing due diligence on the customer, ensuring compliance with regulatory requirements.enhancedDueDiligence: Process associated with providing proof after completing thecustomerDueDiligenceprocess that is needed in certain high-risk scenarios.cryptoRiskAssessment: Process associated with performing analysis on the user’s knowledge about crypto and associated risks (GBresidents only).selfCategorizationStatement: Process associated with identifying the user’s investor profile, including risk level and investment preferences (GBresidents only).taxDetails: Process associated with collecting and verifying the user’s tax-related information.screening: Background process associated with checking user provided data against official lists of sanctioned parties.risk: Background process associated with checking user provided data and activity patterns.
Form-based processes
Some processes, such asprofile, customerDueDiligence and taxDetails, are composed of a form with questions the user must answer.
For these types of processes, you get a hint property which includes a JSON Schema and UI Schema that define the form structure.
To complete a form-based process:
- Fetch the form schema — call Get KYC Overview with
?detailed={process}to retrieve thehint. - Render the form — use the hint to display the current questions. See Dynamic Forms for rendering guidance.
- Submit answers — call
PATCH /core/kyc/processes/{process}withinput.formIdandinput.answers. - Repeat — continue until
statusleavespendingandoutputis correctly populated.
Forms are progressive — answers to one question may change which questions follow. Never hardcode the question set; always re-fetch the hint after each submission.
partner-verified for your organization, skip the form cycle — collect the data through your own means, then submit both input and output in a single PATCH. The process transitions to ok immediately.
File-based processes
Some processes, such asidentity, proofOfAddress and enhancedDueDiligence, require users to upload necessary documents to complete the verification.
To complete a file-based process:
- Create the file — call Create File for each document. Use the returned
uploadobject to upload the file directly to the storage provider. - Submit the process — call
PATCH /core/kyc/processes/{process}referencing the fileidininput.media.
Background processes
There are background processes, such asscreening and risk, that happen behind the scenes as the user provides data in other KYC processes and engages in activities on the platform, such as transactions.
There are no associated endpoints to update these processes, since their underlying verification is based on internal monitoring done by Uphold.
Periodic review
Some processes require periodic review, in which their status may change topending, signaling that the user must provide updated information.
profile: The user must confirm their profile information is still accurate.address: The user must confirm their address is still accurate.identity: The user must provide up-to-date identity when their underlying document is about to expire.customerDueDiligence: The user must redo the form after a certain period of time.selfCategorizationStatement: The user must redo the form after a certain period of time.