F-Droid


F-Droid is a community-maintained software repository for Android, similar to the Google Play store. The main repository, hosted by the project, contains only free and open source apps. Applications can be browsed, downloaded and installed from the F-Droid website or client app without the need to register for an account. "Anti-Features" such as advertising, user tracking, or dependence on nonfree software are flagged in app descriptions.
The website also offers the source code of applications it hosts, as well as the software running the F-Droid server, allowing anyone to set up their own app repository.

History

F-Droid was founded by Ciaran Gultnieks in 2010. The client was forked from Aptoide's source code. The project is now run by the English nonprofit F-Droid Limited.
Replicant, a fully free software Android operating system, uses F-Droid as its default and recommended app store. The Guardian Project, a suite of free and secure Android applications, started running their own F-Droid repository in early 2012. In 2012, Free Software Foundation Europe featured F-Droid in their Free Your Android! campaign to raise awareness of the privacy and security risks of proprietary software. F-Droid was chosen as part of the GNU Project's GNU a Day initiative during their 30th anniversary to encourage more use of free software.
In March 2016 F-Droid partnered with The Guardian Project and CopperheadOS with the goal of creating "a solution that can be verifiably trusted from the operating system, through the network and network services, all the way up to the app stores and apps themselves".

Scope of project

The F-Droid repository contains a growing number of nearly 3,000 apps, compared to over 1.43 million on the Google Play Store. The project incorporates several software sub-projects:
F-Droid builds apps from publicly available and freely licensed source code. The project is run entirely by volunteers and has no formal app review process. New apps are contributed by user submissions or the developers themselves. The only requirement is that they be free of proprietary software.

Client application

To install the F-Droid client, the user has to allow installation from "Unknown sources" in Android settings and retrieve the APK from the official site. Installation is not available through the Google Play store due to the non-compete clause of the Google Play Developer Distribution Agreement.
The client was designed to be resilient against surveillance, censorship, and unreliable Internet connections. To promote anonymity, it supports HTTP proxies and repositories hosted on Tor onion services. Client devices can function as impromptu "app stores", distributing downloaded apps to other devices over local Wi-Fi, Bluetooth, and Android Beam. The F-Droid client app will automatically offer updates for installed F-Droid apps. When the F-Droid Privileged Extension is installed, updates can also be conducted by the app itself in the background. The extension can be installed via rooting, or by flashing a zip file on the device.

Key management

The Android operating system checks that updates are signed with the same key, preventing others from distributing updates that are signed by a different key. Originally, the Google Play store required applications to be signed by the developer of the application, while F-Droid only allowed its own signing keys. So apps previously installed from another source have to be reinstalled to receive updates.
As of 2017, Google Play encourages developers to let Google Play manage the signing keys, offering a similar service to what F-Droid has offered since 2011, and F-Droid now lets developers use their own keys via the reproducible build process.