Skip to main content
PLOS ONE logoLink to PLOS ONE
. 2021 May 14;16(5):e0251867. doi: 10.1371/journal.pone.0251867

Dissecting contact tracing apps in the Android platform

Vasileios Kouliaridis 1, Georgios Kambourakis 2,*, Efstratios Chatzoglou 1, Dimitrios Geneiatakis 3, Hua Wang 4
Editor: Jacopo Soldani5
PMCID: PMC8121305  PMID: 33989350

Abstract

Contact tracing has historically been used to retard the spread of infectious diseases, but if it is exercised by hand in large-scale, it is known to be a resource-intensive and quite deficient process. Nowadays, digital contact tracing has promptly emerged as an indispensable asset in the global fight against the coronavirus pandemic. The work at hand offers a meticulous study of all the official Android contact tracing apps deployed hitherto by European countries. Each app is closely scrutinized both statically and dynamically by means of dynamic instrumentation. Depending on the level of examination, static analysis results are grouped in two axes. The first encompasses permissions, API calls, and possible connections to external URLs, while the second concentrates on potential security weaknesses and vulnerabilities, including the use of trackers, in-depth manifest analysis, shared software analysis, and taint analysis. Dynamic analysis on the other hand collects data pertaining to Java classes and network traffic. The results demonstrate that while overall these apps are well-engineered, they are not free of weaknesses, vulnerabilities, and misconfigurations that may ultimately put the user security and privacy at risk.

1 Introduction

Digital contact tracing mobile applications (apps) have lately emerged as an invaluable weapon in the hands of governments worldwide in the fight against the COVID-19 pandemic and future epidemics in general. Very quickly, a number of centralised or decentralised digital contact tracing architectures have been proposed [1], while even Google and Apple have aligned their forces to develop a joint privacy-preserving contact tracing framework API based on Bluetooth Low Energy (BLE), commonly known as Google-Apple Exposure Notification (GAEN) or Exposure Notifications System (ENS) [2]. For obvious reasons, the use of the Exposure Notification API is restricted to apps that have been developed by official public health agencies [3, 4].

In the meanwhile, the topic of digital contact tracing has received considerable attention in the literature. In the following, we only refer to works that are pertinent to ours, intentionally leaving out others that are mostly concerned with frameworks [5, 6] and user privacy matters [7, 8].

Hyunghoon et al. [9] focused on the Singapore’s TraceTogether App and compared its characteristics against four alternative contact tracing systems, namely polling-based model, polling-based model with mixing, the use of a public database, and the exploitation of a private messaging system. They concentrated on the required computational infrastructure per system and on user privacy by considering a semi-honest model. Raskar et al. [10] outlined the different technological approaches to mobile-based contact tracing and elaborated on the risks that these technologies may pose to individuals and societies. Furthermore, the authors came up with a number of security enhancing approaches that can mitigate certain risks.

Nadeem et al. [11] conducted a detailed overview of the existing contact tracing architectures as well as its privacy and security issues. Furthermore, the authors surveyed several contact tracing apps and analysed their privacy and security impact. Their work relies on public information about existing tracing apps, and the authors’ own comprehension of the relevant protocols being developed for upcoming apps. Jinfeng [12] et al. presented a short survey of the various data regulations and technology protocols for contact tracing apps as well as a global overview of contact tracing app deployment. Martin et al. [1] contributed a full-fledged comprehensive review of both the emerged contact tracing architectures and the contact tracing apps that have been already deployed by European countries. The discussion related to the apps is done in a rather high-level manner, i.e., concentrating on its installation and functionality, without touching on code analysis.

Recently, Samhi et al. [13] investigated COVID-related Android apps, in an attempt to empirically study their characteristics. Amongst others, the authors (a) generically reported on the top-10 most requested permissions by those apps, (b) examined the presence of privacy leaks by utilising the well-known, but rather obsolete (it has not been updated since 2016) FlowDroid-IccTA tool, (c) checked whether each app is flagged by VirusTotal, and (d) checked for potential misuse of crypto-APIs. They concluded that overall the apps do not seem to leak sensitive data. While this work is the one closer to ours, it is not devoted to privacy or security, thus the results reported by the authors remain mostly at a high-level and address a limited number of analysis axes.

Clearly, as digital tracing apps require mass acceptance in the population, and mass approval is largely based on perceived privacy, security and privacy design becomes a key concern for both policy makers and app architects in this field. Trang et al. [14] elaborate on this matter, and specifically concentrate on ways to attain mass acceptance of tracing apps depending on the context at hand. They identify three groups of citizens with different tendency for acceptance, namely critics, undecided, and advocates. Interestingly, they argue that only one set of tracing app specifications should be formulated for all citizens, and hence an exact targeting of diverse groups is not practical. Therefore, policy makers should first decide if the majority of the population can be assigned to one of the three groups or these groups are somewhat equally split. In the former case, their findings demonstrate that critics respond to societal-benefit appeals and privacy design, and thus policy makers must concentrate on communicating societal-benefit appeals and guarantee minimal exposure to privacy risks. Moreover, among others, although privacy design does play a significant role for undecided citizens, convenience in app usage seems to be more relevant to this group. For advocates, the authors’ findings suggest that “none of the benefit appeals is superior in achieving mass acceptance”, so “policy makers may consider deprioritizing privacy and convenience as advocates would not penalize sacrifices to privacy and convenience”. However, if the population is roughly equally split among the three groups, policy makers should lean toward a carefully app specification set that fulfills the expectations of multiple groups at the same time. That is, they need to specify the app for meeting as closely as possible the needs of the critics and reluctant ones, if these groups prevail; in this respect, privacy, security, and convenience of use should be the primary impetus for persuading more people to participate.

Our contribution: The work at hand aims at scrutinizing both the visible and under-the-hood functionality of the already deployed official Android contact tracing apps by European countries. The term “official” means apps that have been developed by official public health agencies. As seen from Table 1, up to now, a total of twenty-six apps are available. We specifically seek to deliver answers to a couple of essential matters with reference to the security and privacy aspects of this sort of apps. Namely, do these apps (a) curtail their functionality to the strict minimum?, and (b) remain free of known misconfigurations, weaknesses, vulnerabilities, and privacy leaks? As mentioned previously, and especially in reference to the work by [14], privacy and security aspects are decisive factors when it comes to the mass acceptance of this kind of apps in the population, while this issue is also directly linked to the trade-offs that policy makers face in responding to the urgent challenges posed by the pandemic.

Table 1. Outline of the examined apps.

App’s name Country Analysed version GAEN Open-source
Stopp Corona [15] Austria 2.0.8.1133
Coronalert [16] Belgium 1.11.2
ViruSafe [17] Bulgaria 1.0.3
Stop COVID-19 [18] Croatia 2.2.0
CovTracer [19] Cyprus 1.3.2
eRouska [20] Czech Republic 2.2.687 *
Smittestop [21] Denmark 2.1.1
Hoia [22] Estonia 1.0.8
Koronavilkku [23] Finland 2.0.2
TousAntiCovid [24] France 2.2.3
Corona-Warn-App [25] Germany 1.10.1
VirusRadar [26] Hungary 1.0.0
COVID Tracker [27] Ireland 1.0.4
Immuni [28] Italy 2.2.1
Apturi Covid [29] Latvia 1.1
Korona Stop LT [30] Lithuania 1.1.1
COVID Alert [31] Malta 1.3.5
CoronaMelder [32] Netherlands 1.2.2
Smittestopp [33] Norway 1.0.3
STOP COVID—ProteGO Safe [34] Poland 4.9.0
STAYAWAY COVID [35] Portugal 1.1.2
ZostanZdravy [36] Slovakia 1.1.0 #
#OstaniZdrav [37] Slovenia 1.10.1
Radar COVID [38] Spain 1.2.0
SwissCovid [39] Switzerland 1.3.1
NHS COVID-19 [40] UK 4.3

The interested reader can also refer to [4], which gathers all GAEN-based apps worldwide.

Centralised/proprietary approach.

Formerly known as CovTracer. It embraced GAEN on Dec. 2020.

*From ver. 2.0 onward. Prior versions were based on a centralised framework.

#The official website at https://korona.gov.sk/en/ provides a dead link to Google Play Store.

Naturally, app analysis in search of security and privacy concerns is a dynamic and constant process, and this holds especially true for the swiftly introduced contact tracing apps. Given that, until reaching a mature state, these apps are quite frequently updated, and thus the results presented here may not exactly catch up with the very latest version per app. Nevertheless, overall, we argue that the outcomes of this work more or less reflect the general propensity and can be used as a basis for further research in this field. The emphasis is on promoting best practices that facilitate the minimization of the attack surface, prevent data leakage, and foster security and privacy by design in general. We deliver hands-on results stemming from a full-spectrum static analysis, and in addition, we identify: (a) potentially privacy-invasive APIs, (b) possible connections to external URLs, i.e., not API-related URLs that the app might try to connect to, (c) configurations, weaknesses and vulnerabilities that may exist in the app’s manifest file or code. Moreover, all apps have been dynamically analyzed by means of dynamic instrumentation. The outcomes in this case are not momentous, that is, no striking, unconventional, or covert behavior has been perceived, but mostly they serve as a verification step for the static analysis results. However, given that dynamic instrumentation basically depends on method hooking, and therefore needs intensive interaction with the running app, the aforementioned result can only be considered as rudimentary and more work is needed to examine and understand the exact behavior of the code. On top of that, in view of the fact that the great majority of such apps exploit GAEN [2], we position each of them vis-à-vis a baseline privacy policy as defined by the above-mentioned framework.

Given the above, to the best of our knowledge, the current work is the first to elaborately profile the behavior of each of these apps after delving into its code both statically and dynamically. That is, in contrast to our work, all previous contributions in the literature deal with the security, privacy, or usability characteristics of the various hitherto deployed apps either in a high-level, incomplete manner or based on information made available in the app’s website or elsewhere.

The rest of this paper is structured as follows. The next section details on the methodology used to collect and analyze the apps. A first-tier static analysis focusing on apps’ permissions and API calls is given in section 3. A deeper static analysis targeting on a range of possible weaknesses and vulnerabilities is delivered in section 4. The penultimate section details on the results of dynamic analysis, while section 6 concludes and gives pointers to future work.

2 Methodology

Twenty six official apps were collected from the Google Play Store [41] with freeze date as of February 2, 2021. All the essential pieces of information per app, including the analyzed version, whether the app is based on GAEN, and if its source code is publicly available are summarized in Table 1. The apps are sorted alphabetically by their country of origin, and the same sorting order is followed for the rest of the tables and figures across all the sections of this work. For a more detailed high-level presentation of each app, the interested reader may refer to the work of Martin et al. [1, 42].

As shown in Fig 1, two axes of analysis were followed. The first, scrutinizes each app statically, while the second examines the app by running it. Specifically, the static axis incorporates a number of analysis steps, including (a) sensitive permissions and API calls, and third-party trackers, which target mainly the privacy of the end-user, and (b) misconfigurations, weaknesses and vulnerabilities, which focus on the security of the app. For instance, the latter step inspects the code of each app for possibly identifying Common Weakness Enumerations (CWEs), Common Vulnerabilities and Exposures (CVEs), misconfigurations attributed to the use of shared libraries, etc. This step also includes a basic taint analysis.

Fig 1. Overview of the followed methodology.

Fig 1

Static analysis employed three different tools. Two of them, namely Androtomist [43] and MobSF [44] are open-source, while the other, namely Ostorlab [45], utilized only for outdated software component analysis and taint analysis, is a software-as-a-service (SaaS) product. Specifics on these tools are given in the respective sections. When looking for weaknesses and vulnerabilities, we also relied on the methodology set out in the OWASP mobile security testing guide [46].

On the other hand, the dynamic analysis axis concentrates on the use of Java classes and network traffic. As already mentioned, this axis of analysis has been carried out by means of dynamic instrumentation, i.e., the instrumentation, namely, method hooking, is added during the app execution in a just-in-time (JIT) approach. For this task, the Androtomist tool was exploited along with the Nvidia Shield K tablet [47], running on Android 7.0. Note that this device is SIM-less, which, depending on the case, may affect the proper running of apps that require cellular services. To cover all possible functionality, each app was exercised by hand, that is, not via the use of a UI/app exerciser.

3 High-level static analysis

Each app has been statically analyzed following the step-by-step procedure illustrated in Fig 1. Namely, the corresponding android package (APK) archive has been extracted and then decompiled using the apktool [48]. Next, (a) the manifest file has been unpacked and compared against a baseline policy given in subsection 3.1, and (b) the API calls have been retrieved from the smali files. The results have been cross-checked via the Androtomist tool [43]. At minimum, this kind of analysis offers insight on whether the app:

  1. Follows the least privilege principle regarding its declared permissions.

  2. Might enable privacy-sensitive, that is, “dangerous” operations as designated by the Android API [49].

  3. Contains API calls that do not coincide with the requested permissions.

Furthermore, we provide an overall evaluation of the security level of the external network domains each app might connect to, that is, every URL found in its code. This assessment was done with the aid of the “SSL Server Test” as offered by Qualys SSL labs [50]. Precisely, as detailed in [51], this test thoroughly examines the configuration of any TLS web server based on four main criteria, namely, certificate, protocol support, key exchange, and cipher strength. The results vary from “A+” (exceptional configuration) to “F” (vulnerabilities exist). Also, the letter “T” means that the website certificate is not trusted.

3.1 Baseline policy

Assuming the use of GAEN [2], as a baseline, contact tracing apps based on BLE should at the bare minimum ask for the following two “normal” permissions [5254]:

  • BLUETOOTH: This permission is necessary for enabling any Bluetooth communication, i.e., either requesting/accepting a connection or transferring data.

  • INTERNET: It enables the app to perform network operations. Note that this permission goes hand in hand with the ACCESS_NETWORK_STATE one.

According to [54], a GAEN-based contact tracing app does not need and cannot include either BLUETOOTH_ADMIN, ACCESS_FINE_LOCATION, or ACCESS_COARSE_LOCATION. The latter two permissions are classified as “dangerous” in the Android API. Recall that, in contrast to a “normal” permission, every higher-risk one necessitates prompting the user.

  • BLUETOOTH_ADMIN. It is required to trigger device discovery or manipulate the Bluetooth settings. Note that if an app requires this permission, then the app must also declare the BLUETOOTH one.

  • ACCESS_FINE_LOCATION. This permission allows the app to access the precise location of the device via the use of GPS, Wi-Fi, or mobile cell data. On devices running Android 6.0 to 10, the ENS relies on Bluetooth scanning, which in turn mandates the device location setting to be turned on [55]. It should be pointed out that according to [52], the smartphone’s location setting should be enabled: “The system uses this to scan for Bluetooth signals. The system does not collect or track your location”. And in [52], public health authority “apps that use the ENS are not permitted to request permission to use your device location”. On the other hand, for devices running Android 11, ENS does not mandate the smartphone’s location setting to be enabled: “We’re making this update for ENS only, given that ENS has been designed in such a way that neither the system nor the apps using it can infer device location through Bluetooth scanning, and apps that are allowed to use ENS are subject to additional policies that disallow automatic collection of location” [56].

  • ACCESS_COARSE_LOCATION is potentially privacy-invasive as it allows an app to access the approximate location of the device through the use of either or both Wi-Fi and mobile cell data. The accuracy provided to the app is approximately equivalent to a city block.

As already pointed out, API calls per app have been also tracked down. However, in this case, instead of providing a baseline, which is considered impractical, this section only identifies certain API calls that may pose a threat to user privacy. On top of that, this enables one to detect API calls that are in conflict with the requested permissions. Precisely, the focus is on the following list of API calls:

  • android/telephony/TelephonyManager; → getNetworkOperator() returns the mobile country code (MCC) and mobile network code (MNC) of the current registered operator.

  • android/telephony/TelephonyManager; → getNetworkOperatorName() returns the alphabetic name of the current registered operator.

  • android/telephony/TelephonyManager; → getLine1Number() returns the phone number string for line 1, say, the Mobile Station International Subscriber Directory Number (MSISDN) for a GSM phone for a specific subscription. It requires at least one of the following permissions READ_PHONE_STATE, READ_SMS, or READ_PHONE_NUMBERS.

  • android/telephony/TelephonyManager; → getSimCountryIso() returns the SIM provider’s country code.

  • android/telephony/TelephonyManager; → getSimOperatorName() returns the service provider name.

  • android/telephony/TelephonyManager; → getCellLocation() returns the current location of the device and requires the ACCESS_FINE_LOCATION permission. This method was deprecated in Android v8.

  • android/location/LocationManager; → getLastKnownLocation() gets the last known (cached in memory) location, if any, from the given provider. It requires either the ACCESS_COARSE_LOCATION or ACCESS_FINE_LOCATION permission.

  • android/location/LocationManager; → requestLocationUpdates() is used to register for location updates from the given provider. It presupposes the same permission as the getLastKnownLocation() one.

  • android/location/Location; → getLatitude() and android/location/Location; → getLongitude() API calls are used to obtain the latitude and longitude of the device, respectively.

  • android/hardware/Camera; → open() is used to access a particular hardware camera. It presupposes the CAMERA permission.

  • android/hardware/camera2/CameraManager is a system service manager for detecting, characterising, and connecting to CameraDevice.

3.2 Analysis of apps

This section outlines all noteworthy results per app in regard to this first level of static analysis. Extracting the security permissions listed in the AndroidManifest.xml file of an app is a principal step towards understanding its general behavior. Moreover, the lookup for potentially privacy-invasive API calls in the app’s code can on the one hand offer supplementary information about higher-risk actions the app may perform, and on the other, reveal whether the identified calls coincide with the requested permissions. Table 2 summarizes the requested permissions per app with reference to the baseline policy. Additionally, the fourth column of the table shows any extra “dangerous” permission identified in each analyzed app.

Table 2. Overview of requested permissions per app vis-à-vis the baseline.

App BLUETOOTH INTERNET Extra permissions
Stopp Corona + +
Coronalert + +
ViruSafe + ACCESS_BACKGROUND_LOCATION, ACCESS_FINE_LOCATION
Stop COVID-19 + +
CovTracer + +
eRouska + +
Smittestop + +
Hoia + +
KoronaVilkku + +
TousAntiCovid + + CAMERA, ACCESS_COARSE_LOCATION, ACCESS_FINE_LOCATION
Corona-Warn-App + + CAMERA
VirusRadar + + ACCESS_COARSE_LOCATION, ACCESS_FINE_LOCATION
COVID Tracker + +
Immuni + +
Apturi Covid + +
Korona Stop LT + +
COVID Alert + +
CoronaMelder + +
Smittestopp + +
STOP COVID—ProteGO Safe + +
STAYAWAY COVID + +
ZostanZdravy + + ACCESS_FINE_LOCATION, ACCESS_BACKGROUND_LOCATION
#OstaniZdrav + +
Radar COVID + +
SwissCovid + +
NHS COVID-19 + + CAMERA
Total 25 26
  • ViruSafe does not rely on BLE for contact tracing, but on GPS. Naturally, for this app, the baseline policy given in section 3.1 does not apply. Also, TousAntiCovid, VirusRadar, and ZostanZdravy use BLE in conjunction with GPS.

  • With reference to the data minimization principle, all GAEN-based apps seem to abide by the baseline policy. This ensures that only the data which are strictly essential for the running of the service are gathered. Interestingly, only two apps declare an additional dangerous permission, namely CAMERA, on top of those mandated by the baseline policy.

  • Regarding “dangerous” permissions for not GAEN-based apps, ACCESS_COARSE_LOCATION, ACCESS_FINE_LOCATION, CAMERA, and ACCESS_BACKGROUND_LOCATION are exploited by 2, 4, 1, and 2 of them, respectively. Note that the latter permission allows an app to access location in the background, and it goes hand in hand with either ACCESS_COARSE_LOCATION or ACCESS_FINE_LOCATION.

  • As observed from Table 3, the code of all the apps but 5 contain at least one external, not API-related, URL where the app might try to connect to. The security analysis of the domains of these hyperlinks designate that most of them are classified in the range from A+ to B according to [50]. Specifically, from the total of 49 URLs, about 69% were classified as A+ or A, which is definitely on the plus side. On the other hand, an approximately 20% were ranked as B, three URLs have received a “T” score, and another one an “F”. No less important, 11 apps or ≈41% contain only A+ of A-rated URLs.

Table 3. TLS server security level rating of external URLs per app.

App Number of URLs Domain ratings Domains
Stopp Corona 3 A https://cdn.prod-rca-coronaapp-fd.net
A https://app.prod-rca-coronaapp-fd.net
A+ https://sms.prod-rca-coronaapp-fd.net
Coronalert 5 A https://c19statcdn-prd.ixor.be
A coronalert-prd.ixor.be
A c19statcdn-prd.ixor.be
A c19-submission-prd.ixor.be
A c19-verification-prd.ixor.be
ViruSafe 1 A https://virusafe.io/
Stop COVID-19 0
CovTracer 2 A https://kiosapps.ucy.ac.cy
B covtracer.dmrid.gov.cy
eRouska 1 A+ https://erouska.cz
Smittestop 0
Hoia 4 A https://www.digilugu.ee
A+ https://www.terviseamet.ee
A+ https://hoia.me
A https://enapi.sm.ee
KoronaVilkku 2 A https://omaolo.fi
A+ https://repo.thl.fi
TousAntiCovid 5 B https://api.stopcovid.gouv.fr
B https://tacw.tousanticovid.gouv.fr
T https://stopcovid.gouv.fr
T https://app.stopcovid.gouv.fr
A https://tac.gouv.fr
Corona-Warn-App 1 N/A (dead link) https://submission.coronawarn.ap
VirusRadar 2 B https://f-droid.org
A+ https://github.com
COVID Tracker 0
Immuni 1 A+ https://www.immuni.italia.it
Apturi Covid 3 A+ https://apturicovid-files.spkc.gov.lv
A+ apturicovid-api.spkc.gov.lv
A+ apturicovid-files.spkc.gov.lv
Korona Stop LT 3 B https://download.koronastop.lt
B https://submission.koronastop.lt
B https://verification.koronastop.lt
COVID Alert 4 B https://tools.ietf.org
A https://data.ws.covidalert.gov.mt
A https://authz.ws.covidalert.gov.mt
A https://config.ws.covidalert.gov.mt
CoronaMelder 2 A+ https://coronamelder-api.nl
B https://productie.coronamelder-dist.nl
Smittestopp 1 A https://in.appcenter.ms
STOP COVID—ProteGO Safe 2 A+ https://safesafe.app
A+ https://v4.safesafe.app
STAYAWAY COVID 2 F https://stayaway.min-saude.pt
A https://stayaway.incm.pt
ZostanZdravy 1 B https://t.mojeezdravie.sk
#OstaniZdrav 0
Radar COVID 1 A https://radarcovid.covid19.gob.es
SwissCovid 3 A https://www.pt1.bfs.admin.ch
T https://www.pt.bfs.admin.ch
A https://codegen-service.bag.admin.ch
NHS COVID-19 0
Total 49 13xA+, 21xA, 10xB, 3xT, 1xF

As already pointed out, API calls per app have been also extracted with the aim of identifying certain call to methods which may pose a threat to the user’s privacy. Specifically, the API calls listed in section 3.1 have been grouped in Table 4 into three categories, namely cellular network, location, and camera. It is noteworthy that API calls related to the cellular network may also expose the user’s location. For example, the phone number (getLine1Number()) or SIM operator name (getSimOperatorName()) may reveal the user’s country, while getCellLocation() returns the current location of the device. Precisely, as outlined in Table 5, the following key observations have been made.

Table 4. Categorisation of sensitive API calls discovered in the apps.

Relevant System API Calls
Cellular Network android/telephony/TelephonyManager; → getNetworkOperatorName()
android/telephony/TelephonyManager; → getNetworkOperator()
android/telephony/TelephonyManager; → getLine1Number()
android/telephony/TelephonyManager; → getSimOperatorName()
android/telephony/TelephonyManager; → getSimCountryIso()
android/telephony/TelephonyManager; → getCellLocation()
Location android/location/LocationManager; → getLastKnownLocation()
android/location/LocationManager; → requestLocationUpdates()
android/location/Location; → getLatitude()
android/location/Location; → getLongitude()
Camera android/hardware/Camera; → open()
android/hardware/camera2/CameraManager; → *

*All class methods.

Table 5. Potentially privacy-invasive API call groups per app.

App Cellular Network Location Camera
Stopp Corona +*
Coronalert +* +*
ViruSafe +
Stop COVID-19 +*
CovTracer + +*
eRouska +*
Smittestop +*
Hoia +*
KoronaVilkku +*
TousAntiCovid + +
Corona-Warn-App +* +
VirusRadar +
COVID Tracker + +*
Immuni +*
Apturi Covid +* +*
Korona Stop LT +*
COVID Alert +*
CoronaMelder +*
Smittestopp + +*
STOP COVID—ProteGO Safe +*
STAYAWAY COVID +*
ZostanZdravy +
#OstaniZdrav +* +*
Radar COVID +*
SwissCovid +*
NHS COVID-19 +* +
Total 3 26 6

The asterisk indicates that at least one API call does not coincide with the permissions requested by this app.

  • All apps include android/location/LocationManager; → getLastKnownLocation, which gets the last known location, if any, from the given provider. On top of that, all apps include the android/location/Location; → getLatitude and android/location/Location; → getLongitude API calls, which are used to get the latitude and longitude of the device. Nevertheless, as explained in 3.1 for the ACCESS_FINE_LOCATION, according to [55], GAEN-based apps are not permitted to request permission to use the device location. Also, according to the Android API, only apps which declare the ACCESS_COARSE_LOCATION or ACCESS_FINE_LOCATION permissions are able to get device location data. So, overall, the aforementioned three calls can be only carried out by apps which do not follow GAEN.

  • Corona-Warn-App-App, TousAntiCovid, NHS COVID-19, Apturi Covid, Coronalert, and #OstaniZdrav include android/hardware/Camera; → open, which creates a new Camera object to access the first back-facing camera on the device, if any. For the three first of the aforementioned apps this API call coincides with the requested permissions. Nevertheless, for the rest of them, this call is unjustifiable vis-à-vis the requested permissions, and anyway cannot be executed. Interestingly, according to an article from [57], Apple and Google recently refused to publish an updated version of the NHS COVID-19 app. The updated version was asking users to upload logs of venue check-ins, via barcode scans, if they tested positive for the virus. The reason behind this extra functionality would be to warn others. To enable this operation, an app would require permission for the camera, as well as the aforementioned API call. Both conditions are met for the three first of the above-mentioned apps.

  • CovTracer, COVID Tracker, and Smittestopp include the android/telephony/TelephonyManager; → getNetworkOperatorName call, which returns the alphabetical name of the current registered operator. As already pointed out, this may reveal the user’s country. According to the API, this method does not require any special permission, thus all these apps can indeed get the relevant information.

4 Low-level static analysis

To investigate further each examined app, and for subsections 4.1 to 4.5, we relied on the well-known Mobile Security Framework (MobSF) in v3.2.4 [44]. MobSF is capable of performing both static and dynamic analysis and is used as a pen-testing, malware analysis, and security assessment framework. It is also one of the all-in-one tools recommended by the OWASP Mobile Security Testing Guide [46].

As seen in Table 6, the focus of this part of study is on signer certificate information, APKiD, network security, code analysis aiming at divulging CWEs, tracker analysis, manifest analysis, and shared library binary analysis. For all these categories, and for the sake of conciseness, we only consider high severity (or high value according to the common weakness scoring system) weaknesses. For extracting the above-mentioned pieces of information, MobSF decompiles the provided APK using Dex to Java decompiler (Jadx) [58]; code de-obfuscation processes are applicable to this step as well.

Table 6. Potential weaknesses and other security issues per app.

App Name Signer certificate information Janus Network Security CWE-330 CWE-276 CWE-532 CWE-312 CWE-89 CWE-327 CWE-295 CWE-749 CWE-919
Stopp Corona + + +
Coronalert + + + + + + +
ViruSafe + + + + + AES ECB
Stop COVID-19 + + + +
CovTracer + + + + + MD5, AES-ECB
eRouska + + + +
Smittestop + + +
Hoia + + + + +
Koronavilkku + + + + + +
TousAntiCovid + + + + +
Corona-Warn-App + + + + + MD5, SHA1 +
VirusRadar + + + + +
COVID Tracker + + ++ + + + SHA1
Immuni + + + + + +
Apturi Covid + + + + +
Korona Stop LT + + + + SHA1 +
COVID Alert SHA1withRSA (SHA256withRSA) + + + +
CoronaMelder + + ++ + + +
Smittestopp + + + + + +
STOP COVID—ProteGO Safe + + + +
STAYAWAY COVID + + + + +
ZostanZdravy + Domain is insecurely configured and permits clear text traffic + ++ + + MD5, SHA1, AES-ECB
#OstaniZdrav + + + + + MD5, SHA1 +
Radar COVID + + + + +
SwissCovid + + + + +
NHS Covid-19 + Domain is insecurely configured and permits clear text traffic + + + + +
Total 1 26 2 25 16 24 18 17 7 5 1 1

Moreover, the last two subsections of the current section are devoted to the use of outdated third-party software by the apps and to taint analysis, respectively. For both these undertakings, the Ostorlab tool was utilised. Ostorlab is a well-known software-as-a-service (SaaS) product to review the security and privacy of mobile apps. Note that for the sake of the reproducibility of the results, we employed the free-to-use “community” edition of the tool. To our knowledge, the same tool has been exploited in the context of similar researches [5961].

4.1 Signer cert., APKiD, network security

Each APK is signed by the developer using a specific cryptographic hash function, say, SHA-1, and APK signature scheme version, say, v3. As observed from the second column of Table 6, one app indicates a diverse hash algorithm (SHA256) than the one actually used (SHA-1) to sign the app. Precisely, the algorithm in parenthesis indicates the hash algorithm declared in the app’s manifest file, while the actual algorithm used is shown at the left. Note that NIST deprecated the use of SHA-1 and suppressed its use for digital signatures in 2011 and 2013, respectively [62]. Precisely, if the app has been signed with the use of SHA-1, collisions may be possible. This means that any app signed with the corresponding algorithm is prone to attacks, including hijacking the app with phony updates or granting permissions to a malicious app. For example, the attacker can repackage the app after including malicious code in it. Then, if the signature validates, they could lure users to install the repacked app instead of the legitimate one.

Another vulnerability which is rooted to improper signature usage is commonly known as “Janus” (CVE-2017-13156) [63]. It can be exploited if the v1 signature scheme (JAR signing) is used along with Android v5.0 (API 21) to v7.0 (API 25). Specifically, Janus leverages the possibility of adding extra bytes to APK and DEX files, without affecting the signature. As perceived from Table 6, all the examined apps are vulnerable to Janus, namely, they were signed under scheme v1 and support Android v6.

As presented in Table 6, network security analysis pinpointed one high severity, self-explanatory vulnerability, namely, the “domain is insecurely configured and permits clear text traffic”. It is important to note that this issue refers to the network security configuration xml file an app may designate via a specific entry <application android:networkSecurityConfig=“”> in its manifest file under the <application> tag [64]. On the positive side, only two apps were found to be susceptible to that vulnerability.

4.2 CWEs

This subsection details on all the high value CWEs that are pertinent to each app. From them, CWE-89 currently belongs to the list of top 25 most dangerous software weaknesses [65], while CWE-295 and CWE-532 occupy positions 28 and 33 in the extended list, respectively.

  • CWE-330: The “Use of insufficiently random values” vulnerability pertains to the generation of predictable random values inside the app. This issue happens if the app uses an insecure random number generator. In OWASP top 10 mobile risks list (OWASP-10), this weakness is placed in the fifth position, namely “insufficient cryptography”. Surprisingly, all but one app are potentially prone to this weakness.

  • CWE-276: This CWE, namely “Incorrect default permissions”, occurs if the app is granted unneeded read/write permissions. So, any affected file can be read/written from anyone. With reference to OWASP-10, this weakness is classified under M2, namely, “insecure data storage”. As observed from the table, sixteen apps were potentially vulnerable to this weakness for at least one of the following reasons. The first, pertaining to the leftmost “+” sign, links to the fact that the app requests (read/write) access to the external storage. The second is related to the creation of a temp file, which may contain sensitive data. This is a major issue, since anyone can access folders that contain temp files, say, “/data/local/tmp/*”.

  • CWE-532: This weakness, namely, “Insertion of sensitive information into log file”, emerges when a production app has enabled logging information to a file. While this feature may be of aid during the development stage of an app, it must be removed before the app becomes publicly available. In simple terms, an attacker could read these files and acquire any private information stored on them. All apps but two are potentially vulnerable to this issue.

  • CWE-312: It is well-known as “Cleartext storage of sensitive information”, and classified as M9 in OWASP-10. That is, when sensitive information, e.g., a username and/or password, are stored in cleartext form, anyone may be in position to read them. In some cases, this information may be stored inside the code of the app, e.g., in a configuration file. As observed from the table, seven apps were immune to this weakness.

  • CWE-89: This hazardous weakness, titled “Improper neutralization of special elements used in an SQL command (’SQL Injection’)” is classified as M7 in OWASP-10. It arises when the app does not sanitize or improperly sanitizes input stemming from an upstream component, say, from a Web form for user authentication. About two-thirds of the apps were found to be potentially vulnerable to this issue.

  • CWE-327: It is referred to as “Use of a broken or risky cryptographic algorithm”, and it belongs to M5 (“Insufficient Cryptography”) of OWASP-10. This weakness relates to the usage of obsolete or risky encryption or hash algorithms. As observed from the table, six apps may potentially use at least one obsolete hash algorithm, namely MD5 or SHA-1, and 3 of them support AES in ECB mode.

  • CWE-295: This weakness titled “Improper certificate validation” is classified under M3 (“Insecure Communication”) in OWASP-10. This occurs in cases where the app is configured to trust an insecure or self-signed or any kind of certificate. This situation however may enable an opponent to mount man-in-the-middle (MitM) attacks. Five of the examined apps are potentially vulnerable to this weakness due to an insecure implementation of TLS.

  • CWE-749: It is referred to as “Exposed dangerous method or function” and classified as M1 (“Improper Platform Usage”) in OWASP-10. This weakness is linked to a number of grave vulnerabilities, which each time depend on the underlying vulnerable function. Specifically, one app was found to offer an insecure WebView implementation. The latter is used to display web content as part of an activity layout. In presence of this weakness, an attacker could possibly mount a MitM attack or even execute a Cross Site Scripting (XSS) injection. For more details regarding this issue, the interested reader may refer to the “WebView” section of [66].

  • CWE-919: This weakness titled “Weaknesses in Mobile Applications” is directly related to CWE-749. Both of them address the same issue, but for another matter. For the examined apps, it was observed that only one of them has enabled the remote WebView debugging. That is, debug mode must be disabled before deploying a production application, otherwise anyone who can access an unlocked mobile device can easily obtain the app’s data.

Altogether, the analysis demonstrated that a significant number of apps are susceptible to an array of high value common weaknesses. For instance, the great majority, i.e., 24 to 25 apps, were found to be prone to two of the revealed weaknesses, namely CWE-532 and CWE-330, respectively, while 18, 17, and 16 of them to CWE-312, CWE-89, and CWE-276, respectively. Overall, as with many other software and hardware products, despite the fact that keeping up-to-date with common and high severity weaknesses aids in preventing security vulnerabilities and mitigating risk, this situation bespeaks a rather medium priority on security features.

4.3 Tracker analysis

This subsection reports on third-party trackers that may be utilized by each app. Specifically, MobSF uses the open source Exodus-Privacy [67] webapp to analyze any detected tracker in the app’s APK. We report only on two tracker categories which were spotted in the analyzed apps.

“Crash reporters” focus on the crashes that may occur during the normal operation of the app. Upon a crash event, they send a notification message to the developers, informing them about the relevant error. On the other hand, an “analytics” tracker collects any possible information regarding the usage of the app by the users, say, the time each user spent in the app, which features they used, and so forth. For details about the third-party trackers issue in the mobile ecosystem, the interested reader can refer to the works in [6870].

App analysis revealed that 7 apps only employ Firebase [71] or other Google analytics service as a means to measure users’ engagement with them. On top of that, 17 apps were found to be free of any tracker, which certainly is on the plus side. For the rest two apps the following observations were made.

Microsoft Visual Studio App Center Crashes [72] and Microsoft Visual Studio App Center Analytics [73] were detected in Smittestopp. The first tracker creates an automatic report, which includes any required information related to an app crash. When the user re-opens the app, the report is sent to the “App Center”. In that regard, this tracker is categorized as crash reporter. Based on Exodus, the second tracker “collects real-time analytics that highlight users’ behavior. It also provides push notifications to mobile devices”, therefore it is categorized as an analytics one. Lastly, Matomo [74] and Bugsnag [75] trackers were detected in CovTracer. The former is an open-source analytics tracker, while the latter a crash analytics one.

4.4 Manifest analysis

Based on coarse-grained static analysis given in section 3, we noted the use of several dangerous permissions from a privacy-invasive perspective. To deepen the analysis, we utilized MobSF to scrutinize the manifest file of each app, and possibly reveal any latent weaknesses. The focus here is on services, activities, and broadcast receivers. All of them, utilize intents and intent-filters. Based on the Android developer’s guide, all of the aforementioned components, but the intents, must be declared in the manifest file of an app [76].

Intents are basically message objects, which are used for either intra- or inter-app communication. They have three main usages, namely start an activity, initiate a service, and deliver a broadcast. There are two types of intents, namely explicit and implicit. The former is used to handle messages within the app, while the latter to transfer messages towards another capable app. On the other hand, an intent filter is an expression in an app’s manifest file that determines the kind of intents the component would wish to obtain. In this respect, intent-filters are responsible for handling any implicit intent, e.g., broadcast receivers, and capturing system-oriented broadcast messages, where the specific broadcast message is contained inside an intent. This means that for an app to receive such a broadcast message, it must declare in its manifest file a matching intent-filter.

The service app component can perform operations without needing a user interface (UI), e.g., transferring files from one app to another without involving the user. There are three types of services; foreground, which is discernible to the user, background, which is not directly perceivable by the user, and bound, which is used to bound a specific service with an app. Lastly, activities is an key component of any Android app. An activity, comprises a single, specific thing the end-user can perform, and it usually involves a UI. For example, when a user opens an app, the main activity is typically executed.

App analysis revealed that some of these three types of components did not declare a permission in the respective manifest file. Namely, according to Android developer security tips [66], when a component is declared in the manifest file is by default enabled to communicate with other apps. To restrict this functionality, the developer must declare among others a permission to this component. Next, any other app must possess the same permission for being able to communicate with this component. Note that this is a minimum security measure, meaning it is not adequate to fully secure the component, but only lessen the magnitude of the issue. Therefore, the omission to at least provide the right permission to such a component is identified as a high severity weakness.

Precisely, the results obtained per app are summarized in Table 7. The left part of the table divides the components of interest in two categories, namely intent-filter on and off. The first (on) means that the app can send and also receive intents which target that specific component. When the received intent contains a malicious content, it can potentially compromise that app, e.g., bypass authentication [77]. The second (off) signifies that the app can potentially only send any information that will be requested from another app. Meaning that it is possible for the app to unwillingly leak sensitive information to an assailant. From the table, it is inferred that in either of these two categories and across all the three components, a considerably but generally not large number of apps, i.e., 1, 15, 3 and 8, 3, and 2, respectively neglect to declare the appropriate permissions.

Table 7. Potentially vulnerable components in the manifest file of each app.

App Name Intent-filter on Intent-filter off Cleartext
Service Broadcast Receiver Activity Service Broadcast Receiver Activity
Stopp Corona 1 1
Coronalert 1
ViruSafe 1
Stop COVID-19 1
CovTracer 1 1
eRouska 1 2
Smittestop 4 1
Hoia 1
Koronavilkku
TousAntiCovid
Corona-Warn-App 1
VirusRadar
COVID Tracker 1
Immuni 1
Apturi Covid 1
Korona Stop LT 1
COVID Alert 1
CoronaMelder 2 1
Smittestopp 3 1
STOP COVID—ProteGO Safe 1 1
STAYAWAY COVID 1
ZostanZdravy 1 1 1 +
#OstaniZdrav 1
Radar COVID 1
SwissCovid 1
NHS COVID-19 2 1
Total 1 15 3 8 3 2 1

The last column of Table 7 exhibits information on another important feature related to the contents of the manifest file. This is the android:usesCleartextTraffic flag in the <application> manifest element, which designates whether the app intends to use cleartext network traffic, including cleartext HTTP. As seen from the table, only one app allows this functionality. Naturally, this may compromise the privacy of the end-user.

4.5 Shared library analysis

This type of analysis pertains to the shared libraries (with the extension.so) an app may incorporate. These libraries, are typically written in C and compiled with the Android native development kit (NDK) toolset [78]. Android capitalizes on this logic for achieving better performance and reusing existing C libraries, without translating them to Java. These libraries are loaded into memory at runtime. Bear in mind that security and privacy issues with the use of shared libraries have been already identified in the Android literature [7981].

To investigate if and to what degree this issue applies to the examined apps, we present the number of potentially vulnerable shared libraries per app in Table 8. Again, we only consider high severity potential vulnerabilities, which pertain to four exploit mitigation techniques, namely, no-execute (NX), position-independent executable (PIE), Stack Canary, and relocation read-only (RELRO). These countermeasures, more accurately referred to as memory corruption mitigation techniques, are specific to C language, and if neglected may create space for memory-based exploits, which inevitably migrate to the affected Android app. As seen from the table, about half of the analyzed apps were found to incorporate shared libraries that overlook two of the above-mentioned remedies, namely PIE and RELRO, while only two apps have a plethora of libraries that disregard all four exploit mitigation techniques.

Table 8. Shared library issues per app.

App Name NX PIE Stack Canary RELRO
Stopp Corona
Coronalert 8 8
ViruSafe
Stop COVID-19
CovTracer 92 92
eRouska
Smittestop 409 560 546 568
Hoia
Koronavilkku 4 4
TousAntiCovid
Corona-Warn-App 8 8
VirusRadar
COVID Tracker 83 83
Immuni 4 4
Apturi Covid
Korona Stop LT 8 8
COVID Alert
CoronaMelder
Smittestopp 525 594 583 611
STOP COVID—ProteGO Safe 4 4
STAYAWAY COVID 80 80
ZostanZdravy
#OstaniZdrav 8 8
Radar COVID
SwissCovid
NHS COVID-19
Total 2 12 2 12

An OS that endorses the NX bit—a feature of the memory management unit of some CPUs—may tag specific sections of the memory as non-executable, meaning that the CPU will deny to execute any code residing in that region. If the NX bit is not set on the library, an attacker may be able to mount a buffer overflow. That is, frequently, such attacks place code in a program’s data region or stack, and subsequently jump to it. But if all writable addresses are non-executable (through the -z noexecstack compiler flag), such an attack is blocked. As observed from the table, a couple of apps were found to incorporate libraries that allow for executable writable addresses in memory.

PIEs on the other hand are executable binaries which are made from position-independent codes (PICs). The latter are used by shared libraries for loading their code into memory at runtime, without overlapping with other shared libraries that already exist there. Actually, this is a common mechanism to harden Executable and Linkable Format (ELF) binaries. As seen from the table, about half of the apps incorporate shared libraries which were built without enabling the position independent code flag (-f PIC). This could be exploited by an attacker, forcing the app to jump to a specific part of the memory that contains malicious code.

The use of Stack Canaries is a well-known defense against memory corruption attacks; it is a value placed on the stack with the intention to be overwritten by a stack buffer that overflows to the return address. If this protection is withheld, the app is prone to stack buffer overflow attacks, say, those that aim to overwrite certain parts of memory with malicious code. Our results show that only two apps embrace shared libraries which neglect this defence.

Relocation Read-Only (RELRO) is another mechanism to harden ELF binaries by rendering some binary sections read-only. Precisely, RELRO ensures that the global offset table (GOT)—a lookup table used by a dynamically linked ELF binary to dynamically resolve functions that are located in shared libraries—cannot be overwritten. For the interested reader, an example of a RELPO-relevant attack is given in [82]. With reference to Table 8, at least four libraries in roughly half of the apps do not make use of the RELRO defence.

4.6 Outdated software components analysis

For both the desktop and mobile platforms, third-party components, say, libraries, comprise one of the keystones of modern software development. However, as already mentioned in subsection 4.5, the benefit of reusing third-party code may be largely neutralized, if that code is buggy or outdated. This may significantly augment the attack surface of the app and expose end-users to security and privacy risks stemming from those external software components. Indeed, the importance of updatability of such Libraries on the Android platform has been frequently pinpointed in the literature [83, 84]. Put simply, it has been shown that many Android apps do not update their third-party libraries, remaining vulnerable to a range of CVEs.

As already mentioned, to delve into this issue under the perspective of the examined apps, we employed the Ostorlab tool. The outcomes of this type of analysis per app are summarized in Table 9. As observed from the table, approximately the one-third of the apps (8) make use of one at least outdated library. However, as already stated, such a shortcoming is tightly connected to one or more CVEs, meaning that the respective app is susceptible to publicly disclosed security flaws. In the following, we briefly describe such issues per shared library by just enumerating the relevant CVEs. The interested reader may in addition consult the respective CVE page in [85].

Table 9. Outdated third-party software components per app.

App Name SQLite OpenSSL libjpeg
Stopp Corona
Coronalert + +
ViruSafe
Stop COVID-19
CovTracer +
eRouska
Smittestop
Hoia
Koronavikku + +
TousAntiCovid
Corona-Warn-App + +
VirusRadar
COVID Tracker + + +
Immuni
Apturi Covid
Korona Stop LT + +
COVID Alert
CoronaMelder
Smittestopp
STOP COVID—ProteGO Safe
STAYAWAY COVID +
ZostanZdravy
#OstaniZdrav + +
Radar COVID
SwissCovid
NHS COVID-19
Total 6 6 3

Specifically, Table 9 reveals that the same 6 apps utilize an outdated version of the well-known SQLite [86] and OpenSSL [87] libraries, v.3.31.0 and v.1.1.1g, respectively. As it is well-known, the first library, implements a lightweight, full-featured, SQL database engine, while the second provides an open-source implementation of the SSL and TLS protocols. With reference to the SQLite documentation [86], obsolete versions of SQLite may be vulnerable to denial of service (DoS) attacks. Some pertinent CVEs to this case are CVE-2020-13632, CVE-2020-13434, and CVE-2020-13435. Even worse, several of them, say, CVE-2020-11655, CVE-2020-11656, and CVE-2020-13632 are classified as being of high or critical severity. With respect to OpenSSL, along with DoS-related CVEs, we observed 3 others of medium severity, namely CVE-2018-12433, CVE-2018-12438, and CVE-2020-1971. Clearly, these kind of vulnerabilities can be potentially weaponized for breaking the encryption between the app and the server.

Lastly, three apps were found to incorporate an obsolete version (v1.5.3) of the libjpeg [88] library, used to read and write JPEG image files. With reference to CVE-2018-14498 and CVE-2018-20330, this version may be vulnerable to DoS attacks.

4.7 Taint analysis

Static taint analysis, i.e., a form of information flow analysis, has been performed with the aid of the Ostorlab tool. Generally, this type of examination can identify data leakage type of problems in the examined code. This typically refers to a variety of user or other kind of input sanitization hiccups, that may facilitate intent injection, SQL injection, password tracking, or even buffer overflows. To do so, taint analysis uses a script, which tags every private data of interest, known as the source. By following each source throughout the code as a flow, the analysis may reveal every code snippet that potentially has a leakage, the so-called sink. A notable remark here is that taint analysis may yield a considerable number of false positives. Therefore, to reduce the error factor, the results of this subsection have been cross-checked with those of manifest analysis given in subsection 4.4, and we preserved only the intersection of the two sets based on the findings of taint analysis. Overall, an approximately 15% of the taint analysis results were found to be common between the two sets.

For the examined apps, taint analysis only identified issues related to intent leakage. As already mentioned in subsection 4.4, this type of leakage is related to three major components of the Android OS; broadcast receivers, services, and activities. Basically, properly sanitizing these components in the manifest file, means less leaked intents. More precisely, the results of applying taint analysis to each of the available apps are illustrated in Fig 2. The number inside each bar designates the quantity of the issues per app. As observed, potential issues have been identified for less than half, i.e., 10, of the examined apps; seven of them showed a relatively low number of issues, while the rest a considerably larger number.

Fig 2. Issues identified through taint analysis.

Fig 2

5 Dynamic analysis

As already mentioned in section 2, the features collected during this phase pertain to Java classes and network traffic. The instrumentation code fed to Androtomist is given in code Listing 1, where the tracked classes are defined in the objectsToLookFor variable. Precisely, during runtime, the code logs specific Java classes related to network traffic, location, mobile network, and Bluetooth, according to the API documentation, as follows:

  • Network traffic: java.net.URLConnection, java.net.URL, java.net.Socket, including all relevant parameters, that is, URLs, IP addresses, and network protocols.

  • Location: android.location.Location, android.location.LocationManager, and android.location.LocationProvider. An object of the first class represents a geographic location, including latitude, longitude, and timestamp. The second class provides access to the system’s location services, while the location provider abstract class can be implemented to periodically report on the geographical location of the device.

  • Bluetooth: android.bluetooth.BluetoothAdapter, android.bluetooth.BluetoothManager, android.bluetooth.BluetoothDevice, android.bluetooth.BluetoothClass.

  • Mobile network: android.telephony.TelephonyManager. This class is of interest because it provides access to pieces of data regarding the telephony services on the mobile device. Precisely, the methods of this class can be called by an app to learn the available telephony services and states, and obtain certain types of sensitive subscriber information, including the unique subscriber identity, i.e., the International Mobile Subscriber Identity (IMSI).

Listing 1. The instrumentation code exploited to hook Java classes

1 //Objects to hook

2 var objectsToLookFor = [“android.location.Location”,

3 “android.location.LocationManager”,

4 “android.location.LocationProvider”,

5 “java.net.Socket”, “java.net.URLConnection”,

6 “java.net.URL”,

7 “android.telephony.TelephonyManager”,

8 “android.bluetooth.BluetoothAdapter”,

9 “android.bluetooth.BluetoothManager”,

10 “android.bluetooth.BluetoothDevice”,

11 “android.bluetooth.BluetoothClass”,

12 “android.hardware.Camera”,

13 “android.hardware.camera2.CameraManager”,

14 “dalvik.system.DexClassLoader”];

15

16 for (var i in objectsToLookFor) {

17  Java.perform(function () {

18   Java.choose(objectsToLookFor[i], {

19     “onMatch”: function (instance) {

20      console.log(“\nProcess_has_Instantiated_instance_of:” + objectsToLookFor[i]);

21     console.log(“Details:” + instance.toString());

22   }, 

23   “onComplete”: function () {

24   }

25  });

26 });

27 }

The results produced by dynamic analysis are recapitulated in Table 10. The four rightmost columns of the table designate if the examined app has (a) produced network traffic, (b) instantiated the Java class android.location.LocationManager, (c) instantiated the Java class android.telephony.TelephonyManager, and (d) instantiated either or both the Java classes android.bluetooth.BluetoothAdapter and android.bluetooth.BluetoothManager, respectively. As seen in the table, two apps asked for phone number authentication through a verification code received via SMS to properly work. So, given that the Nvidia Shield K tablet device is SIM-less, these apps were excluded from the current analysis. All in all, the following key takeaways emerge.

Table 10. Dynamic analysis results.

App Net. traffic Location Telephony Bluetooth
Stopp Corona + + +
Coronalert + + + +
ViruSafe* N/A N/A N/A N/A
Stop COVID-19 + + + +
CovTracer + + + +
eRouska + + + +
Smittestop + +
Hoia + + +
KoronaVilkku + + +
TousAntiCovid + + +
Corona-Warn-App + + + +
VirusRadar* N/A N/A N/A N/A
COVID Tracker + + + +
Immuni + + + +
Apturi Covid + + + +
Korona Stop LT + + + +
COVID Alert + + +
CoronaMelder + + + +
Smittestopp + +
STOP COVID—ProteGO Safe + + + +
STAYAWAY COVID + + +
ZostanZdravy + +
#OstaniZdrav + + + +
Radar COVID + + +
SwissCovid + + +
NHS COVID-19 + + +
Total 21 13 24 23

*Excluded from analysis.

  • All the examined apps but three produced network traffic, meaning they visited specific URLs as detailed in subsection 3.2.

  • Thirteen apps employed the android.location.LocationManager class, which provides access to the system’s location services and allows apps to obtain periodic updates of the device’s geographical location. Actually, this result confirms the outcomes of subsection 3.2 with reference to the android/location/LocationManager API call.

  • All the examined apps used the android.telephony.TelephonyManager. This outcome comes in addition to that of subsection 3.2 in relation to the android/telephony/TelephonyManager API call.

  • All the examined apps but one instantiated either or both the android.bluetooth.BluetoothAdapter and android.bluetooth.BluetoothManager Java classes. The first class lets the app conduct basic Bluetooth tasks, including starting up device discovery, while the latter offers a high-level manager employed to get an instance of an BluetoothAdapter and to perform overall Bluetooth management.

Besides the above-mentioned general remarks, the following observations were done after comparing the results of Table 10 with those from Tables 2 and 5:

  • As shown in Table 5, according to the findings of static analysis, all apps included API calls related to location, while in dynamic analysis only 13 of them did instantiate relevant classes. As previously mentioned, according to the API, all location methods require either or both the ACCESS_COARSE_LOCATION and ACCESS_FINE_LOCATION permissions. As a result, ViruSafe, TousAntiCovid, VirusRadar, and ZostanZdravy, namely, all the not GAEN-based apps, do declare the necessary permissions, and thus are indeed able to get the device’s location data.

  • With reference to the results of subsection 3.2, the ZostanZdravy app did not instantiate any Bluetooth classes.

  • As already mentioned, all apps instantiated the android.telephony.TelephonyManager class, which pertains to the cellular network. Nevertheless, according to static analysis results, only 3 apps included API calls related to the same category.

6 Conclusions

The merit of mobile digital contact tracing apps in swiftly and accurately identifying and alerting individuals at risk in large-scale is rather unquestionable. Nevertheless, along with other considerations, for such a privacy-sensitive app to gain widespread adoption, certain security and data protection requirements need to be met. Actually, this reluctance can be perceived from the information contained in Google Play Store, where it seems that (i) based on the app downloads, the penetration of most apps in the population is still not very high, and (ii) the rather fair average evaluation score they receive can be translated as an indication of undesired, unneeded, or sometimes buggy or problematic functionality.

The empirical results reported in this work can serve a triad of goals. The first, targets app designers and developers, and relates to strengthening the sound design of upcoming versions of these apps, as well as future contact tracing apps, in terms of security and end-user privacy. Also, given that the findings of this endeavor reflect the general proclivity in this ecosystem, it can be straightforwardly used as a basis for further research, focusing on promoting best practices that facilitate the minimization of the attack surface, obstruct data leakage, and nurture security and privacy by design overall. Especially for privacy, the root issue being at stake here is the so-called principle of minimal privilege, mandating that a user, process, or program, must be by default enabled to only access the data and resources that are necessary for fulfilling its mission. Last but not least, our findings can aid policy makers in shaping a better understanding of this ecosystem. That is, in this “black swan” situation, policy makers must be provided with sufficient and suitable data and knowledge to formulate strategies for promoting mass digital tracing app acceptance, thus contributing to the greater good. This would augment the chances of favorable app exploitation. Under this prism, policy makers need to not only be aware of which app characteristics matter most for, say, the reluctant or opposed citizens, but also be informed of the current situation and if and to what degree it coincides with the achievement of objectives and priorities in the mid- or long-run.

In this context, this work attempts to answer two rudimentary, but decisive questions: Do the currently deployed digital contact apps (a) reduce their functionality to the bare minimum?, and (b) remain free of known misconfigurations, weaknesses, and vulnerabilities? If so, user privacy is well-preserved, data protection is ensured, and the app’s attack surface is decreased. To answer both these matters in a tangible way, we meticulously analyzed all official mobile contact tracing apps currently deployed by European countries.

The results stemming for static analysis lead to a number of conclusions: (a) All GAEN-based apps respect the minimum set of required permissions, but exceptions do apply; two of them demand in addition access to the camera, say, for enabling the user to scan a QR code, (b) a limited number of GAEN-incompatible apps request at least a couple of extra sensitive additional permissions, (c) at least ≈62% of the apps were found to be potentially exposed to 5 out of the total 9 high value CWEs. This percentage increases to about 92% and 96% for CWE-532 and CWE-330, respectively, (d) roughly 88% and 46% of the apps exhibited more than one issue in their manifest file and shared libraries, respectively, (e) outdated software component exploration and taint analysis revealed that approximately one-quarter and one-third of the apps, respectively, have at least one issue, (f) on the plus side, almost 65% of the apps were found to be free of any third-party tracker, and only 2 apps were found to incorporate at least one third-party tracker.

On the other hand, dynamic analysis also yielded significant outcomes, allowing us to verify the results stemming from static analysis. Overall, it was perceived that in most cases, the outcomes coincide, but exceptions do exist. For instance, despite that all apps contain at least one location-related API call, about half (13) of them actually instantiate the relevant classes. Interestingly, the same observation stands true in the opposite direction for telephony-related API calls. Namely, with reference to static analysis, only 3 apps were found to include such calls, while dynamic analysis showed that all apps instantiated the relevant class. In any case, dynamic analysis is further to be addressed in a future work by hooking additional operations, i.e., refining the instrumentation code, and via the use of control flow graphs.

Finally yet importantly, an app may include code (logged in static or triggered during dynamic analysis) for which it has not asked permission in the manifest file. Typically, in such a case, the app cannot use these pieces of code, but this situation does not apply to rooted phones. That is, any permission listed in the manifest file provides access to some of the data and functions offered by the Android OS, but root privileges grant access to data and functions that were never intended to be shared or used. Not to mention, of course, the fact that an app with root access can automatically configure all permissions as will. In any case, deliberately rooting or jailbreaking a smartphone, drastically alters the security posture of the device, entailing the circumvention of the native security restrictions put in place by the operating system. This may expose data and apps to numerous threats, and thus this practice is exclusively under the end-user’s own responsibility.

Data Availability

All the examined software (mobile applications) by this article are publicly available at Google Play Store. All other relevant data are within the manuscript.

Funding Statement

The authors received no specific funding for this work.

References

Associated Data

This section collects any data citations, data availability statements, or supplementary materials included in this article.

Data Availability Statement

All the examined software (mobile applications) by this article are publicly available at Google Play Store. All other relevant data are within the manuscript.


Articles from PLoS ONE are provided here courtesy of PLOS

RESOURCES