2023-04-08 10:40:53 +02:00
|
|
|
import Logger from '@joplin/lib/Logger';
|
2023-01-04 20:18:51 +00:00
|
|
|
import Setting from '@joplin/lib/models/Setting';
|
|
|
|
import FingerprintScanner from 'react-native-fingerprint-scanner';
|
2023-04-08 10:40:53 +02:00
|
|
|
const logger = Logger.create('sensorInfo');
|
2023-01-04 20:18:51 +00:00
|
|
|
|
|
|
|
export interface SensorInfo {
|
|
|
|
enabled: boolean;
|
|
|
|
sensorsHaveChanged: boolean;
|
|
|
|
supportedSensors: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export default async (): Promise<SensorInfo> => {
|
2023-03-22 18:22:58 +00:00
|
|
|
// Early exit if the feature is disabled, so that we don't make any
|
|
|
|
// FingerprintScanner scanner calls, since it seems they can fail and freeze
|
|
|
|
// the app.
|
|
|
|
|
2023-04-08 10:40:53 +02:00
|
|
|
logger.info('Start');
|
|
|
|
logger.info('security.biometricsEnabled', Setting.value('security.biometricsEnabled'));
|
|
|
|
|
2023-03-22 18:22:58 +00:00
|
|
|
if (!Setting.value('security.biometricsEnabled')) {
|
|
|
|
return {
|
|
|
|
enabled: false,
|
|
|
|
sensorsHaveChanged: false,
|
|
|
|
supportedSensors: '',
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2023-01-04 20:18:51 +00:00
|
|
|
let hasChanged = false;
|
|
|
|
let supportedSensors = '';
|
|
|
|
|
2023-01-05 13:29:19 +00:00
|
|
|
try {
|
2023-04-08 10:40:53 +02:00
|
|
|
logger.info('Getting isSensorAvailable...');
|
2023-04-09 11:28:18 +02:00
|
|
|
|
|
|
|
// Note: If `isSensorAvailable()` doesn't return anything, it seems we
|
|
|
|
// could assume that biometrics are not setup on the device, and thus we
|
|
|
|
// can unlock the app. However that's not always correct - on some
|
|
|
|
// devices (eg Galaxy S22), `isSensorAvailable()` will return nothing if
|
|
|
|
// the device is on lockout - i.e. if the user gave the wrong
|
|
|
|
// fingerprint multiple times.
|
|
|
|
//
|
|
|
|
// So we definitely can't unlock the app in that case, and it means
|
|
|
|
// `isSensorAvailable()` is pretty much useless. Instead we ask for
|
|
|
|
// fingerprint when the user turns on the feature and at that point we
|
|
|
|
// know if the device supports biometrics or not.
|
2023-01-05 13:29:19 +00:00
|
|
|
const result = await FingerprintScanner.isSensorAvailable();
|
2023-04-08 10:40:53 +02:00
|
|
|
logger.info('isSensorAvailable result', result);
|
2023-01-05 13:29:19 +00:00
|
|
|
supportedSensors = result;
|
2023-01-04 20:18:51 +00:00
|
|
|
|
2023-01-05 13:29:19 +00:00
|
|
|
if (result) {
|
|
|
|
if (result !== Setting.value('security.biometricsSupportedSensors')) {
|
|
|
|
hasChanged = true;
|
|
|
|
Setting.setValue('security.biometricsSupportedSensors', result);
|
2023-01-04 20:18:51 +00:00
|
|
|
}
|
|
|
|
}
|
2023-01-05 13:29:19 +00:00
|
|
|
} catch (error) {
|
2023-04-08 10:40:53 +02:00
|
|
|
logger.warn('Could not check for biometrics sensor:', error);
|
2023-01-05 13:29:19 +00:00
|
|
|
Setting.setValue('security.biometricsSupportedSensors', '');
|
2023-01-04 20:18:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
2023-01-05 13:29:19 +00:00
|
|
|
enabled: Setting.value('security.biometricsEnabled'),
|
2023-01-04 20:18:51 +00:00
|
|
|
sensorsHaveChanged: hasChanged,
|
|
|
|
supportedSensors,
|
|
|
|
};
|
|
|
|
};
|