Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/akeru-inc/xcnotary
the missing macOS app notarization helper, built with Rust
https://github.com/akeru-inc/xcnotary
catalina macos notarization objc objectivec osx rust swift
Last synced: 3 months ago
JSON representation
the missing macOS app notarization helper, built with Rust
- Host: GitHub
- URL: https://github.com/akeru-inc/xcnotary
- Owner: akeru-inc
- License: mit
- Archived: true
- Created: 2020-03-27T01:09:11.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2022-07-10T13:26:23.000Z (over 2 years ago)
- Last Synced: 2024-07-31T17:23:39.494Z (5 months ago)
- Topics: catalina, macos, notarization, objc, objectivec, osx, rust, swift
- Language: Rust
- Homepage:
- Size: 830 KB
- Stars: 648
- Watchers: 12
- Forks: 24
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# `xcnotary` is no longer needed!
Use `xcrun notarytool --wait` as described in Apple's docs: [Customizing the notarization workflow](https://developer.apple.com/documentation/security/notarizing_macos_software_before_distribution/customizing_the_notarization_workflow#3087734)
With a concise example given here: https://github.com/akeru-inc/xcnotary/issues/22#issuecomment-1179170957
---
![logo](/docs/images/logo.png)
### ~~the missing macOS app notarization helper, built with Rust~~
# About
[Notarizing a macOS app](https://developer.apple.com/documentation/xcode/notarizing_macos_software_before_distribution) involves a series of manual steps, including zipping a bundle, uploading it to to Apple, and polling the notarization service.
`xcnotary` automates these steps for you. It:
- Attempts to fail fast if necessary, performing several checks on your target before uploading it to Apple.
- Zips the input if it is an .app bundle.
- Submits the input to the notarization service, and polls until completion. This step typically takes a few minutes.
- In case of success, attaches the notarization ticket to the target, enabling the app to pass Gatekeeper on first run even without an Internet connection.
- In case of failure, fetches the error log from Apple and outputs it to `stderr`.
- Return a zero/non-zero code for easy CI integration.![Notarization](/docs/images/notarize.png)
# Installation
### Homebrew
```sh
# Install
brew install akeru-inc/tap/xcnotary# Upgrade
brew update
brew upgrade akeru-inc/tap/xcnotary
```# Usage
To perform various code signing checks on the input without submitting:
```sh
xcnotary precheck
```To perform code signing checks, submit to the notarization service, and block waiting for response:
```sh
xcnotary notarize \
--developer-account \
--developer-password-keychain-item \
[--provider ]
[--no-precheck]
```Supported inputs:
- ✅ .app bundles
- ✅ .dmg disk images
- ✅ .pkg installer packages### Specifying the password keychain item
This tool does not handle your Apple Developer password. Instead, Xcode's helper `altool` reads an app-specific Apple Developer ID password directly from the keychain. See [the documentation](https://developer.apple.com/documentation/xcode/notarizing_macos_software_before_distribution/customizing_the_notarization_workflow#3087734) for `xcrun altool --store-password-in-keychain-item` to set up a suitable keychain item.
### Specifying the developer team
The optional `--provider` argument should be specified if the developer account is associated with more than one team. This value can be obtained by running the following command and noting the "ProviderShortname" displayed.
```sh
xcrun altool --list-providers -u "$DEVELOPER_ACCOUNT_USERNAME" -p "@keychain:$PASSWORD_KEYCHAIN_ITEM"
```### Required network access
- Xcode's `altool` will connect to several Apple hosts as outlined in [the documentation](https://developer.apple.com/documentation/xcode/notarizing_macos_software_before_distribution/customizing_the_notarization_workflow).
- When notarization fails, `xcnotary` will connect to `https://osxapps-ssl.itunes.apple.com/` on port 443 to retrieve the failure log.
### Service response
Apple [documentation](https://developer.apple.com/documentation/xcode/notarizing_macos_software_before_distribution/customizing_the_notarization_workflow) advises: "Always check the log file, even if notarization succeeds, because it might contain warnings that you can fix prior to your next submission."
`xcnotary` will fetch and display the notarization service response upon completion.
# Bundle pre-checks
`xcnotary` attempts to check the input for some [common notarization issues](https://developer.apple.com/documentation/xcode/notarizing_macos_software_before_distribution/resolving_common_notarization_issues) before uploading it to Apple. While not foolproof, these checks may potentially save you minutes waiting for a response only to fail due to an incorrect code signing flag.
![Bundle pre-check](/docs/images/precheck.png)
When the input is an app bundle, the following checks will be performed:
- ✅ Bundle being signed with a Developer ID certificate and not containing unsigned items.
- ✅ Bundle being signed with a secure timestamp.
- ✅ Bundle *not* having the get-task-allow entitlement.
- ✅ Bundle having hardened runtime enabled.When the input is a *.dmg* or a *.pkg*, only the Developer ID signing check is performed, i.e. the only check that can be performed at the moment without extracting the contents. In your workflow, you may want to run `xcnotary precheck` on your bundle target before packaging it.
In rare cases, it may be helpful to troubleshoot code signing issues directly using the notarization service response. To do so, specify `--no-precheck` when invoking `xcnotary notarize`.
# Building for notarization
The following examples set various necessary build flags, such as code signing with a "secure timestamp."
### Bundles
```sh
xcodebuild \
-target \
-scheme \
-configuration Release \
-derivedDataPath .xcodebuild \
"CODE_SIGN_IDENTITY=Developer ID Application: " \
"OTHER_CODE_SIGN_FLAGS=--timestamp --options=runtime" \
CODE_SIGN_INJECT_BASE_ENTITLEMENTS=NO \
CODE_SIGN_STYLE=Manual
````CODE_SIGN_IDENTITY` should match the corresponding Keychain certificate.
Note that `--options=runtime` will have the effect of opting in your binary to the hardened runtime environment. You most likely want to first manually enable the "Hardened Runtime" capability in Xcode's target settings > "Signing and Capabilities" and make sure your application functions as expected. There, you may also add any entitlements to relax the runtime restrictions.
### Packages
```sh
pkgbuild \
--component
--sign "Developer ID Installer: " \
--timestamp \
```### Disk images
Codesign after creating the DMG:
```sh
codesign -s "Developer ID Application: "
```# Additional Information
- [Change Log](CHANGELOG.md)
- Feature requests/comments/questions? Write: [email protected]