2022-11-07 17:40:21 -08:00
|
|
|
---
|
|
|
|
name: package and draft GitHub release
|
|
|
|
# https://github.com/product-os/flowzone/tree/master/.github/actions
|
|
|
|
inputs:
|
|
|
|
json:
|
2023-06-28 07:26:16 -04:00
|
|
|
description: 'JSON stringified object containing all the inputs from the calling workflow'
|
2022-11-07 17:40:21 -08:00
|
|
|
required: true
|
|
|
|
secrets:
|
2023-06-28 07:26:16 -04:00
|
|
|
description: 'JSON stringified object containing all the secrets from the calling workflow'
|
2022-11-07 17:40:21 -08:00
|
|
|
required: true
|
2023-05-16 00:02:37 +00:00
|
|
|
variables:
|
2023-06-28 07:26:16 -04:00
|
|
|
description: 'JSON stringified object containing all the variables from the calling workflow'
|
2023-05-16 00:02:37 +00:00
|
|
|
required: true
|
2022-11-07 17:40:21 -08:00
|
|
|
|
|
|
|
# --- custom environment
|
|
|
|
XCODE_APP_LOADER_EMAIL:
|
|
|
|
type: string
|
2023-06-28 07:26:16 -04:00
|
|
|
default: 'accounts+apple@balena.io'
|
2022-11-07 17:40:21 -08:00
|
|
|
NODE_VERSION:
|
|
|
|
type: string
|
2024-01-17 08:43:14 -03:00
|
|
|
default: '20.x'
|
2022-11-07 17:40:21 -08:00
|
|
|
VERBOSE:
|
|
|
|
type: string
|
2023-06-28 07:26:16 -04:00
|
|
|
default: 'true'
|
2022-11-07 17:40:21 -08:00
|
|
|
|
|
|
|
runs:
|
|
|
|
# https://docs.github.com/en/actions/creating-actions/creating-a-composite-action
|
2023-06-28 07:26:16 -04:00
|
|
|
using: 'composite'
|
2022-11-07 17:40:21 -08:00
|
|
|
steps:
|
|
|
|
- name: Download custom source artifact
|
2023-12-19 14:26:28 -03:00
|
|
|
uses: actions/download-artifact@f44cd7b40bfd40b6aa1cc1b9b5b7bf03d3c67110 # v4.1.0
|
2022-11-07 17:40:21 -08:00
|
|
|
with:
|
2023-05-16 00:02:37 +00:00
|
|
|
name: custom-${{ github.event.pull_request.head.sha || github.event.head_commit.id }}-${{ runner.os }}-${{ runner.arch }}
|
2022-11-07 17:40:21 -08:00
|
|
|
path: ${{ runner.temp }}
|
|
|
|
|
|
|
|
- name: Extract custom source artifact
|
|
|
|
shell: pwsh
|
|
|
|
working-directory: .
|
|
|
|
run: tar -xf ${{ runner.temp }}/custom.tgz
|
|
|
|
|
|
|
|
- name: Setup Node.js
|
2024-06-21 16:47:51 +00:00
|
|
|
uses: actions/setup-node@1a4442cacd436585916779262731d5b162bc6ec7 # v3
|
2022-11-07 17:40:21 -08:00
|
|
|
with:
|
|
|
|
node-version: ${{ inputs.NODE_VERSION }}
|
|
|
|
cache: npm
|
|
|
|
|
2024-03-11 15:37:34 -03:00
|
|
|
- name: Set up Python 3.11
|
|
|
|
if: runner.os == 'macOS'
|
|
|
|
uses: actions/setup-python@d27e3f3d7c64b4bbf8e4abfb9b63b83e846e0435 # v4
|
|
|
|
with:
|
|
|
|
python-version: "3.11"
|
|
|
|
|
2022-11-07 17:40:21 -08:00
|
|
|
- name: Install additional tools
|
|
|
|
if: runner.os == 'Windows'
|
2022-11-10 12:13:03 -08:00
|
|
|
shell: bash
|
2022-11-07 17:40:21 -08:00
|
|
|
run: |
|
|
|
|
choco install yq
|
|
|
|
|
|
|
|
- name: Install additional tools
|
|
|
|
if: runner.os == 'macOS'
|
2022-11-10 12:13:03 -08:00
|
|
|
shell: bash
|
2022-11-07 17:40:21 -08:00
|
|
|
run: |
|
|
|
|
brew install coreutils
|
|
|
|
|
|
|
|
# https://www.electron.build/code-signing.html
|
|
|
|
# https://github.com/Apple-Actions/import-codesign-certs
|
|
|
|
- name: Import Apple code signing certificate
|
|
|
|
if: runner.os == 'macOS'
|
2024-06-21 16:47:51 +00:00
|
|
|
uses: apple-actions/import-codesign-certs@253ddeeac23f2bdad1646faac5c8c2832e800071 # v1
|
2022-11-07 17:40:21 -08:00
|
|
|
with:
|
|
|
|
p12-file-base64: ${{ fromJSON(inputs.secrets).APPLE_SIGNING }}
|
|
|
|
p12-password: ${{ fromJSON(inputs.secrets).APPLE_SIGNING_PASSWORD }}
|
|
|
|
|
|
|
|
- name: Import Windows code signing certificate
|
|
|
|
if: runner.os == 'Windows'
|
|
|
|
shell: powershell
|
|
|
|
run: |
|
2024-03-06 08:06:27 -03:00
|
|
|
Set-Content -Path ${{ runner.temp }}/certificate.base64 -Value $env:SM_CLIENT_CERT_FILE_B64
|
|
|
|
certutil -decode ${{ runner.temp }}/certificate.base64 ${{ runner.temp }}/Certificate_pkcs12.p12
|
2022-11-07 17:40:21 -08:00
|
|
|
Remove-Item -path ${{ runner.temp }} -include certificate.base64
|
|
|
|
env:
|
2024-03-06 08:06:27 -03:00
|
|
|
SM_CLIENT_CERT_FILE_B64: ${{ fromJSON(inputs.secrets).SM_CLIENT_CERT_FILE_B64 }}
|
2022-11-07 17:40:21 -08:00
|
|
|
|
|
|
|
# https://github.com/product-os/scripts/tree/master/shared
|
|
|
|
# https://github.com/product-os/balena-concourse/blob/master/pipelines/github-events/template.yml
|
|
|
|
- name: Package release
|
2022-11-10 12:13:03 -08:00
|
|
|
shell: bash
|
2022-11-07 17:40:21 -08:00
|
|
|
run: |
|
|
|
|
set -ea
|
|
|
|
|
|
|
|
[[ '${{ inputs.VERBOSE }}' =~ on|On|Yes|yes|true|True ]] && set -x
|
|
|
|
|
|
|
|
runner_os="$(echo "${RUNNER_OS}" | tr '[:upper:]' '[:lower:]')"
|
|
|
|
runner_arch="$(echo "${RUNNER_ARCH}" | tr '[:upper:]' '[:lower:]')"
|
|
|
|
|
|
|
|
if [[ $runner_os =~ darwin|macos|osx ]]; then
|
|
|
|
CSC_KEY_PASSWORD=${{ fromJSON(inputs.secrets).APPLE_SIGNING_PASSWORD }}
|
|
|
|
CSC_KEYCHAIN=signing_temp
|
|
|
|
CSC_LINK=${{ fromJSON(inputs.secrets).APPLE_SIGNING }}
|
|
|
|
|
|
|
|
elif [[ $runner_os =~ windows|win ]]; then
|
2024-03-06 08:06:27 -03:00
|
|
|
SM_HOST=${{ fromJSON(inputs.secrets).SM_HOST }}
|
|
|
|
SM_API_KEY=${{ fromJSON(inputs.secrets).SM_API_KEY }}
|
|
|
|
SM_CLIENT_CERT_FILE='${{ runner.temp }}\Certificate_pkcs12.p12'
|
|
|
|
SM_CLIENT_CERT_PASSWORD=${{ fromJSON(inputs.secrets).SM_CLIENT_CERT_PASSWORD }}
|
|
|
|
SM_CODE_SIGNING_CERT_SHA1_HASH=${{ fromJSON(inputs.secrets).SM_CODE_SIGNING_CERT_SHA1_HASH }}
|
|
|
|
|
|
|
|
curl --silent --retry 3 --fail https://one.digicert.com/signingmanager/api-ui/v1/releases/smtools-windows-x64.msi/download \
|
|
|
|
-H "x-api-key:$SM_API_KEY" \
|
|
|
|
-o smtools-windows-x64.msi
|
|
|
|
msiexec -i smtools-windows-x64.msi -qn
|
|
|
|
PATH="/c/Program Files/DigiCert/DigiCert One Signing Manager Tools:${PATH}"
|
|
|
|
smksp_registrar.exe list
|
|
|
|
smctl.exe keypair ls
|
|
|
|
/c/Windows/System32/certutil.exe -csp "DigiCert Signing Manager KSP" -key -user
|
|
|
|
smksp_cert_sync.exe
|
2022-11-07 17:40:21 -08:00
|
|
|
|
|
|
|
# (signtool.exe) https://github.com/actions/runner-images/blob/main/images/win/Windows2019-Readme.md#installed-windows-sdks
|
|
|
|
PATH="/c/Program Files (x86)/Windows Kits/10/bin/${runner_arch}:${PATH}"
|
|
|
|
fi
|
|
|
|
|
|
|
|
npm run package
|
|
|
|
|
|
|
|
find dist -type f -maxdepth 1
|
|
|
|
|
|
|
|
env:
|
|
|
|
# https://github.blog/2020-08-03-github-actions-improvements-for-fork-and-pull-request-workflows/#improvements-for-public-repository-forks
|
|
|
|
# https://docs.github.com/en/actions/managing-workflow-runs/approving-workflow-runs-from-public-forks#about-workflow-runs-from-public-forks
|
|
|
|
CSC_FOR_PULL_REQUEST: true
|
2024-03-06 08:06:27 -03:00
|
|
|
# https://docs.digicert.com/es/software-trust-manager/ci-cd-integrations/plugins/github-custom-action-for-keypair-signing.html
|
|
|
|
TIMESTAMP_SERVER: http://timestamp.digicert.com
|
2022-11-07 17:40:21 -08:00
|
|
|
# Apple notarization (automation/build-bin.ts)
|
|
|
|
XCODE_APP_LOADER_EMAIL: ${{ inputs.XCODE_APP_LOADER_EMAIL }}
|
|
|
|
XCODE_APP_LOADER_PASSWORD: ${{ fromJSON(inputs.secrets).XCODE_APP_LOADER_PASSWORD }}
|
2023-06-29 07:41:07 -04:00
|
|
|
XCODE_APP_LOADER_TEAM_ID: ${{ inputs.XCODE_APP_LOADER_TEAM_ID }}
|
2022-11-07 17:40:21 -08:00
|
|
|
|
2022-11-17 15:06:37 -08:00
|
|
|
- name: Upload artifacts
|
2024-06-21 17:49:06 +00:00
|
|
|
uses: actions/upload-artifact@65462800fd760344b1a7b4382951275a0abb4808 # v4
|
2022-11-07 17:40:21 -08:00
|
|
|
with:
|
2023-12-19 14:26:28 -03:00
|
|
|
name: gh-release-${{ github.event.pull_request.head.sha || github.event.head_commit.id }}-${{ strategy.job-index }}
|
2022-11-17 15:06:37 -08:00
|
|
|
path: dist
|
2022-11-07 17:40:21 -08:00
|
|
|
retention-days: 1
|
2023-12-19 14:26:28 -03:00
|
|
|
if-no-files-found: error
|