Any macOS Target
The top-level mac key contains set of options instructing electron-builder on how it should build macOS targets. These options applicable for any macOS target.
MacConfiguration
undefined
-
category
String | “undefined” - The application category type, as shown in the Finder via View -> Arrange by Application Category when viewing the Applications directory.For example,
"category": "public.app-category.developer-tools"
will set the application category to Developer Tools.Valid values are listed in Apple’s documentation.
-
target
String | TargetConfiguration - The target package type: list ofdefault
,dmg
,mas
,mas-dev
,pkg
,7z
,zip
,tar.xz
,tar.lz
,tar.gz
,tar.bz2
,dir
. Defaults todefault
(dmg
andzip
for Squirrel.Mac). Note: Squirrel.Mac auto update mechanism requires bothdmg
andzip
to be enabled, even when onlydmg
is used. Disablingzip
will break auto update indmg
packages. -
identity
String | “undefined” - The name of certificate to use when signing. Consider using environment variables CSC_LINK or CSC_NAME instead of specifying this option. MAS installer identity is specified in the mas. -
icon
=build/icon.icns
String | “undefined” - The path to application icon. -
entitlements
String | “undefined” - The path to entitlements file for signing the app.build/entitlements.mac.plist
will be used if exists (it is a recommended way to set). MAS entitlements is specified in the mas. See this folder in osx-sign’s repository for examples. Be aware that your app may crash if the right entitlements are not set likecom.apple.security.cs.allow-jit
for example on arm64 builds with Electron 20+. See Signing and Notarizing macOS Builds from the Electron documentation for more information. -
entitlementsInherit
String | “undefined” - The path to child entitlements which inherit the security settings for signing frameworks and bundles of a distribution.build/entitlements.mac.inherit.plist
will be used if exists (it is a recommended way to set). See this folder in osx-sign’s repository for examples.This option only applies when signing with
entitlements
provided. -
entitlementsLoginHelper
String | “undefined” - Path to login helper entitlement file. When using App Sandbox, the thecom.apple.security.inherit
key that is normally in the inherited entitlements cannot be inherited since the login helper is a standalone executable. Defaults to the value provided forentitlements
. This option only applies when signing withentitlements
provided. -
provisioningProfile
String | “undefined” - The path to the provisioning profile to use when signing, absolute or relative to the app root. -
bundleVersion
String | “undefined” - TheCFBundleVersion
. Do not use it unless you need to. -
bundleShortVersion
String | “undefined” - TheCFBundleShortVersionString
. Do not use it unless you need to. -
darkModeSupport
=false
Boolean - Whether a dark mode is supported. If your app does have a dark mode, you can make your app follow the system-wide dark mode setting. -
helperBundleId
=${appBundleIdentifier}.helper
String | “undefined” - The bundle identifier to use in the application helper’s plist. -
helperRendererBundleId
=${appBundleIdentifier}.helper.Renderer
String | “undefined” - The bundle identifier to use in the Renderer helper’s plist. -
helperPluginBundleId
=${appBundleIdentifier}.helper.Plugin
String | “undefined” - The bundle identifier to use in the Plugin helper’s plist. -
helperGPUBundleId
=${appBundleIdentifier}.helper.GPU
String | “undefined” - The bundle identifier to use in the GPU helper’s plist. -
helperEHBundleId
=${appBundleIdentifier}.helper.EH
String | “undefined” - The bundle identifier to use in the EH helper’s plist. -
helperNPBundleId
=${appBundleIdentifier}.helper.NP
String | “undefined” - The bundle identifier to use in the NP helper’s plist. -
type
=distribution
“distribution” | “development” | “undefined” - Whether to sign app for development or for distribution. -
extendInfo
any - The extra entries forInfo.plist
. -
binaries
Array<String> | “undefined” - Paths of any extra binaries that need to be signed. -
minimumSystemVersion
String | “undefined” - The minimum version of macOS required for the app to run. Corresponds toLSMinimumSystemVersion
. -
requirements
String | “undefined” - Path of requirements file used in signing. Not applicable for MAS. -
extraDistFiles
Array<String> | String | “undefined” - Extra files to put in archive. Not applicable fortar.*
. -
hardenedRuntime
=true
Boolean - Whether your app has to be signed with hardened runtime. -
gatekeeperAssess
=false
Boolean - Whether to let @electron/osx-sign validate the signing or not. -
strictVerify
=true
Boolean - Whether to let @electron/osx-sign verify the contents or not. -
preAutoEntitlements
=true
Boolean - Whether to enable entitlements automation from @electron/osx-sign. -
signIgnore
Array<String> | String | “undefined” - Regex or an array of regex’s that signal skipping signing a file. -
timestamp
String | “undefined” - Specify the URL of the timestamp authority server -
mergeASARs
=true
Boolean - Whether to merge ASAR files for different architectures or not.This option has no effect unless building for “universal” arch.
-
singleArchFiles
String | “undefined” - Minimatch pattern of paths that are allowed to be present in one of the ASAR files, but not in the other.This option has no effect unless building for “universal” arch and applies only if
mergeASARs
istrue
. -
x64ArchFiles
String | “undefined” - Minimatch pattern of paths that are allowed to be x64 binaries in both ASAR filesThis option has no effect unless building for “universal” arch and applies only if
mergeASARs
istrue
. -
notarize
NotarizeLegacyOptions | NotarizeNotaryOptions | Boolean | “undefined” - Options to use for @electron/notarize (ref: https://github.com/electron/notarize). Supports bothlegacy
andnotarytool
notarization tools. Usefalse
to explicitly disableNote: In order to activate the notarization step You MUST specify one of the following via environment variables: 1.
APPLE_API_KEY
,APPLE_API_KEY_ID
andAPPLE_API_ISSUER
. 2.APPLE_ID
andAPPLE_APP_SPECIFIC_PASSWORD
3.APPLE_KEYCHAIN
andAPPLE_KEYCHAIN_PROFILE
For security reasons it is recommended to use the first option (see https://github.com/electron-userland/electron-builder/issues/7859)
NotarizeLegacyOptions
undefined
appBundleId
String | “undefined” - The app bundle identifier your Electron app is using. E.g. com.github.electron. Useful if notarization ID differs from app ID (unlikely). Only used bylegacy
notarization toolascProvider
String | “undefined” - Your Team Short Name. Only used bylegacy
notarization tool
NotarizeNotaryOptions
undefined
teamId
String - The team ID you want to notarize under for when usingnotarytool
And all common platform-specific options.