oxen-electron-gui-wallet/BUILDING.md

1.8 KiB

Building

Building oxen electron wallet binaries is done using github actions. Windows and linux binaries will build right out of the box but there are some extra steps needed for Mac OS

Mac OS

The build script for Mac OS requires you to have a valid Developer ID Application certificate. Without this the build script cannot sign and notarize the mac binary which is needed for Catalina 10.15 and above. If you would like to disable this then comment out "afterSign": "build/notarize.js", in package.json.

You will also need an App-specific password for the apple account you wish to notarize with

Setup

Once you have your Developer ID Application you need to export it into a .p12 file. Keep a note of the password used to encrypt this file as it will be needed later.

We need to Base64 encode this file, so run the following command:

base64 -i certificate.p12 -o encoded.txt

On GitHub:

  1. Navigate to the main page of the repository.
  2. Under your repository name, click Settings.
  3. In the left sidebar, click Secrets.
  4. Add the following secrets:
    1. Certificate
      • Name: MAC_CERTIFICATE
      • Value: The encoded Base64 certificate
    2. Certificate password
      • Name: MAC_CERTIFICATE_PASSWORD
      • Value: The password that was set when the certificate was exported.
    3. Apple ID
      • Name: SIGNING_APPLE_ID
      • Value: The apple id (email) to use for signing
    4. Apple Password
      • Name: SIGNING_APP_PASSWORD
      • Value: The app-specific password that was generated for the apple id
    5. Team ID (Optional)
      • Name: SIGNING_TEAM_ID
      • Value: The apple team id if you're sigining the application for a team