Revoke App Permissions on Firefox OS

On Firefox OS (FxOS), every app has its own set of permissions. The operating system makes sure that an app may only do things that are requested in the app manifest. Some of these permissions are always set to Ask. Sometimes just because the web platform is built this way. A common example is the geolocation permission:

geolocation prompt

There's also the Alarms API, for example. It allows applications to get opened at a specific time. There is nothing inherently bad with precise alarm functions that honor timezones (or not). But it is hard to know what the App will do with it. This gets exceedingly difficult to explain to users, especially when it comes to technical terms and features like the tcp-socket permission.

The security model of Firefox OS is based on contextual prompts. So for APIs that are understandable and human meaningful like geolocation, using the camera or recording audio the OS will prompt the user. You can save & remember these choices and later revisit them in the Settings app under "App Permissions". You may set them to Allow, Prompt, or Deny.

For simplicity's sake, all permissions default to something that the inventor's of these APIs deemed safe. For tcp-sockets and alarms this is Allow. For geolocation it's Prompt. If you want to know more about the default permission settings, the App Manager can show you how the table looks like for your phone. Here's an excerpt generated on my Flame device on FxOS 2.0:

permissions table

But what if you are tech savvy? What if you do want to revoke or be asked for permissions that are a bit hard to explain?

To bridge this gap and empower tech savvy & paranoid privacy enthusiasts, I have created a developer settings that shows a verbose app permissions list. It enhances the normal App Permissions panel of the Settings app.

Starting with Firefox 2.1, you may activate the developer settings and tick the checkbox near "Verbose App Permissions". The typical list in the Settings app will then show you all the permissions an app has and allows you to set them to Allow, Prompt or Deny. This feature, however, only targets the Privileged apps. These are apps that come through the Marketplace. For now, we can not revoke permissions for the built-in apps (the permission set() call throws).

Beware that you may break the app that you wish to contain - just because it is not designed to cope with failure. Some APIs are designed with an asynchronous request/response pattern. These will likely work fine and not throw an unrecoverable exception. But it still means that the developer has had to set an error handler, or the app might be indefinitely stuck in a waiting state.


If you find a mistake in this article, you can submit a pull request on GitHub.

Other posts

  1. What is mixed content? (Sat 15 June 2024)
  2. How I got a new domain name (Sat 15 June 2024)
  3. How Firefox gives special permissions to some domains (Fri 02 February 2024)
  4. Examine Firefox Inter-Process Communication using JavaScript in 2023 (Mon 17 April 2023)
  5. Origins, Sites and other Terminologies (Sat 14 January 2023)
  6. Finding and Fixing DOM-based XSS with Static Analysis (Mon 02 January 2023)
  7. DOM Clobbering (Mon 12 December 2022)
  8. Neue Methoden für Cross-Origin Isolation: Resource, Opener & Embedding Policies mit COOP, COEP, CORP und CORB (Thu 10 November 2022)
  9. Reference Sheet for Principals in Mozilla Code (Mon 03 August 2020)
  10. Hardening Firefox against Injection Attacks – The Technical Details (Tue 07 July 2020)
  11. Understanding Web Security Checks in Firefox (Part 1) (Wed 10 June 2020)
  12. Help Test Firefox's built-in HTML Sanitizer to protect against UXSS bugs (Fri 06 December 2019)
  13. Remote Code Execution in Firefox beyond memory corruptions (Sun 29 September 2019)
  14. XSS in The Digital #ClimateStrike Widget (Mon 23 September 2019)
  15. Chrome switching the XSSAuditor to filter mode re-enables old attack (Fri 10 May 2019)
  16. Challenge Write-up: Subresource Integrity in Service Workers (Sat 25 March 2017)
  17. Finding the SqueezeBox Radio Default SSH Password (Fri 02 September 2016)
  18. New CSP directive to make Subresource Integrity mandatory (`require-sri-for`) (Thu 02 June 2016)
  19. Firefox OS apps and beyond (Tue 12 April 2016)
  20. Teacher's Pinboard Write-up (Wed 02 December 2015)
  21. A CDN that can not XSS you: Using Subresource Integrity (Sun 19 July 2015)
  22. The Twitter Gazebo (Sat 18 July 2015)
  23. German Firefox 1.0 ad (OCR) (Sun 09 November 2014)
  24. My thoughts on Tor appliances (Tue 14 October 2014)
  25. Subresource Integrity (Sun 05 October 2014)
  26. Revoke App Permissions on Firefox OS (Sun 24 August 2014)
  27. (Self) XSS at Mozilla's internal Phonebook (Fri 23 May 2014)
  28. Tales of Python's Encoding (Mon 17 March 2014)
  29. On the X-Frame-Options Security Header (Thu 12 December 2013)
  30. html2dom (Tue 24 September 2013)
  31. Security Review: HTML sanitizer in Thunderbird (Mon 22 July 2013)
  32. Week 29 2013 (Sun 21 July 2013)
  33. The First Post (Tue 16 July 2013)
π