Gatekeeper (macOS) explained

Gatekeeper
Developer:Apple Inc.
Operating System:macOS

Gatekeeper is a security feature of the macOS operating system by Apple.[1] [2] It enforces code signing and verifies downloaded applications before allowing them to run, thereby reducing the likelihood of inadvertently executing malware. Gatekeeper builds upon File Quarantine, which was introduced in Mac OS X Leopard (10.5) and expanded in Mac OS X Snow Leopard (10.6).[3] [4] The feature originated in version 10.7.3 of Mac OS X Lion as the command-line utility .[5] [6] A graphical user interface was originally added in OS X Mountain Lion (10.8) but was backported to Lion with the 10.7.5 update.[7]

Functions

Configuration

In the security & privacy panel of System Preferences, the user has three options, allowing apps downloaded from:

The command-line utility provides granular controls, such as custom rules and individual or blanket permissions, as well as an option to turn Gatekeeper off.

Quarantine

Upon download of an application, a particular extended file attribute ("quarantine flag") can be added to the downloaded file.[8] This attribute is added by the application that downloads the file, such as a web browser or email client, but is not usually added by common BitTorrent client software, such as Transmission, and application developers will need to implement this feature into their applications and is not implemented by the system. The system can also force this behavior upon individual applications using a signature-based system named Xprotect.[9]

Execution

When the user attempts to open an application with such an attribute, the system will postpone the execution and verify whether it:

Since Snow Leopard, the system keeps two blacklists to identify known malware or insecure software. The blacklists are updated periodically. If the application is blacklisted, then File Quarantine will refuse to open it and recommend to the user that they drag it to Trash.[10]

Gatekeeper will refuse to open the application if the code-signing requirements are not met. Apple can revoke the developer's certificate with which the application was signed and prevent further distribution.

Once an application has passed File Quarantine or Gatekeeper, it will be allowed to run normally and will not be verified again.

Override

To override Gatekeeper, the user (acting as an administrator) either has to switch to a more lenient policy from the security & privacy panel of System Preferences or authorize a manual override for a particular application, either by opening the application from the context menu or by adding it with .

Path randomization

Developers can sign disk images that can be verified as a unit by the system. In macOS Sierra, this allows developers to guarantee the integrity of all bundled files and prevent attackers from infecting and subsequently redistributing them. In addition, "path randomization" executes application bundles from a random, hidden path and prevents them from accessing external files relative to their location. This feature is turned off if the application bundle originated from a signed installer package or disk image or if the user manually moved the application without any other files to another directory.

Implications

The effectiveness and rationale of Gatekeeper in combating malware have been acknowledged, but been met with reservations. Security researcher Chris Miller noted that Gatekeeper will verify the developer certificate and consult the known-malware list only when the application is first opened. Malware that already passed Gatekeeper will not be stopped.[11] In addition, Gatekeeper will only verify applications that have the quarantine flag. As this flag is added by other applications and not by the system, any neglect or failure to do so does not trigger Gatekeeper. According to security blogger Thomas Reed, BitTorrent clients are frequent offenders of this. The flag is also not added if the application came from a different source, like network shares and USB flash drives. Questions have also been raised about the registration process to acquire a developer certificate and the prospect of certificate theft.[12]

In September 2015, security researcher Patrick Wardle wrote about another shortcoming that concerns applications that are distributed with external files, such as libraries or even HTML files that can contain JavaScript. An attacker can manipulate those files and through them exploit a vulnerability in the signed application. The application and its external files can then be redistributed, while leaving the original signature of the application bundle itself intact. As Gatekeeper does not verify such individual files, the security can be compromised.[13] With path randomization and signed disk images, Apple provided mechanisms to mitigate this issue in macOS Sierra.

In 2021, a vulnerability was discovered where putting [[Shebang (Unix)|#!]] on the first line (without the path of the interpreter) of a file bypassed Gatekeeper.[14]

In 2022, a Microsoft researcher shared a vulnerability that abuses the AppleDouble format to set an arbitrary access-control list to bypass Gatekeeper.[15]

See also

Notes and References

  1. Web site: OS X: About Gatekeeper. February 13, 2015. June 18, 2015. Apple.
  2. News: Surprise! OS X Mountain Lion Roars Into Existence (For Developers Today, Everyone This Summer). Siegler. MG. February 16, 2012. TechCrunch. AOL Inc.. March 3, 2012.
  3. Web site: OS X 10.8 Mountain Lion: the Ars Technica review. Siracusa. John. July 25, 2012. Ars Technica. 14–15. https://web.archive.org/web/20160314044507/http://arstechnica.com/apple/2012/07/os-x-10-8/14/. March 14, 2016. live. June 17, 2016.
  4. Web site: Mac Malware Guide : How does Mac OS X protect me?. Reed. Thomas. April 25, 2014. The Safe Mac. October 6, 2016.
  5. Web site: How to test OS X Mountain Lion's Gatekeeper in Lion. Johannes. Ullrich. February 22, 2012. July 27, 2012. Internet Storm Center.
  6. Web site: spctl(8). Mac Developer Library. Apple. July 27, 2012.
  7. Web site: About the OS X Lion v10.7.5 Update. June 18, 2015. February 13, 2015. Apple. September 22, 2012. https://web.archive.org/web/20120922075451/http://support.apple.com/kb/HT5313. bot: unknown.
  8. Web site: Bypassing Apple's Gatekeeper. Reed. Thomas. October 6, 2015. Malwarebytes Labs. June 17, 2016.
  9. Web site: Inside Snow Leopard's hidden malware protection. Moren. Dan. August 26, 2009. Macworld. September 30, 2016.
  10. Web site: About the 'Are you sure you want to open it?' alert (File Quarantine / Known Malware Detection) in OS X. March 22, 2016. Apple Support. https://web.archive.org/web/20160617155624/https://support.apple.com/en-us/HT201940. June 17, 2016. live. September 30, 2016.
  11. Web site: Mac developers: Gatekeeper is a concern, but still gives power users control. February 17, 2012. June 18, 2015. Ars Technica. Foresman. Chris.
  12. News: OS X Mountain Lion Gatekeeper: Can it Really Keep Malware Out?. Chatterjee. Surojit. February 21, 2012. International Business Times. March 3, 2012.
  13. Web site: Drop-dead simple exploit completely bypasses Mac's malware Gatekeeper. Goodin. Dan. Ars Technica. September 30, 2015. https://web.archive.org/web/20160320093306/http://arstechnica.com/security/2015/09/drop-dead-simple-exploit-completely-bypasses-macs-malware-gatekeeper/. March 20, 2016. live. June 17, 2016.
  14. Web site: Gatlan . Sergiu . December 23, 2021 . Apple fixes macOS security flaw behind Gatekeeper bypass . 2022-05-06 . . en-us.
  15. Web site: Gatlan . Sergiu . December 19, 2022 . Microsoft: Achilles macOS bug lets hackers bypass Gatekeeper. 2022-12-19 . . en-us.