A React Native library for Android SMS Retriever API with support for both Nitro Modules and TurboModules (new architecture). This library allows you to automatically retrieve SMS messages containing OTP codes without requiring SMS permissions.
## Features- ✅ Android SMS Retriever API - Automatically retrieve SMS messages
- ✅ New Architecture Support - Built with Nitro Modules and TurboModules
- ✅ TypeScript Support - Full TypeScript definitions included
- ✅ React Hook - Easy-to-use
useSMSRetrieverhook - ✅ Android-Only - Optimized specifically for Android SMS Retriever API
- ✅ No Permissions Required - Uses Google Play Services SMS Retriever API
- ✅ Automatic OTP Extraction - Smart pattern matching for OTP codes
# Using npm
npm install @huymobile/react-native-sms-retriever-nitro-module
# Using yarn
yarn add @huymobile/react-native-sms-retriever-nitro-module
# Using bun
bun add @huymobile/react-native-sms-retriever-nitro-moduleThe library uses autolinking, so no additional setup is required for React Native 0.76+.
import React from 'react';
import { View, Text, TouchableOpacity, Alert } from 'react-native';
import { useSMSRetriever } from '@huymobile/react-native-sms-retriever-nitro-module';
export default function App() {
const {
appHash,
smsCode,
isLoading,
isListening,
error,
isReady,
clearError,
} = useSMSRetriever({
timeoutMs: 30000, // 30 seconds
onSuccess: (otp) => {
Alert.alert('Success', `OTP received: ${otp}`);
},
onError: (error) => {
Alert.alert('Error', `${error.type}: ${error.message}`);
},
});
return (
<View style={{ flex: 1, padding: 20 }}>
<Text>App Hash: {appHash}</Text>
<Text>Status: {isListening ? 'Listening...' : 'Ready'}</Text>
{smsCode && <Text>OTP: {smsCode}</Text>}
{error && <Text style={{ color: 'red' }}>Error: {error}</Text>}
</View>
);
}import NativeSMSRetriever from '@huymobile/react-native-sms-retriever-nitro-module';
// Get app hash for SMS message
const appHash = await NativeSMSRetriever.getAppHash();
console.log('App Hash:', appHash);
// Start listening for SMS
try {
const otp = await NativeSMSRetriever.startSMSListenerWithPromise(30000);
console.log('OTP received:', otp);
} catch (error) {
console.error('SMS retrieval failed:', error);
}
// Stop listening
NativeSMSRetriever.stopSMSListener();
// Listen for events
const subscription = NativeSMSRetriever.onSMSRetrieved((otp) => {
console.log('OTP received via event:', otp);
});
// Clean up
subscription.remove();To use the SMS Retriever API, your SMS message must:
- Contain the app hash at the end of the message
- Be sent from a phone number (not an email or other service)
- Be received within the timeout period (default: 30 seconds)
Example SMS format:
Your OTP is 123456 FA+9qCX9VSu
Where FA+9qCX9VSu is your app hash (obtained from getAppHash()).
timeoutMs?: number- Timeout in milliseconds (default: 30000)autoStart?: boolean- Automatically start listening on mount (default: true)onSuccess?: (otp: string) => void- Success callbackonError?: (error: SMSError) => void- Error callback
appHash: string- Your app's hash for SMS messagessmsCode: string- The extracted OTP codeisLoading: boolean- Whether the module is initializingisListening: boolean- Whether currently listening for SMSerror: string | null- Current error messagestatus: SMSStatus | null- Current status objectisReady: boolean- Whether the module is ready to usehasError: boolean- Whether there's an errorstartListening: () => Promise<string>- Start listening for SMSstopListening: () => void- Stop listeningrefreshStatus: () => Promise<void>- Refresh statusclearError: () => void- Clear current errorreset: () => void- Reset all state
getAppHash(): Promise<string>- Get the app hash for SMS messagesstartSMSListener(): void- Start listening (fire-and-forget)startSMSListenerWithPromise(timeoutMs?: number): Promise<string>- Start listening with promisestopSMSListener(): void- Stop listeninggetStatus(): Promise<SMSStatus>- Get current statusonSMSRetrieved: EventEmitter<string>- Listen for successful SMS retrievalonSMSError: EventEmitter<SMSError>- Listen for errors
- ✅ Android - Full SMS Retriever API support
- ❌ iOS - Not supported (SMS Retriever API is Android-only)
- React Native 0.76+ (New Arch)
- Android API level 19+
- Google Play Services (for SMS Retriever API)
- Nitro Modules (optional, for improved performance)
- SMS not detected: Ensure your SMS contains the app hash at the end
- Timeout errors: Increase the timeout or check if Google Play Services is available
- Permission errors: SMS Retriever API doesn't require SMS permissions
- Build errors: Make sure you're using React Native 0.60+ with autolinking
- Use
getAppHash()to get the correct hash for your app - Check the console logs for detailed error messages
- Ensure your app is signed with the correct keystore
- Test with the debug keystore first before using release keystore
MIT
Made with ❤️ by huymobile
