Heimdall is an advanced toolkit designed to empower researchers, developers, and privacy enthusiasts in analysing and studying the privacy-related behavior of Android applications. By providing a comprehensive overview of permissions, embedded third-party libraries, and network traffic, Heimdall aims to foster transparency and awareness regarding mobile privacy. Through a scoring framework and an intuitive interface, it makes complex privacy information more accessible for users.
Heimdall is still under active development, with lots of features and refinements still to come. Feel free to use the issue tracker if you come across any bugs or have feature requests!
- Permission Analysis: Heimdall helps you to view and analyze the permissions used by installed apps, providing a detailed breakdown of what resources an app may access.
- Library Detection: Easily detect embedded third-party libraries and SDKs that may be collecting user data.
- Network Traffic Monitoring: Real-time inspection of network traffic to help you identify potential data leakages or suspicious connections.
- Fully on-device: Heimdall requires no external infrastructure and does not transmit any data off the device, be it personal or any other kind of data.
- Privacy Score Gathered privacy information on apps is abstracted and condensed into an intuitive numeric score. Gamify your privacy!
- Modular Extensions Framework: Metrics for this score can easily be added via in a single file - plug-and-play! We provide a template that makes it easy to create a new Module.
- Accessible UI: Visual indicators, color coding and helpful info texts make discovering your apps data processing easy and engaging.
- Android SDK version 28 (Android 9) or higher. We're working on making Heimdall compatible with older Android versions.
- Root access is required to decrypt HTTPS traffic of monitored apps. All other features work in standard user space. If you don't need to access the application-layer traffic of monitored apps, there's no need to modify your device in any way.
- Clone this repository:
git clone https://github.com/proxycon/heimdall.git
- Open the project with Android Studio
- Build and run the app on an emulator or your device, using USB or WiFI debugging.
Alternatively you can install the .apk
found
under Releases or build the apk yourself.
Heimdall leverages a variety of tools, frameworks and technologies, most notably:
- Gradle offers extensive build automation for Kotlin and Android development.
- Jetpack Compose and Material Design 3 are Android’s recommended modern toolkit and design system for building native User Interfaces that offer many standardized components.
- Room is the recommended built-in local database solution of Android. It provides a well integrated abstraction of SQLite , the most widespread database engine.
- kotlinx.serilization.json was used for JSON en- and decoding as official serialization library of Kotlin.
Heimdall comprises three Scanners:
PermissionScanner
- Queries thePackageManager
API for all permissions requested by (but not necessarily granted to) monitored apps.LibraryScanner
- Parses the .dex files of monitored apps to extract their package signatures and matches them against the Exodus Privacy Project's database of third-party tracker signatures to identify trackers embedded in monitored apps.TrafficScanner
- Leverages theVpnService
API to intercept the network traffic of monitored apps. In standard user space, extracted information is limited to connection metadata, e.g. hostnames and geolocation of remote servers. On rooted devices, theTrafficScanner
is capable of employing an on-device Man-in-the-Middle (MitM) VPN layer to decrypt HTTPS traffic, thereby granting access to the application-layer data transmitted by monitored apps.
The figure below shows how these scanners extract data from monitored apps, what label sources they employ to label the extracted data and what insights can be gained by analysing the data:
In modern versions of Android, HTTPS is enabled by default, which means that the vast majority of network traffic is TLS-encrypted as it passes through Heimdall's TrafficScanner
.
Bypassing this encryption requires the use of a MitM attack to hijack the TLS sessions that monitored apps establish with remote hosts.
his capability is baked into the TrafficScanner in the form of a MitM-VPN layer and can be enabled via the MitM preferences menu.
To function correctly, the MitM-VPN requires a custom root CA certificate to be installed on the device. Since Android 7, user-installed CA certificates are no longer accepted by default, which means that in most cases, the custom CA certificate must be placed in the system CA store for apps to accept it. This generally requires root access on the device.
Here's how to install Heimdall's custom CA on a rooted device using Magisk:
- Root your device and install Magisk
- Open Heimdall, navigate to the MitM preferences and select
Generate Magisk Module
- Open Magisk and import the generated module
- Reboot your device and verify that the module is installed correctly
If you are using a rooted device without Magisk, you need to generate Heimdall's CA certificate by navigating to the MitM preferences and selecting Generate CA certificate
and manually add it to the system CA store located at:
system/etc/security/cacerts
Once you have installed the custom CA certificate, simply enable the MitM VPN via the MitM preferences and launch the TrafficScanner
.
Evaluation of installed apps is mainly driven by the Evaluator. It is the interface between the modules and the rest of the application. A typical data flow might look like this:
Currently, there are two example modules implemented:
StaticPermissonScore
evaluates the static permissions an app might use, declared in it's manifests. This is not to be confused with the permission the app is actively using at any given time.TrackerScore
evaluates results from theLibraryScanner
and deducts points from the score for each tracker library found in the app.
Future development might add Modules for active traffic, privacy policy or activity analysis.
All data collected by Heimdall is persisted in an on-device SQLite database and can be exported for external analysis. While better and more convenient methods are developed, use the Database inspector of Android Studio to export Heimdall's database
You can also export evaluation results for a single app directly from within Heimdall. The export will be formatted as JSON for easy further processing and contain the following data:
Of course, additional properties your module might record can be added to this.
Export flows for the whole database in the following formats are currently under development:
- SQLite database dump
- CSV
- JSON
Feel free to open a new issue for bug reports or feature requests. Pull requests for contributions are always welcome!
The code is documented using KDoc and follows the official KDoc Style Guide.
If you want to add your own module into Heimdall, create a file in
the modules directory and add one line in
the
init()
of
the ModuleFactory:
init {
/* add new modules here: */
this.registeredModules.add(yourNewModule())
}
For orientation, what functionality is expected of your module, refer to the Module Template Class. All modules should inherit from this class and have to implement the required function for the evaluation to work. You are very unrestricted in the design of your module and can even decide how you metric data is presented to the user.
If you use this toolkit in your academic research, please be so kind as to cite our paper introducing Heimdall:
@INPROCEEDINGS{9343230,
author={Cory, Thomas and Raschke, Philip and Küpper, Axel},
booktitle={2020 IEEE 19th International Conference on Trust, Security and Privacy in Computing and Communications (TrustCom)},
title={Heimdall: Illuminating the Hidden Depths of Third-Party Tracking in Android Applications},
year={2020},
volume={},
number={},
pages={676-682},
doi={10.1109/TrustCom50675.2020.00094}}
Heimdall is being developed by a team of researchers and students lead by Thomas Cory at the Service-centric Networking chair at Technische Universität Berlin.
Early versions of the TrafficScanner employed LittleProxy-mitm to decrypt HTTPS traffic - and the proxy remains an optional feature to supplement the MitM-VPN layer.
Identification of third-party tracking hosts is based on the unified hosts file curated by Steven Black. Similarly, third-party tracking library identification is based on the database curated by the Exodus Privacy Project.
This project is licensed under GPLv3.