Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jpudysz/react-native-turbo-mock-location-detector
Protect your business from location spoofing. Library supports both Android and iOS with Fabric powers.
https://github.com/jpudysz/react-native-turbo-mock-location-detector
android fabric ios newarchitecture react-native typescript
Last synced: 1 day ago
JSON representation
Protect your business from location spoofing. Library supports both Android and iOS with Fabric powers.
- Host: GitHub
- URL: https://github.com/jpudysz/react-native-turbo-mock-location-detector
- Owner: jpudysz
- License: mit
- Created: 2022-08-12T15:42:46.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-08-15T21:32:00.000Z (5 months ago)
- Last Synced: 2024-12-27T20:07:19.696Z (8 days ago)
- Topics: android, fabric, ios, newarchitecture, react-native, typescript
- Language: TypeScript
- Homepage:
- Size: 792 KB
- Stars: 91
- Watchers: 3
- Forks: 8
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# react-native-turbo-mock-location-detector
Protect your business from location spoofing. Mock location detector is designed to detect and prevent any attempts to spoof GPS location, making it the perfect solution for any use case that requires accurate location tracking. Common examples include fleet management and logistics apps where truck drivers may use tools like [Location Changer](https://www.ultfone.com/ios-location-changer.html) and [Mock Locations](https://play.google.com/store/apps/details?id=ru.gavrikov.mocklocations&hl=pl&gl=US).
Library supports both new and old architecture of React Native.
## Installation
```sh
yarn add react-native-turbo-mock-location-detector
cd ios && pod install
```## Expo
Works with no additional config## Prerequisites
1. Use eg. [react-native-permissions](https://github.com/zoontek/react-native-permissions) to ask for location permission
2. In your AndroidManifest.xml use at least one of:
```xml```
3. In your Info.plist use:
```text
NSLocationWhenInUseUsageDescription
YOUR TEXT
```## Usage
```typescript
import { isMockingLocation, MockLocationDetectorErrorCode, MockLocationDetectorError } from 'react-native-mock-location-detector'useEffect(() => {
isMockingLocation()
.then(({ isLocationMocked }) => {
// isLocationMocked: boolean
// boolean result for Android and iOS >= 15.0
})
.catch((error: MockLocationDetectorError) => {
// error.message - descriptive message
switch (error.code) {
case MockLocationDetectorErrorCode.GPSNotEnabled: {
// user disabled GPS
return
}
case MockLocationDetectorErrorCode.NoLocationPermissionEnabled: {
// user has no permission to access location
return
}
case MockLocationDetectorErrorCode.CantDetermine: {
// always for iOS < 15.0
// for android and iOS if couldn't fetch GPS position
}
}
})
}, [])```
## Support
| Lib version | RN version |
|-------------|------------|
| 1.0 - 1.2 | \>= 0.68 |
| ^2.0 | 0.71, 0.72 |## Testing
Library was tested:
- on iOS with the use of [Location Changer](https://www.ultfone.com/ios-location-changer.html)
- on Android with the use of [Mock Locations](https://play.google.com/store/apps/details?id=ru.gavrikov.mocklocations&hl=pl&gl=US)## Contributing
See the [contributing guide](CONTRIBUTING.md) to learn how to contribute to the repository and the development workflow.
## License
MIT
---