Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Swift 3,4,5...) Aadhaar Paperless Offline e-kycOpens an encrypted .zip containing Aadhaar Paperless Offline e-KYC XML. Gets the XML and validates the digital signature. Then computes the hash for the mobile number and Email ID. For more information, see https://uidai.gov.in/ecosystem/authentication-devices-documents/about-aadhaar-paperless-offline-e-kyc.html
func chilkatTest() { // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // Open the .zip containing the Aadhaar Paperless Offline e-KYC XML. // The .zip is encrypted using the "Share Phrase". let zip = CkoZip()! var success: Bool = zip.open("qa_data/xml_dsig/offline_paperless_kyc.zip") if success == false { print("\(zip.lastErrorText!)") return } // The .zip should contain 1 XML file. var entry: CkoZipEntry? = zip.getEntryByIndex(0) if zip.lastMethodSuccess == false { print("\(zip.lastErrorText!)") return } // To get the contents, we need to specify the Share Phrase. var sharePhrase: String? = "Lock@487" zip.decryptPassword = sharePhrase let bdXml = CkoBinData()! // The XML file will be unzipped into the bdXml object. success = entry!.unzip(toBd: bdXml) if success == false { print("\(entry!.lastErrorText!)") entry = nil return } entry = nil // First verify the XML digital signature. let dsig = CkoXmlDSig()! success = dsig.loadSignatureBd(bdXml) if success != true { print("\(dsig.lastErrorText!)") return } // The UIDAI XML signature does not contain the KeyInfo, so we must load the uidai certificate // and indicate that its public key is to be used for verifying the signature. let cert = CkoCert()! success = cert.load(fromFile: "qa_data/xml_dsig/uidai_auth_sign_prod_2023.cer") if success != true { print("\(cert.lastErrorText!)") return } // Get the certificate's public key. var pubKey: CkoPublicKey? = cert.exportPublicKey() success = dsig.setPublicKey(pubKey) pubKey = nil // The XML in this example contains only 1 signature. var bVerifyReferenceDigests: Bool = true var bVerified: Bool = dsig.verifySignature(bVerifyReferenceDigests) if bVerified == false { print("\(dsig.lastErrorText!)") print("The signature was not valid.") return } print("The XML digital signature is valid.") // Let's compute the hash for the Mobile Number. // Hashing logic for Mobile Number : // Sha256(Sha256(Mobile+SharePhrase))*number of times last digit of Aadhaar number // (Ref ID field contains last 4 digits). // // Example : // Mobile: 1234567890 // Aadhaar Number:XXXX XXXX 3632 // Passcode : Lock@487 // Hash: Sha256(Sha256(1234567890Lock@487))*2 // In case of Aadhaar number ends with Zero we will hashed one time. let crypt = CkoCrypt2()! crypt.hashAlgorithm = "sha256" crypt.encodingMode = "hexlower" var strToHash: String? = "1234567890Lock@487" let bdHash = CkoBinData()! success = bdHash.append(strToHash, charset: "utf-8") // Hash a number of times equal to the last digit of your Aadhaar number. // If the Aadhaar number ends with 0, then hash one time. // For this example, we'll just set the number of times to hash // for the case where an Aadhaar number ends in "9" var numTimesToHash: Int = 9 var i: Int for i = 1; i <= numTimesToHash; i++ { var tmpStr: String? = crypt.hashBdENC(bdHash) bdHash.clear() bdHash.append(tmpStr, charset: "utf-8") } print("Computed Mobile hash = \(bdHash.getString("utf-8")!)") // Let's get the mobile hash stored in the XML and compare it with our computed hash. let xml = CkoXml()! success = xml.loadBd(bdXml, autoTrim: true) var m_hash: String? = xml.chilkatPath("UidData|Poi|(m)") print("Stored Mobile hash = \(m_hash!)") // Now do the same thing for the email hash: strToHash = "abc@gm.comLock@487" bdHash.clear() success = bdHash.append(strToHash, charset: "utf-8") for i = 1; i <= numTimesToHash; i++ { var tmpStr: String? = crypt.hashBdENC(bdHash) bdHash.clear() bdHash.append(tmpStr, charset: "utf-8") } print("Computed Email hash = \(bdHash.getString("utf-8")!)") var e_hash: String? = xml.chilkatPath("UidData|Poi|(e)") print("Stored Email hash = \(e_hash!)") } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.