This React Native plugin enables the reading of NFC-enabled passports using native device capabilities. It provides a user-friendly interface for initiating and handling NFC operations, including reading passport data, checking NFC support, and managing NFC settings.
- Start and stop NFC passport reading
- Basic Access Control (BAC) support for secure passport reading
- Check if NFC is supported and enabled on the device
- Open device NFC settings
- Support for both iOS and Android platforms
- Optional image extraction from passport
To use the NFC Passport Reader in your React Native project, follow these steps:
-
Install the Plugin:
npm install @didit-sdk/react-native-nfc-passport-reader
-
Link Native Modules (if required for versions below React Native 0.60):
npx react-native link @didit-sdk/react-native-nfc-passport-reader
-
iOS Additional Setup:
- Modify your Info.plist to include necessary NFC usage descriptions.
<key>NFCReaderUsageDescription</key> <string>This app requires NFC access to verify your identity.</string> <key>com.apple.developer.nfc.readersession.iso7816.select-identifiers</key> <array> <string>A0000002471001</string> <string>00000000000000</string> <string>D4100000030001</string> </array>
- Ensure your entitlements include NFC tag reading capability.
- Add the following pod to your Podfile:
pod 'OpenSSL-Universal', '~> 1.1.1900'
- Disable Flipper in your Podfile (required for proper functionality)
- Modify your Info.plist to include necessary NFC usage descriptions.
-
Android Additional Setup:
- Add NFC permissions in your AndroidManifest.xml.
<uses-feature android:name="android.hardware.nfc" android:required="false" /> <uses-permission android:name="android.permission.NFC" />
- Ensure your device has NFC capabilities and that NFC is enabled.
- Add NFC permissions in your AndroidManifest.xml.
Import and use the NFC Passport Reader as follows:
import NfcPassportReader from '@didit-sdk/react-native-nfc-passport-reader';
import type { NfcResult } from '@didit-sdk/react-native-nfc-passport-reader';
-
startReading: Initiates the NFC passport reading process.
const result: NfcResult = await NfcPassportReader.startReading({ bacKey: { documentNo: '123456789', // Document Number expiryDate: '2025-03-09', // YYYY-MM-DD birthDate: '2025-03-09', // YYYY-MM-DD }, includeImages: true, // Include images in the result (default: false) });
-
stopReading: Stops the NFC passport reading process. (Only Android)
NfcPassportReader.stopReading();
-
addOnTagDiscoveredListener: Triggers when an NFC tag is discovered.
NfcPassportReader.addOnTagDiscoveredListener(() => { console.log('Tag Discovered'); });
-
addOnNfcStateChangedListener: Monitors changes in NFC state.
NfcPassportReader.addOnNfcStateChangedListener((state: 'on' | 'off') => { console.log('NFC State Changed:', state); });
-
isNfcSupported: Checks if NFC is supported by the device.
const supported = await NfcPassportReader.isNfcSupported();
-
isNfcEnabled: Checks if NFC is enabled on the device.
const enabled = await NfcPassportReader.isNfcEnabled();
-
openNfcSettings: Opens the device's NFC settings. (Only Android)
NfcPassportReader.openNfcSettings();
For a detailed example of how to use the NFC Passport Reader, please see the Example App.
Special thanks to Andy Qua for his excellent NFCPassportReader library that powers the iOS implementation of this package. His work on implementing BAC, Secure Messaging, and various passport data group readings has been instrumental in making this React Native wrapper possible.
See the contributing guide to learn how to contribute to the repository and the development workflow.
MIT
Made with create-react-native-library