⚙️ (jfrog) [NO-ISSUE]: Attest and sign package #143
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: publish npm packages | |
on: | |
pull_request: | |
# push: | |
# branches: | |
# - main | |
env: | |
FORCE_COLOR: "1" | |
# NPM_REGISTRY: jfrog.ledgerlabs.net/artifactory/api/npm/ldk-npm-prod-public | |
NPM_REGISTRY: jfrog.ledgerlabs.net/artifactory/api/npm/ldk-npm-sandbox-green | |
permissions: | |
id-token: write | |
contents: write | |
pull-requests: write | |
jobs: | |
publish: | |
# environment: Production | |
runs-on: ledgerhq-shared-medium | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: ./.github/actions/setup-toolchain-composite | |
- name: install dependencies | |
run: pnpm install | |
- name: build libraries | |
run: pnpm build | |
- name: Login to internal JFrog registry | |
id: jfrog-login | |
uses: LedgerHQ/actions-security/actions/jfrog-login@actions/jfrog-login-1 | |
- name: Setup npm config for JFrog | |
env: | |
NPM_REGISTRY_TOKEN: ${{ steps.jfrog-login.outputs.oidc-token }} | |
run: | | |
cat << EOF | tee .npmrc | |
registry=https://${NPM_REGISTRY}/ | |
//${NPM_REGISTRY}/:_authToken=${NPM_REGISTRY_TOKEN} | |
EOF | |
- name: Publish | |
id: changesets | |
uses: changesets/action@v1 | |
# to remove | |
with: | |
publish: pnpm release | |
# to remove | |
title: "⚙️ (release) [NO-ISSUE]: Version packages" | |
commit: "⚙️ (release): Version packages" | |
branch: feat/no-issue-jfrog-attest-sign-package | |
createGithubReleases: false | |
env: | |
GITHUB_TOKEN: ${{ secrets.CI_BOT_TOKEN }} | |
- name: Download published packages to attest and sign | |
if: steps.changesets.outputs.published == 'true' | |
run: | | |
# Extract package name | |
# output will be in the form of | |
# [{"name":"@ledgerhq/device-sdk-core","version":"0.4.0"}] | |
cat << EOF | tee published-packages.json | |
${{ steps.changesets.outputs.publishedPackages }} | |
EOF | |
PACKAGE_NAME=$(cat published-packages.json | jq -r '.[0].name') | |
PACKAGE_VERSION=$(cat published-packages.json | jq -r '.[0].version') | |
# Create dist directory | |
mkdir -p dist | |
echo "\033[0;32mDownload artifact from\033[0m https://${NPM_REGISTRY}/${PACKAGE_NAME}/-/${PACKAGE_NAME}-${PACKAGE_VERSION}.tgz" | |
curl -sL --output dist/${PACKAGE_NAME}-{PACKAGE_VERSION}.tgz https://${NPM_REGISTRY}/${PACKAGE_NAME}/-/${PACKAGE_NAME}-${PACKAGE_VERSION}.tgz | |
ls -al dist | |
- name: Attest tarball | |
if: steps.changesets.outputs.published == 'true' | |
uses: LedgerHQ/actions-security/actions/attest@actions/attest-1 | |
with: | |
subject-path: ./dist | |
push-to-registry: true | |
# The action currently doesn't support pushing the blob to the registry | |
- name: Sign tarball | |
if: steps.changesets.outputs.published == 'true' | |
uses: LedgerHQ/actions-security/actions/sign-blob@actions/sign-blob-1 | |
with: | |
path: ./dist |