Get your API Key (take note of the environment you are running the job in)
Get the ID information from your users
Submit the Job to Smile ID
Interpret your results
Get your Partner ID
You can find your Partner ID in the menu list when logged into the portal.
Get your API Key
Your api key is in the developer section of the portal.
Click on the Generate New API Key button
Copy your api key (ensure you are in the right environment)
Get the ID information from your users
To submit an Enhanced KYC job you need the ID information of your user. Depending on the ID type you are attempting to query, the required information varies. For the comprehensive list of required information for each ID Type, check the Supported ID Types section of the docs.
Submit the Job to Smile ID
You can copy the sample code below and edit with your partner and job details.
<?phprequire'vendor/autoload.php';// Initialize$partner_id ="<Put your partner ID here>"; // login to the Smile ID portal to view your partner id$default_callback = "<Put your default callback here>"; //callback is only required if you are running an asynchronous job
$api_key ="<Put your API key here>"; // copy your API key from the Smile ID portal$sid_server ="<0 or 1>"; // Use '0' for the sandbox server, use '1' for production server$connection =newIdApi( $partner_id, $default_callback, $api_key, $sid_server);// Create required tracking parameters$partner_params =array('job_id'=>"<put your unique job ID here>",'user_id'=>"<put your unique ID for the user here>",'job_type'=>5);// Create ID info$id_info =array('first_name'=>"<name>",'middle_name'=>"<middle>",'last_name'=>"<surname>",'country'=>"<2-letter country code>",'id_type'=>"<id type>",'id_number'=>"<valid id number>",// Always required'dob'=>"<date of birth>",// yyyy-mm-dd'entered'=>"true"// MUST BE A STRING);// Set the options for the job$options =array( 'use_async' => <true | false>, // Set to true if you want to run the job asynchronously, you will be required to provide a callback in the $default_callback variable above
'signature'=>true);// Submit the job// This method returns a json array$result = $connection->submit_job($partner_params, $id_info, $options);?>p
Example Response Body
Your response will return a JSON array containing the below:
{"SmileJobID":"0000001105","PartnerParams": {"user_id":"T6yzdOezucdsPrY0QG9LYNDGOrC","job_id":"FS1kd1dd15JUpd87gTBDapvFxv0","job_type":5 },"ResultText":"ID Number Validated","ResultCode":"1012","Actions": {"Verify_ID_Number":"Verified","Return_Personal_Info":"Returned" },"Country":"NG","IDType":"DRIVERS_LICENSE","IDNumber":"ABC000000000","ExpirationDate":"2017-10-28","FullName":"John Doe","DOB":"1900-09-20","Photo":"SomeBase64Image","signature":"iWyc...P0=","timestamp":"2022-03-13T11:44:10.231Z"}
Interpret your Results
You can read more about result codes and responses in the Enhanced KYC section of the docs.