Uidai: Registrar Integration Manual Pre-Enrolment, Security & Kyr+ Data
Uidai: Registrar Integration Manual Pre-Enrolment, Security & Kyr+ Data
Uidai: Registrar Integration Manual Pre-Enrolment, Security & Kyr+ Data
Table of Contents
1. INTRODUCTION.......................................................................................5
1.1 TERMINOLOGY........................................................................................................................ 6
1.2 OBJECTIVE OF THIS DOCUMENT............................................................................................... 6
1.3 ABBREVIATIONS AND GLOSSARY.............................................................................................. 6
2. INTEGRATION PROCESS...........................................................................7
2.1 PRE-ENROLMENT DATA INTEGRATION......................................................................................7
2.2 REGISTRAR SECURITY INTEGRATION......................................................................................10
2.2.1 Decryption of Enrollment Data Packets..........................................................................11
2.3 KYR+ DATA INTEGRATION.................................................................................................... 15
3. DATA TYPE AND DATA FORMAT..............................................................19
4. ENROLMENT CLIENT XSDS......................................................................21
4.1 DEMOGRAPHIC..................................................................................................................... 21
4.2 BIOMETRICS......................................................................................................................... 30
4.3 REGISTRAR REPORT (EID-UID MAPPING)..............................................................................31
5. Appendix.................................................................................................................. 45
© UIDAI, 2011
Page 2 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
© UIDAI, 2011
Page 3 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
number
1.2 03/12/2010 Gaurav Mojasia Changes made to sec 2.1.
Registrar EID-UID
mapping changed
© UIDAI, 2011
Page 4 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
1. Introduction
UIDAI was created with the responsibility to plan and implement a Unique
Identification scheme, own and operate the CIDR and be responsible for updates and
maintenance on an ongoing basis.
Since the capture of biometrics using sophisticated biometric devices by highly trained
professionals could be the bottle-neck in the entire enrolment processes, it is desirable
to complete the other demographic data capture and verification ahead of the biometric
capture. This step is called pre-enrolment. It is conceivable that through existing
databases available to the Registrars (For example, state governments BPL, PDS, or
NREGA databases) a pre-enrolment workflow can import data into the AADHAAR
Enrolment Client module, and only call upon residents to capture biometric data so that
it can be linked to the existing demographic record for that resident. Note that, even
with pre-enrolment, final verification is done at the time of enrolment during which
biometric data will also be captured.
At the end of every enrolment, Enrolment Client software writes KYR fields into a pre-
configured directory as per software manual as a name- value pair file which Registrar’s
software can load and continue to collect additional KYR+ fields. This document also
lists the name- value pair file format required for the Registrars for launching their
KYR+ application. The allowed data format and the allowed character length have been
covered in the subsequent sections of this document.
The document also covers the data format and the data length (maximum) supported
with various labels. The registrars are expected to input the data in the suggested data
format and length.
The document covers the registrar security integration. The registrar is expected to
share the public key in the specified format with which the client application will
encrypt their set of packets. The same set of packets needs to be decrypted at the
registrar’s end for their internal purpose. The document elaborates the decryption
mechanism which the registrar needs to adhere to for successful packet decryption.
© UIDAI, 2011
Page 5 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
1.1 Terminology
Enrolment: is the process of capturing resident data (including demographic and
biometric data). The enrolment is done by the enrolment operator/agent.
Enrolment centre: is the location where the enrolment happens. Each enrolment
station has the required enrolment set-up to make the enrolment possible.
Enrolment station: is the system which does the enrolment capture. The enrolment
set-up includes a computer, the biometric devices and some accessories.
Resident: is a person who undergoes the enrolment capture process and gets a UID
from the government.
Central ID Data Repository (CIDR): a repository regulated and managed by the UIDAI.
It issues AADHAAR numbers, updates resident information and authenticates the
identity of residents as required.
The objective of this document is not to cover the installation and configuration of the
AADHAAR Enrolment Client. For the intended users of this document, the AADHAAR
Enrolment Client application should be seamless and hence the user didn’t bother about
the internal demarcations of the system.
© UIDAI, 2011
Page 6 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
2. Integration Process
This section covers how to integrate the pre-enrolment data to the AADHAAR
Enrolment Client. Also, this document well illustrates the integration of the KYR+ data
fields required for the registrar’s application from the Enrolment Client.
The subsequent sections cover the file templates required for the Registrar as well the
KYR+ application. The fields/labels listed in the table shall not necessary feature in the
same order as mentioned in the file format. The file shall contain all the labels as defined
and no column with that label should be missing from the file. The Registrar can pass on
the other fields, the details of which are not a part of the template file. The Enrolment
Client application is intelligent enough to pick the labels required for running the
application. The fields defined as part of pre-enrolment file is adhere to the DDVSP
committee report circulated by UIDAI.
The last section covers the decryption process of the registrar packets.
In the case where Registrar has a good database, it can be used to pre-populate the
AADHAAR Enrolment Client. This data is required to reduce the effort and time of the
enrolment operators during enrolment capture process.
Enrolment Station
The typical process to integrate the pre-enrolment data file with the AADHAAR
Enrolment Client application is as follows:
Prepare a CSV (Comma separated Value) file for the pre-enrolment data in the
template suggested in the subsequent section
Ensure that the CSV file is stored in the pre-defined location as suggested in the
installation guide in the enrolment station
© UIDAI, 2011
Page 7 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
The CSV file will contain the headers and all these headers should feature in the same
CSV file. The registrar should make sure that the labels are not missing from the CSV file
though the field level value may or may not be available for that label.
The table has been broken down in two fields, mandatory and optional fields.
PreEnrolmentID
Mandatory
LocalLanguageCode
FullName
FullName_LL
DateOfBirth
Gender
AddrCareOf
AddrCareOf_LL
AddrBuilding
AddrBuilding_LL
AddrStreet
AddrStreet_LL
AddrLandmark
AddrLandmark_LL
AddrLocality
Optional AddrLocality_LL
AddrVTC
AddrVTC_LL
AddrDistrict
AddrDistrict_LL
AddrState
AddrState_LL
PinCode
RelativeName
RelativeName_LL
RelativeUID
RelationType
Mobile
Email
ApplicationNumber
TinNumber
The labels which shall be part of the pre-enrolment CSV file are as explained as below:
PreEnrolmentID- This is the document ID for the document which the resident
has. For ex. Ration card number, Passport number etc. This is a mandatory field.
LocalLanguageCode- This is the local language code for all the Indian state
official language. The registrar may select the appropriate language code in
© UIDAI, 2011
Page 8 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
accordance to his data and should ensure that the details to be mentioned in all
the labels suffixed with ‘LL’ should be in the same local language. This is a
mandatory field. For ex. 06-Hindi. The local language code shall be followed as
per MDDS: 01 Version: 1.0 specification for the languages as per the ISO 639-3. 1
FullName- This is the Name of the resident in English. This shall adhere to the
data type format and length as described in section 3 of this document.
FullName_LL- This is the Name of the resident in the local language as per the
local language code mentioned.
DateOfBirth- This is the Date of Birth of the resident. This shall adhere to the
data type format and length as described in section 3 of this document. This
should be in DDMMYYY format.
Gender- This is the Gender of the resident. This shall adhere to the data type
format and length as described in section 3 of this document. For ex. M-Male, F-
Female, T-Transgender.
AddrCareOf- This is the ‘Care of’ detail of resident in English. This shall adhere
to the data type format and length as described in section 3 of this document.
AddrCareOf_LL- This is the ‘Care of’ detail in the local language as per the local
language code mentioned.
AddrBuilding- This is the ‘building’ detail of resident in English. This shall
adhere to the data type format and length as described in section 3 of this
document.
AddrBuilding_LL- This is the ‘building’ detail in the local language as per the
local language code mentioned.
AddrStreet- This is the ‘Street’ detail of resident in English. This shall adhere to
the data type format and length as described in section 3 of this document.
AddrStreet_LL- This is the ‘Street’ detail in the local language as per the local
language code mentioned.
AddrLandmark- This is the ‘landmark’ detail of resident in English. This shall
adhere to the data type format and length as described in section 3 of this
document.
AddrLandmark_LL- This is the ‘landmark’ detail in the local language as per the
local language code mentioned.
AddrLocality- This is the ‘locality’ detail of resident in English. This shall adhere
to the data type format and length as described in section 3 of this document.
AddrLocality_LL- This is the ‘locality’ detail in the local language as per the local
language code mentioned.
AddrVTC- This is the ‘Village/Town/City’ detail of resident in English. This shall
adhere to the data type format and length as described in section 3 of this
document.
AddrVTC_LL- This is the ‘Village/Town/City’ detail in the local language as per
the local language code mentioned.
AddrDistrict- This is the ‘District’ detail of resident in English. This shall adhere
to the data type format and length as described in section 3 of this document.
AddrDistrict_LL- This is the ‘District’ detail in the local language as per the local
language code mentioned.
1
Refer document Metadata and Data Standards for Person Identification and Land Region Codification
MDDS: 01 Version: 1.0 December 24, 2009
© UIDAI, 2011
Page 9 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
AddrState- This is the ‘State’ detail of resident in English. This shall adhere to
the data type format and length as described in section 3 of this document.
AddrState_LL- This is the ‘State’ detail in the local language as per the local
language code mentioned.
PinCode-this is the Pincode details of the address of the resident.
RelativeName- This is the ‘Relative Name’ detail of resident in English. This shall
adhere to the data type format and length as described in section 3 of this
document.
RelativeName_LL- This is the ‘Relative Name ‘detail in the local language as per
the local language code mentioned.
RelativeUID- This is the ‘Relative UID or Enrolment ID’ detail of resident in
English. This shall adhere to the data type format and length as described in
section 3 of this document.
RelationType- This is the ‘Relative Name detail of resident in English. This shall
adhere to the data type format and length as described in section 3 of this
document.
o F-Father
o M-Mother
o H-Husband
o W-Wife
o G-Guardian
Mobile- This is the Mobile number of resident in English. This shall adhere to the
data type format and length as described in section 3 of this document.
Email- This is the Email address of resident in English. This shall adhere to the
data type format and length as described in section 3 of this document.
ApplicationNumber- This is the application number printed on the paper form
which the resident’s fills for enrolment. This shall adhere to the data type format
and length as described in section 3 of this document.
TinNumber- This is the NPR receipt number provided by the RGI to the resident.
This shall adhere to the data type format and length as described in section 3 of
this document.
UIDAI recommends using multiple public keys to strengthen the security of the resident
data. The public keys should be provided by the registrar before the registrar on-
boarding process. The public keys will be integrated into the enrolment client. If a
public key is not provided by the registrar, the registrar packets would not be created.
© UIDAI, 2011
Page 10 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
The accepted Public Key Format for the AADHAAR enrolment client application is
Class 3 Web based X509 DER binary encoded.
The Registrar code ‘000’ to ‘010’ are reserved for internal/training use. Hence, it is
advised to not to use these codes as their registrar code.
The registrar packets which got created need to be successfully decrypted for internal
purpose. The packets can be decrypted with the help of the public-private key
combination at the registrar end.
The following figure depicts the flow for the decryption of the encrypted enrollment
data packets. The section following the flow chart details the process followed in details.
The decryption logic uses the RSA-OAEP & AES encryption algorithms to decrypt the
content. The entire byte stream is decrypted.
© UIDAI, 2011
Page 11 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
AES Key
AES decrypted
data(Symmetric Key to
Encrypted Message
decrypt the final
packet)
HMAC
Split 32 bytes HMAC and actual content Validator
(SHA256)
© UIDAI, 2011
Page 12 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
Content Size
Extracting the Public key: The RSA public key (162 bytes) is extracted from the
packet and decoded. The keys are stored in the packet in DER format.
Decrypt the Private Key using master key: The private key is obtained from
the certificate store
Decrypting AES key with RSA OAEP: The encrypted AES key is extracted from
the encrypted packet. Then, AES symmetric key is decrypted back using RSA
private key.
AES Decryption: The encrypted data is decrypted using AES symmetric key.
Integrity checking: The HMAC is extracted from the decrypted data. After
removing original HMAC, for the remaining data the new HMAC is again
calculated using SHA256. The 2 HMAC values are compared – if they are equal it
shows the integrity is preserved else it means the enrolment data has been
tampered.
© UIDAI, 2011
Page 13 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
This test decryptor utility is developed to assist Registrars in decrypting the Registrar
Enrolment Packets before go-live. This utility supports only PFX and PEM formats for
private key files. The private key files must be password protected. The decryptor tool
and the source code is available at http://developer.uidai.gov.in/site/downloads
This is designed purely as a test tool along with source code provided for initial
testing. THIS IS NOT SUPPORTED SOFTWARE.
© UIDAI, 2011
Page 14 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
2.3 KYR+ Data Integration
The AADHAAR Enrolment Client application captures the KYR (Know Your Resident)
data. The registrars may require capturing some other registrar specific fields related to
residents called as KYR+ data. For example, In case of PDS data, information such as APL
(Above poverty line), BPL (Below poverty line), Family Details, etc. May be collected as
part of KYR+ data.
Following diagram depicts the relation between AADHAAR Enrolment Client and
Registrar’s KYR+ Application their integration.
Enrolment Station
The typical process to integrate the pre-enrolment data file with the AADHAAR
Enrolment Client application is as follows:
The KYR+ data gets captured from the AADHAAR client application after each
enrolment capture and gets saved into a pre-defined location. At the end of every
enrolment, a unique “Enrolment ID” is generated. This edited KYR data along with
Enrolment ID is shared using a Name-Value pair file which will typically be a .dat file
(kyrplus.dat) to Registrar’s software for collecting KYR+ fields.
The KYR+ application requires almost the same set of data what AADHAAR system
collects from the pre-enrolment data from registrar. The only extra column added is
that of the Enrolment ID which is generated as a part of the enrolment from the
application itself. The “Name” and the “Value” field will be separator with delimiter ‘=’
(equal to) and name will carry the labels as mentioned below. For every new name-
value pair, ‘new Line’ will be the separator, ex.
FullName=Ram Prakash
DateOfBirth=10/04/1980
PreEnrolmentID
Mandatory
LocalLanguageCode
© UIDAI, 2011
Page 15 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
EnrolmentClientVersion
DocumentSpecificationVersion
RegistrarCode
EnrolmentAgencyCode
StationID
EnrolmentID
ApplicationNumber
NPR Receipt Number
Bank Name
Bank Branch Name
Bank Branch IFSC Code
Bank Account Number
FullName
FullName_LL
DateOfBirth
DateOfBirthType
Gender
AddrCareOf
AddrCareOf_LL
AddrBuilding
Optional
AddrBuilding_LL
AddrStreet
AddrStreet_LL
AddrLandmark
AddrLandmark_LL
AddrLocality
AddrLocality_LL
AddrVTC
AddrVTC_LL
AddrDistrict
AddrDistrict_LL
AddrState
AddrState_LL
PinCode
RelativeName
RelativeName_LL
RelativeUID
RelationType
Mobile
Email
Note: The fields have been broken down to accommodate in this document.
The labels mentioned above are generated out of the AADHAAR Enrolment Client
application. The description for all these labels are same as discussed in the Pre-
enrolment integration section. The labels suffixed with ‘LL’ are the respective details of
© UIDAI, 2011
Page 16 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
the resident in the local language in which the AADHAAR Enrolment Client is configured
for.
The EnrolmentID label is the enrolment Id of the resident. This Id was generated as a
part of enrolment capture from the AADHAAR Enrolment Client application. This shall
adhere to the data type format and length as described in section 3 of this document.
The format of the enrolment ID is as follows:
N1N2N3N4N5N6N7N8N9N10N11N12N13N14YYYYMMDDHHMMSS where,
The NPR Receipt Number label is the National Population Register acknowledgement
number of the resident. This shall adhere to the data type format and length as
described in section 3 of this document.
The Bank State is the state in which the bank is located and where the resident owns an
account. This state is the valid state. This shall adhere to the data type format and length
as described in section 3 of this document.
The Bank Name is the name of the bank where the resident owns an account. This bank
shall be a valid bank. This shall adhere to the data type format and length as described
in section 3 of this document.
The Bank Branch Name is the branch where the resident has his account in that bank.
This shall adhere to the data type format and length as described in section 3 of this
document.
The Bank Branch IFSC code will be the IFSC code of the branch. In case, the branch has
no IFSC code, the IFSC code will not be available. This shall adhere to the data type
format and length as described in section 3 of this document.
The Bank Account Number is the bank account number of the resident. This should be
a valid account number. This shall adhere to the data type format and length as
described in section 3 of this document.
© UIDAI, 2011
Page 17 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
In case when the resident provides the age in years, the year of birth is calculated and
passed on to the registrar specific application with the Date of Birth name value pair.
© UIDAI, 2011
Page 18 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
The data type and the data length for the various labels mentioned in the file format as
mentioned in the previous sections are described below. The registrars are expected to
follow the norms and provide the input file in the suggested data formats only.
Enrolment Agency code- (a-z, A-Z) [4]
Station ID- (0-9) [5]
Sequence Number(system generated 5
digit number)
Date Time Stamp-(0-9,hyphen,front
slash) in YYYYMMDDHHMMSS format [16]
LocalLanguageCode numeric (0-9) 2
ApplicationNumber alpha-numeric (a-z, A-Z, 0-9, space, hyphen) 40
TinNumber alpha-numeric (a-z, A-Z, 0-9, space, hyphen) 15
NPR Receipt Same as
Number2 Same as TinNumber TinNumber
Alphabet(a-z,A-Z,dot,space)
Bank State 40
Alphabet(a-z,A-Z,dot,space)
Bank Name 40
alpha-numeric (a-z, A-Z, 0-9,
Bank Branch Name space,hyphen,comma,parenthesis) 80
Bank Branch IFSC alpha-numeric (a-z, A-Z, 0-9,
Code space,hyphen,comma,parenthesis) 20
Bank Account
Number alpha-numeric (a-z, A-Z, 0-9, space,hyphen) 20
FullName alphabetic (a-z, A-Z, space, dot) 99
FullName_LL Indian language value of "Full Name" 99
3
DateOfBirth numeric (0-9) 8
4
DateOfBirthType alphabetic (a-z, A-Z) 15
Gender char[M,F,T] 1
AddrCareOf alpha-numeric (a-z, A-Z, 0-9, space, 60
#,,comma,Dot,Front slash, hyphen)
2
The validations are same as that of Tin Number. Tin number and NPR receipt number are one and the
same thing
3
Date of Birth must be in DDMMYYYY format
4
DOB type can be Approximate, Declared or Verified
© UIDAI, 2011
Page 19 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
AddrCareOf_LL Indian language value of “AddrCareOf” 60
AddrBuilding alpha-numeric (a-z, A-Z, 0-9, space, 60
#,,comma,Dot,Front slash, hyphen)
AddrBuilding_LL Indian language value of “AddrBuilding” 60
AddrStreet alpha-numeric (a-z, A-Z, 0-9, space, 60
#,,comma,Dot,Front slash, hyphen)
AddrStreet_LL Indian language value of “AddrStreet” 60
AddrLandmark alpha-numeric (a-z, A-Z, 0-9, space, 60
#,,comma,Dot,Front slash, hyphen)
AddrLandmark_LL Indian language value of “AddrLandmark” 60
AddrLocality alpha-numeric (a-z, A-Z, 0-9, space, 60
#,,comma,Dot,Front slash, hyphen)
AddrLocality_LL Indian language value of “AddrLocality” 60
AddrVTC alpha-numeric (a-z, A-Z, 0-9, space, 50
#,,comma,Dot,Front slash, hyphen)
AddrVTC_LL Indian language value of “AddrVTC” 50
AddrDistrict alpha-numeric (a-z, A-Z, 0-9, space, &) 50
AddrDistrict_LL Indian language value of “AddrDistrict” 50
AddrState alpha-numeric (a-z, A-Z, 0-9, space, &) 50
AddrState_LL Indian language value of “AddrState” 50
PinCode numeric (0-9) 6
RelativeName alphabetic (a-z, A-Z, space, dot) 99
RelativeName_LL Indian language value of “RelativeName” 99
RelativeUID alpha-numeric (a-z, A-Z, 0-9, 30
space,hyphen,Front slash)
RelationType char[F,M,H,W,G] 1
Mobile5 numeric (0-9) 10
Email alpha-numeric (a-z, A-Z, 0-9, 254
hyphen,underscore,dot,@)
Registrars shall make sure that the string values for all the villages/Districts/States
names shall match exactly with the appropriate directories.
5
The mobile number shall not prefix '0' or +''
© UIDAI, 2011
Page 20 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
This section contains the schema design of the various files which are part of the
enrolment client packet. The respective files have been embedded as an object in
Appendix.
4.1 Demographic
This XSD contains field definition and structure of the resident demographics xml which
is created when registrar enrolment packets are created. The xml will contain values
from demographic details screens, static values from Face, Iris, Finger Print and Review
screen. The XSD can be used in application which will need to read the resident
demographic details.
© UIDAI, 2011
Page 21 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:element name="vtc-name" type="xs:string" minOccurs="0" />
<xs:element name="district" type="xs:string" minOccurs="0" />
<xs:element name="district-name" type="xs:string" minOccurs="0" />
<xs:element name="state" type="xs:string" minOccurs="0" />
<xs:element name="state-name" type="xs:string" minOccurs="0" />
© UIDAI, 2011
Page 22 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
</xs:all>
<xs:attribute name="version" type="xs:string" use="optional"/>
</xs:complexType>
<xs:complexType name="VerificationProofType">
<xs:choice>
<xs:element name="Document" type="DocumentType"/>
<xs:element name="Introducer" type="IntroducerType"/>
</xs:choice>
</xs:complexType>
<xs:complexType name="DocumentType">
<xs:sequence>
<xs:element name="POI" minOccurs="0" >
<xs:complexType>
<xs:sequence>
<xs:element name="documentType" type="xs:string"/>
</xs:sequence>
</xs:complexType>
</xs:element>
<xs:element name="POA" minOccurs="0" >
<xs:complexType>
<xs:sequence>
<xs:element name="documentType" type="xs:string"/>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
<xs:complexType name="IntroducerType">
<xs:sequence>
<xs:element name="id" type="xs:string"/>
<xs:element name="name" type="xs:string"/>
</xs:sequence>
</xs:complexType>
<xs:simpleType name="ModeType">
<xs:restriction base="xs:string">
<xs:enumeration value="NEW" />
<xs:enumeration value="UPDATE" />
<xs:enumeration value="CORRECTION" />
</xs:restriction>
</xs:simpleType>
<xs:complexType name="LinkEnrolmentType">
<xs:all>
© UIDAI, 2011
Page 23 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:element name="link-id" type="xs:string"/>
<xs:element name="link-id-type">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:enumeration value="UID" />
<xs:enumeration value="EID" />
</xs:restriction>
</xs:simpleType>
</xs:element>
</xs:all>
</xs:complexType>
<xs:complexType name="RelationType">
<xs:all>
<xs:element name="rel-id" type="xs:string" minOccurs="0" />
<xs:element name="rel-id-type" minOccurs="0">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:enumeration value="UID" />
<xs:enumeration value="EID" />
</xs:restriction>
</xs:simpleType>
</xs:element>
<xs:element name="rel-name" type="xs:string" minOccurs="0" />
<xs:element name="local-rel-name" type="xs:string"
minOccurs="0" />
<xs:element name="rel-type" minOccurs="0">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:enumeration value="F" />
<xs:enumeration value="M" />
<xs:enumeration value="H" />
<xs:enumeration value="W" />
<xs:enumeration value="G" />
</xs:restriction>
</xs:simpleType>
</xs:element>
</xs:all>
</xs:complexType>
<xs:simpleType name="GenderType">
<xs:restriction base="xs:string">
<xs:enumeration value="M" />
<xs:enumeration value="F" />
<xs:enumeration value="T" />
</xs:restriction>
</xs:simpleType>
<xs:complexType name="DateOfBirthType">
<xs:all>
© UIDAI, 2011
Page 24 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:element name="day" type="xs:int" />
<xs:element name="month" type="xs:int" />
<xs:element name="year" type="xs:int" />
<xs:element name="status">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:enumeration value="DECLARED" />
<xs:enumeration value="APPROXIMATE" />
<xs:enumeration value="VERIFIED" />
</xs:restriction>
</xs:simpleType>
</xs:element>
</xs:all>
</xs:complexType>
<xs:complexType name="ExtendedAttributes">
<xs:sequence>
<xs:element name="Attribute" minOccurs="1" maxOccurs="unbounded">
<xs:complexType>
<xs:sequence>
<xs:element name="key" type="xs:string" />
<xs:element name="value" type="xs:string" />
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
<xs:complexType name="FinancialDetails">
<xs:all>
<xs:element name="bankaccount-opening-consent" type="xs:boolean"
minOccurs="0" />
<xs:element name="state-name" type="xs:string" minOccurs="0" />
<xs:element name="state-code" type="xs:string" minOccurs="0" />
<xs:element name="bank-name" type="xs:string" minOccurs="0" />
<xs:element name="bank-entity-code" type="xs:string" minOccurs="0" />
<xs:element name="branch-name" type="xs:string" minOccurs="0" />
<xs:element name="ifsc-code" type="xs:string" minOccurs="0" />
<xs:element name="account-number" type="xs:string" minOccurs="0" />
</xs:all>
</xs:complexType>
<!--
Root element for operator-details.xml file
-->
© UIDAI, 2011
Page 25 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:element name="operator-details">
<xs:complexType>
<xs:complexContent>
<xs:extension base="OperatorSupervisorType"></xs:extension>
</xs:complexContent>
</xs:complexType>
</xs:element>
<!--
Root element for supervisor-details.xml file
-->
<xs:element name="supervisor-details">
<xs:complexType>
<xs:complexContent>
<xs:extension base="OperatorSupervisorType"></xs:extension>
</xs:complexContent>
</xs:complexType>
</xs:element>
<xs:complexType name="OperatorSupervisorType">
<xs:all>
<xs:element name="opid" type="xs:string" minOccurs="0" />
<xs:element name="name" type="xs:string" minOccurs="0" />
<xs:element name="timestamp" type="xs:string" minOccurs="0" />
<xs:element name="biometric-capture" type="BiometricCaptureType"
minOccurs="0" />
</xs:all>
<xs:attribute name="version" type="xs:string" use="optional" />
</xs:complexType>
<!--
Root element for introducer-details.xml file
-->
<!--
The resident's biometric data as a collection of capture trails for
each group (left-slap, right-slap, face, left-iris, right-iris).
© UIDAI, 2011
Page 26 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
-->
<xs:complexType name="ResidentBiometricType">
<xs:sequence>
<xs:element name="biometric-capture-trail" type="BiometricCaptureTrailType"
minOccurs="1" maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
<!--
A collection of biometric captures corresponding to a specific group
that can be left-slap, right-slap, face, left-iris, right-iris, etc.
-->
<xs:complexType name="BiometricCaptureTrailType">
<xs:sequence>
<xs:element name="biometric-capture" type="BiometricCaptureType"
minOccurs="1" maxOccurs="unbounded" />
</xs:sequence>
<xs:attribute name="group" type="xs:string" use="required" />
</xs:complexType>
<!--
Contains metadata information about a single biometric capture.
-->
<xs:complexType name="BiometricCaptureType">
<xs:all>
<!--
Device information as a collection of name-value pairs
-->
<xs:element name="device-info" minOccurs="0">
<xs:complexType>
<xs:sequence>
<xs:element name="parameter" type="DeviceParameterType"
minOccurs="1"
maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
</xs:element>
<!--
List of body parts associated with this capture. For example,
for a
left slap, this would be left index, left ring, left pointer and
left middle fingers.
-->
<xs:element name="body-part-list" minOccurs="0">
<xs:complexType>
<xs:sequence>
© UIDAI, 2011
Page 27 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:element name="body-part" type="BodyPartType"
maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
</xs:element>
<!--
List of body parts missing from this capture (e.g. missing
finger)
-->
<xs:element name="missing-part-list" minOccurs="0">
<xs:complexType>
<xs:sequence>
<xs:element name="body-part" type="BodyPartType"
maxOccurs="unbounded" />
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:all>
<!--
<xs:attribute name="start-date" type="xs:string" />
<xs:attribute name="end-date" type="xs:string" />
<xs:attribute name="quality" type="xs:int" />
-->
<!--
This should be the same as the index specified in the BIR info block
in CBEFF XML.
-->
<!--
<xs:attribute name="cbeff-index" type="xs:string" />
<xs:attribute name="forced" type="xs:boolean" />
<xs:attribute name="best-attempt" type="xs:boolean" />
-->
</xs:complexType>
<!--
© UIDAI, 2011
Page 28 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
Contains information about a single device parameter in the form of a
name-value pair.
-->
<xs:complexType name="DeviceParameterType">
<xs:sequence>
<xs:element name="name" type="xs:string" />
<xs:element name="value" type="xs:string" />
</xs:sequence>
</xs:complexType>
<!--
Contains information about a single body part. Type interpretation is as
given below:
The biometric sub-type is arrived at using the following table for bitwise
interpretation:
BBBBBBBB
8 7 6 5 4 3 2 1Biometric Subtype
=====================================
0 0 0 0 0 0 0 0No information given
01 Right
10 Left
000 No meaning
© UIDAI, 2011
Page 29 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
001 Thumb
010 Pointer finger
011 Middle Finger
100 Ring Finger
101 Little Finger
xxx Reserved for Future Use
ex : 0 0 0 1 0 1 0 1 Right Little Finger
-->
<xs:complexType name="BodyPartType">
<xs:attribute name="type" type="xs:int" />
<xs:attribute name="sub-type" type="xs:int" />
</xs:complexType>
</xs:schema>
4.2 Biometrics
The biometrics XSD contains definition and structure in which biometric (Face, Iris,
Finger Print and Operator/ Supervisor/ Introducer authentication) details will be
captured. Registrar pack will contain resident-biometric, operator biometric, supervisor
biometric and introducer biometric xml which will follow the below given structure.
The XSD can be used to develop application which will read the packet details against
the XSD.
<xs:complexType name="bir">
<xs:sequence>
<xs:element name="version" type="RevisionType"
minOccurs="0" />
<xs:element name="cbeff-version" type="RevisionType"
minOccurs="0" />
© UIDAI, 2011
Page 30 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:element name="bdb" type="xs:base64Binary"
minOccurs="0" />
</xs:choice>
</xs:sequence>
</xs:complexType>
<xs:complexType name="RevisionType">
<xs:attribute name="major" type="xs:int" />
<xs:attribute name="minor" type="xs:int" />
</xs:complexType>
<xs:complexType name="BIRInfoType">
<xs:sequence>
<xs:element name="creator" type="xs:string" minOccurs="0" />
<xs:element name="index" type="xs:string" minOccurs="0" />
</xs:sequence>
<xs:attribute name="integrity" type="xs:boolean" use="optional" />
<xs:attribute name="creation-date" type="xs:string" use="optional" />
<xs:attribute name="not-valid-before" type="xs:string"
use="optional" />
<xs:attribute name="not-valid-after" type="xs:string"
use="optional" />
</xs:complexType>
<xs:complexType name="BDBInfoType">
<xs:attribute name="format-owner" type="xs:string" />
<xs:attribute name="format-type" type="xs:string" />
<xs:attribute name="encryption" type="xs:boolean" use="optional" />
<xs:attribute name="creation-date" type="xs:string" />
<xs:attribute name="type" type="xs:string" use="optional" />
<xs:attribute name="subtype" type="xs:string" use="optional" />
<xs:attribute name="level" type="xs:string" use="optional" />
<xs:attribute name="product-owner" type="xs:string" use="optional" />
<xs:attribute name="product-type" type="xs:string" use="optional" />
<xs:attribute name="purpose" type="xs:string" use="optional" />
<xs:attribute name="quality" type="xs:string" use="optional" />
</xs:complexType>
</xs:schema>
© UIDAI, 2011
Page 31 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
xmlns:xs="http://www.w3.org/2001/XMLSchema"
elementFormDefault="qualified"
targetNamespace="http://www.uidai.gov.in/registar/report/1.0">
<xs:simpleType name="enrollmentStatus">
<xs:restriction base="xs:string">
<xs:enumeration value="ISSUED"></xs:enumeration>
<xs:enumeration value="REJECTED"></xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:simpleType name="reasonCodes">
<xs:restriction base="xs:string">
<xs:enumeration value="PKT_STRUCT_VALID_FAIL">
<xs:annotation>
<xs:documentation>
Invalid Packet Structure.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_FAIL_FOR_VIRUS">
<xs:annotation>
<xs:documentation>
Packet failed due to virus.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_FAIL_IN_DECRYPTION">
<xs:annotation>
<xs:documentation>
Packet failed in decryption.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_METADATA_AUDIT_INFO_EMPTY">
<xs:annotation>
<xs:documentation>
Metadata Audit information is missing.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_METADATA_REGISTRAR_ID_EMPTY">
<xs:annotation>
<xs:documentation>
Registrar Id is missing.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
© UIDAI, 2011
Page 32 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:enumeration
value="PKT_METADATA_INVALID_REGISTRAR_ID">
<xs:annotation>
<xs:documentation>
Registrar Id is invalid.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_METADATA_STATION_ID_EMPTY">
<xs:annotation>
<xs:documentation>
Station Id is missing.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_METADATA_INVALID_STATION_ID">
<xs:annotation>
<xs:documentation>
Station Id is invalid.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_ENR_MACHINE_CODE_DUPLICATE">
<xs:annotation>
<xs:documentation>
Duplicate Enrollment id and Machine code
found.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_ENR_MACHINE_CODE_NO_DUPLICATE">
<xs:annotation>
<xs:documentation>
Duplicate Enrollment id and different
Machine code found.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_ENR_MACHINE_CODE_EMPTY">
<xs:annotation>
<xs:documentation>
Packet Machine code is missing.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_ENR_INVALID_START_DATE">
© UIDAI, 2011
Page 33 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:annotation>
<xs:documentation>
Invalid start date of Enrolment.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_ENR_INVALID_END_DATE">
<xs:annotation>
<xs:documentation>
Invalid end date of Enrolment.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_METADATA_INVALID_AGENCY_ID">
<xs:annotation>
<xs:documentation>
Enrolment Agency Id is invalid.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_METADATA_AGENCY_ID_EMPTY">
<xs:annotation>
<xs:documentation>
Enrolment Agency Id is missing.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_METADATA_FACE_IMAGE_MISSING">
<xs:annotation>
<xs:documentation>
Face image is missing.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_METADATA_INVALID_GUARDIAN_UID">
<xs:annotation>
<xs:documentation>
Guardian UID not found in Aadhaar database.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_METADATA_EXCEPTION_IMAGE_MISSING">
<xs:annotation>
<xs:documentation>
Exception image is missing.
</xs:documentation>
© UIDAI, 2011
Page 34 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_METADATA_SUPERVISOR_FINGERPRINT_MISSING">
<xs:annotation>
<xs:documentation>
Supervisor Fingerprint is missing.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_ENR_MACHINE_CODE_INVALID">
<xs:annotation>
<xs:documentation>
Invalid Machine Code.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_ENR_INVALID_ORG_AND_MACHINE_CODE_COMBINATION">
<xs:annotation>
<xs:documentation>
Invalid Registrar, EnrolmentAgency, Station
and Machine Code combination.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_METADATA_INVALID_CLIENT_REGISTRATION">
<xs:annotation>
<xs:documentation>
Invalid client registration.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_METADATA_DUPLICATE_ENROLMENT_ID">
<xs:annotation>
<xs:documentation>
Duplicate Enrolment id.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_NAME_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid Name.
</xs:documentation>
</xs:annotation>
© UIDAI, 2011
Page 35 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_DOB_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid Date of birth.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_GENDER_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid Gender.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_ADDRESS_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid Address.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_RELNAME_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid relative name.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_RELATION_TYPE_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid relative type.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_UIDRELATION_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid UID of the relative.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
© UIDAI, 2011
Page 36 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:enumeration value="PKT_RDEMO_ADDRESS_PINCODE_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid Pincode.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_ADDRESS_VTC_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid village.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_ADDRESS_STATE_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid state.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_ADDRESS_DISTRICT_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid district.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_ADDRESS_PIN_VTC_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid Pincode-VTC mapping.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_RDEMO_ADDRESS_VTC_DISTRICT_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid VTC-District mapping.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
© UIDAI, 2011
Page 37 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:enumeration
value="PKT_RDEMO_ADDRESS_VTC_STATE_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
invalid VTC-State mapping.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_RDEMO_DOB_FUTURE_DATE_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
future Date of birth.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RDEMO_RELATION_FAIL">
<xs:annotation>
<xs:documentation>
Resident demorgaphic Validation failed for
missing relative details.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_OPERATOR_ID_FAIL">
<xs:annotation>
<xs:documentation>
Invalid Operator ID .
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_OPERATOR_FILE_INVALID_FAIL">
<xs:annotation>
<xs:documentation>
Operator File does not exist in Enrolment
packet.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_OPERATOR_ID_NA_FAIL">
<xs:annotation>
<xs:documentation>
Operator ID does not exist in Aadhaar
database.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
© UIDAI, 2011
Page 38 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:enumeration value="PKT_OPERATOR_BIO_VAL_FAIL">
<xs:annotation>
<xs:documentation>
Operator Biometric Verification Failed.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_OPERATOR_BIO_VAL_ERROR">
<xs:annotation>
<xs:documentation>
ABIS Error Response for Operator
Verification.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_OPERATOR_BIO_DISPATCH_ERROR">
<xs:annotation>
<xs:documentation>
Operator Biometric request dispatch failed.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_OPERATOR_USER_NA">
<xs:annotation>
<xs:documentation>
OOperator as a User does not exist in Aadhaar
database.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_SUPERVISOR_ID_FAIL">
<xs:annotation>
<xs:documentation>
Supervisor ID does not exist in Aadhaar
database.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_SUPERVISOR_FILE_INVALID_FAIL">
<xs:annotation>
<xs:documentation>
Supervisor File does not exist in Enrolment
Packet.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_SUPERVISOR_ID_NA_FAIL">
<xs:annotation>
© UIDAI, 2011
Page 39 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:documentation>
Supervisor EID/UID does not exist in Aadhaar
database.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_SUPERVISOR_BIO_VAL_FAIL">
<xs:annotation>
<xs:documentation>
Supervisor Biometric Verification Failed.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_SUPERVISOR_BIO_VAL_ERROR">
<xs:annotation>
<xs:documentation>
Supervisor Biometric Error in ABIS Response.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_SUPERVISOR_BIO_DISPATCH_ERROR">
<xs:annotation>
<xs:documentation>
Supervisor Biometric request to ABIS failed.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_INTRODUCER_ID_FAIL">
<xs:annotation>
<xs:documentation>
Invalid Introducer ID.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_INTRODUCER_FILE_INVALID_FAIL">
<xs:annotation>
<xs:documentation>
Introducer File does not exist in Enrolment
Packet.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_INTRODUCER_ID_NA_FAIL">
<xs:annotation>
<xs:documentation>
Introducer UID does not exist in Aadhaar
database.
© UIDAI, 2011
Page 40 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_INTRODUCER_BIO_VAL_FAIL">
<xs:annotation>
<xs:documentation>
Introducer Biometric Validation Failed.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_INTRODUCER_BIO_VAL_ERROR">
<xs:annotation>
<xs:documentation>
Introducer Biometric Error in ABIS Response.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_INTRODUCER_BIO_DISPATCH_ERROR">
<xs:annotation>
<xs:documentation>
IIntroducer Biometric request to ABIS Failed.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_INTRODUCER_REGION_VAL_FAIL">
<xs:annotation>
<xs:documentation>
Not a valid Introducer in the Region.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_INTRODUCER_INACTIVE">
<xs:annotation>
<xs:documentation>
Introducer is not Active.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_INTRODUCER_REGION_STATUS_INACTIVE">
<xs:annotation>
<xs:documentation>
Introducer is not Active in the Region .
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_INTRODUCER_REGION_UNKNOWN_ERROR">
© UIDAI, 2011
Page 41 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:annotation>
<xs:documentation>
Introducer Region association status is
missing.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_INTRODUCER_USER_NA_FAIL">
<xs:annotation>
<xs:documentation>
Introducer as User does not exists in Aadhaar
database.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_INTRODUCER_REGISTRAR_VAL_FAIL">
<xs:annotation>
<xs:documentation>
Introducer belongs to different registrar in
the Region.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RESIDENT_BIO_FAIL">
<xs:annotation>
<xs:documentation>
Resident Biometric Verification failed.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_GUARDIAN_BIO_FAIL">
<xs:annotation>
<xs:documentation>
Guardian Biometric Verification failed.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_GUARDIAN_BIO_ERROR">
<xs:annotation>
<xs:documentation>
Guardian Biometric Verification error
returned by ABIS.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RESIDENT_BIO_ERROR">
<xs:annotation>
<xs:documentation>
© UIDAI, 2011
Page 42 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
Resident Biometric Verification error
returned by ABIS.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_RESIDENT_BIO_DISPATCH_ERROR">
<xs:annotation>
<xs:documentation>
Resident biometric request dispatch failed.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_GUARDIAN_BIO_DISPATCH_ERROR">
<xs:annotation>
<xs:documentation>
Guardian biometric request dispatch failed.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RBIO_DEDUP_FAIL">
<xs:annotation>
<xs:documentation>
Duplicate found during biometric
deduplication of the resident.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PKT_RBIO_DEDUP_ERROR">
<xs:annotation>
<xs:documentation>
ABIS Error response received for resident
biometric deduplication.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PKT_LTR_UID_DATA_NOT_FOUND_FAIL">
<xs:annotation>
<xs:documentation>
Resident UID given in update packet does not
exist in Aadhaar database.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="Original Packet for update rejected by
ABIS during Verification">
<xs:annotation>
© UIDAI, 2011
Page 43 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
<xs:documentation>
Linked Packet is rejected.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration value="PACKET_UPDATE_VERIFY_FAIL">
<xs:annotation>
<xs:documentation>
Original Packet for update failed due to
Verification Error.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
<xs:enumeration
value="PACKET_UPDATE_VERIFY_INFANT_GUARDIAN_REJECT">
<xs:annotation>
<xs:documentation>
Guardian Packet rejected by ABIS during
Verification.
</xs:documentation>
</xs:annotation>
</xs:enumeration>
</xs:restriction>
</xs:simpleType>
<xs:complexType name="enrollment">
<xs:attribute name="eid" type="xs:string"
use="required"></xs:attribute>
<xs:attribute name="eidDate" type="xs:string"
use="required"></xs:attribute>
<xs:attribute name="status" type="enrollmentStatus"
use="required"></xs:attribute>
<xs:attribute name="uid" type="xs:long"></xs:attribute>
<xs:attribute name="reasonCode" type="reasonCodes"></xs:attribute>
</xs:complexType>
<xs:complexType name="enrollmentReport">
<xs:sequence>
<xs:element name="enrollment" type="enrollment"
maxOccurs="unbounded"></xs:element>
</xs:sequence>
<xs:attribute name="registarId" type="xs:string"></xs:attribute>
<xs:attribute name="reportDate" type="xs:date"></xs:attribute>
</xs:complexType>
</xs:schema>
© UIDAI, 2011
Page 44 of 45
Version 1.3
Registrar Integration Manual-1.3.2.0
5. Appendix
demographics.xsd
biometrics.xsd
registrarreport.xsd
© UIDAI, 2011
Page 45 of 45