Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

App Signing on macOS; aka "cannot be opened because the developer cannot be verified" #286

Open
allejo opened this issue Jul 13, 2021 · 3 comments
Milestone

Comments

@allejo
Copy link
Member

allejo commented Jul 13, 2021

Looks like we really need to look into signing our distributable for macOS now. Right-clicking and hitting open no longer bypasses GateKeeper on the latest macOS 11 and results in this message:

image

The only remaining ways to bypass this is to go to System Preferences > Security & Privacy and allow the app to open,

image

Or go into Terminal and run this command.

xattr -d com.apple.quarantine BZFlag-2.4.22.app
@allejo allejo pinned this issue Jul 13, 2021
@macsforme
Copy link
Member

I am unable to reproduce this on my machine with Big Sur 11.4. After downloading, activating the contextual menu, and clicking Open, I get a dialog allowing me to open the application. From the discussion on IRC, it sounds like reproducing this issue is hit-and-miss over several different machines.

In any case, I do agree that we need to move toward signing and notarizing our builds.

@timriker timriker unpinned this issue Feb 24, 2023
@timriker timriker pinned this issue Feb 24, 2023
@macsforme macsforme unpinned this issue Apr 22, 2023
@macsforme macsforme pinned this issue Apr 22, 2023
@macsforme
Copy link
Member

I was asked to summarize the current obstacles to signing and notarizing our macOS builds:

Back when I had a paid Apple developer account, I was signing our builds for several years. It was a fairly easy post-build step on the command line (not the only available method, but the preferable one at the time):

codesign --sign "Developer ID Application: Josh Bodine (XXXXXXXXXX)" --deep --force BZFlag.app

Starting around macOS 10.15 Catalina, Gatekeeper also requires applications to be notarized to run by default. A year or two back, ashvala and I were playing around with notarization using his paid Apple developer account (I no longer have one at the moment). It appeared that we would need to semi-substantially change our build system to accommodate notarization. This is from memory, but the general process seemed to be:

  1. We need to create a manifest file of some kind, which is possibly similar in nature to our Info.plist. I remember looking at the format of this file (what you would put into it) and having trouble comprehending it, while also thinking that none of it really seemed pertinent to our application.
  2. Once the manifest is incorporated into the build system, you would build the application within Xcode and then create an "archive" of the application, which I believe was some kind of zip archive (possibly with other info included).
  3. We would submit the archive file to Apple's notarization service using a command-line tool, and after a short period of time, it would come back to us in a notarized state.

Here are links to some information I reviewed back when I last looked at this issue:

https://cocoacasts.com/what-are-app-ids-and-bundle-identifiers/ (these identifiers apparently become more significant once you start notarizing, possibly because of having to be unique for each version IIRC)
https://medium.com/@marksiu/how-to-build-ios-project-with-command-82f20fda5ec5 (describes creating an Xcode application archive on the command line, which would possibly help us keep signing/notarization as a post-build process)
https://developer.apple.com/documentation/security/notarizing_macos_software_before_distribution/customizing_the_notarization_workflow#3087734
https://abhimuralidharan.medium.com/what-is-a-provisioning-profile-in-ios-77987a7c54c2 (general info about application code signing)
https://stackoverflow.com/questions/3465792/whats-the-difference-between-bundle-display-name-and-bundle-name-in-cocoa-a (an important distinction, which I believe we recently fixed)

@blast007
Copy link
Member

https://developer.apple.com/news/?id=saqachfa

In macOS Sequoia, users will no longer be able to Control-click to override Gatekeeper when opening software that isn’t signed correctly or notarized. They’ll need to visit System Settings > Privacy & Security to review security information for software before allowing it to run.

If you distribute software outside of the Mac App Store, we recommend that you submit your software to be notarized. The Apple notary service automatically scans your Developer ID-signed software and performs security checks. When your software is ready for distribution, it’s assigned a ticket to let Gatekeeper know it’s been notarized so customers can run it with confidence.

@blast007 blast007 added this to the 2.4.28 milestone Dec 8, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants