Adversaries may use a device’s geographical location to limit certain malicious behaviors. For example, malware operators may limit the distribution of a second stage payload to certain geographic regions.[1]
Geofencing is accomplished by persuading the user to grant the application permission to access location services. The application can then collect, process, and exfiltrate the device’s location to perform location-based actions, such as ceasing malicious behavior or showing region-specific advertisements.
One method to accomplish Geofencing on Android is to use the built-in Geofencing API to automatically trigger certain behaviors when the device enters or exits a specified radius around a geographical location. Similar to other Geofencing methods, this requires that the user has granted the ACCESS_FINE_LOCATION
and ACCESS_BACKGROUND_LOCATION
permissions. The latter is only required if the application targets Android 10 (API level 29) or higher. However, Android 11 introduced additional permission controls that may restrict background location collection based on user permission choices at runtime. These additional controls include "Allow only while using the app", which will effectively prohibit background location collection.[2]
Similarly, on iOS, developers can use built-in APIs to setup and execute geofencing. Depending on the use case, the app will either need to call requestWhenInUseAuthorization()
or requestAlwaysAuthorization()
, depending on when access to the location services is required. Similar to Android, users also have the option to limit when the application can access the device’s location, including one-time use and only when the application is running in the foreground.[3]
Geofencing can be used to prevent exposure of capabilities in environments that are not intended to be compromised or operated within. For example, location data could be used to limit malware spread and/or capabilities, which could also potentially evade application analysis environments (ex: malware analysis outside of the target geographic area). Other malicious usages could include showing language-specific Input Prompts and/or advertisements.
ID | Name | Description |
---|---|---|
S0507 | eSurv |
eSurv imposes geo-restrictions when delivering the second stage.[1] |
G0112 | Windshift |
Windshift has region-locked their malicious applications during their Operation BULL campaign.[4] |
ID | Mitigation | Description |
---|---|---|
M1005 | Application Vetting |
Application vetting services can detect unnecessary and potentially abused location permissions or API calls. |
M1006 | Use Recent OS Version |
New OS releases frequently contain additional limitations or controls around device location access. |
M1011 | User Guidance |
Users should be advised to be extra scrutinous of applications that request location permissions, and to deny any permissions requests for applications they do not recognize. |
Users can review which applications have location permissions in the operating system’s settings menu. On Android 10 and later, the system shows a notification to the user when an app has been accessing device location in the background.