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/libre 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.[2]

F-Droid
Screenshot of F-Droid 1.2 on Android showing the latest apps
Developer(s)Ciaran Gultnieks, F-Droid Limited
Initial release29 September 2010 (2010-09-29)
Stable release1.8 (29 April 2020 (2020-04-29)[1]) [±]
Repository
Written inPython (server tools), Jekyll (software) (site), Java (client)
Operating systemAndroid system (client), Linux, OSX, Windows 10, FreeBSD (server)
TypeDigital distribution of free software, Software repository
LicenseGNU GPLv3+
Websitef-droid.org

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.[3][4][5]

History

Development of F-Droid data over time[6]

F-Droid was founded by Ciaran Gultnieks in 2010. The client was forked from Aptoide's source code.[7][8] The project is now run by the English nonprofit F-Droid Limited.[8]

Replicant, a fully free software Android operating system, uses F-Droid as its default and recommended app store.[9][10] The Guardian Project, a suite of free and secure Android applications, started running their own F-Droid repository in early 2012.[11] 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.[12][13] 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.[14]

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".[15]

Scope of project

The F-Droid repository contains a growing number of nearly 3,000 apps[16], compared to over 1.43 million on the Google Play Store. The project incorporates several software sub-projects:

  • Client software for searching, downloading, verifying, and updating Android apps from an F-Droid repository
  • fdroidserver – tool for managing existing and creating new repositories
  • Jekyll-based website generator for a repository

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.[17] New apps are contributed by user submissions or the developers themselves. The only requirement is that they be free of proprietary software.[18]

Client application

"Get it on F-Droid" badge

To install the F-Droid client, the user has to allow installation from "Unknown sources" in Android settings[19] and retrieve the APK (installable file) 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.[20]

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.[21][22] 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.[23] The extension can be installed via rooting, or by flashing a zip file on the device.[24]

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.[25][26] 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.[27]

As of 2017, Google Play encourages developers to let Google Play manage the signing keys,[28] 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.[29]

See also

References

  1. "F-Droid on F-Droid repository". F-Droid client code repository. F-Droid Limited. Retrieved 25 July 2019.
  2. "Client 0.54 released". F-droid.org. 5 November 2013. Archived from the original on 26 April 2015.
  3. Hildenbrand, Jerry (27 November 2012). "F-Droid is the FOSS application store for your Android phone". Android Central. Archived from the original on 16 June 2018.
  4. Nardi, Tom (27 August 2012). "F-Droid: The Android Market That Respects Your Rights". The Powerbase. Archived from the original on 3 December 2013.
  5. "F-Droid Server Manual".
  6. "Commits by year and month of F-Droid data reported by gitstats". 2017. Retrieved 19 July 2017.
  7. "F-Droid initial source code". F-Droid. 19 October 2010. Archived from the original on 10 December 2014. Retrieved 10 December 2014.
  8. "F Droid About". Retrieved 28 January 2014.
  9. "FDroid: a free software alternative to Google Market". Replicant Project. 26 November 2010. Retrieved 17 January 2015.
  10. "FDroid". Replicant Wiki.
  11. "Our New F-Droid App Repository". The Guardian Project. 15 March 2012. Archived from the original on 23 March 2017.
  12. Walker-Morgan, Dj (28 February 2012). "FSFE launches "Free Your Android!" campaign". H-online. Retrieved 27 July 2014.
  13. "Liberate Your Device!". Free Software Foundation Europe. Retrieved 27 July 2014.
  14. "GNU-a-Day". GNU Project, Free Software Foundation. Retrieved 23 July 2014. Day 9: Have an Android phone? Install F-Droid, a repository with hundreds of free software apps.
  15. "Copperhead, Guardian Project and F-Droid Partner to Build Open, Verifiably Secure Mobile Ecosystem". The Guardian Project. 28 March 2016.
  16. F-Droid Main Repository. IzzySoft and F-Droid. Retrieved March 12, 2020.
  17. "Contribute". F-Droid. Retrieved 29 March 2015.
  18. "Inclusion Policy". F-Droid. 4 April 2014. Retrieved 29 March 2015.
  19. "Android Open Distribution". 31 October 2012. Retrieved 31 October 2012.
  20. "Google Play Developer Distribution Agreement". 31 October 2012. Retrieved 31 October 2012.
  21. "Client 0.76 Released". F-Droid. 14 October 2014. Archived from the original on 2 February 2017. Retrieved 28 March 2015.
  22. Brandom, Russell (10 June 2014). "Your survival guide for an internet blackout". The Verge. Retrieved 2 August 2014.
  23. "F-Droid Privileged Extension". F-Droid. Retrieved 19 June 2018.
  24. "org.fdroid.fdroid.privileged.ota_2070". F-Droid. Retrieved 19 June 2018.
  25. Marlinspike, Moxie (12 February 2013). "moxie0 commented Feb 12, 2013" via GitHub.
  26. "Signing Your Applications". Android Developers. Google.
  27. "Release Channels and Signing Keys". F-Droid. 12 August 2014. Retrieved 29 March 2015.
  28. Glick, Kobi (6 September 2017). "Enroll for app signing in the Google Play Console & secure your app using Google's robust security infrastructure". Android Developers Blog. Google.
  29. "Reproducible Builds". F-Droid.

Further reading

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.