From d6d12b8c9cae2f7acb9f25911412f502faa55ea2 Mon Sep 17 00:00:00 2001 From: Joseph Flinn Date: Wed, 27 Jan 2021 19:15:29 +0000 Subject: [PATCH] reworking gh actions into the build/release/deploy model --- .github/workflows/build.yml | 195 +++++------------------ .github/workflows/deploy.yml | 121 ++++++++++++++ .github/workflows/release.yml | 290 ++++++++++++++++++++++++++++++++++ package.json | 4 +- 4 files changed, 450 insertions(+), 160 deletions(-) create mode 100644 .github/workflows/deploy.yml create mode 100644 .github/workflows/release.yml diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index f67a066ba7..8d610e1aa1 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -4,9 +4,6 @@ on: push: branches-ignore: - 'l10n_master' - release: - types: - - published jobs: cloc: @@ -23,7 +20,7 @@ jobs: - name: Print lines of code run: cloc --include-lang TypeScript,JavaScript --vcs git - build: + windows: name: Build CLI runs-on: windows-latest steps: @@ -31,58 +28,47 @@ jobs: uses: actions/checkout@v2 - name: Setup Windows builder - run: choco install checksum --no-progress + run: | + choco install checksum --no-progress + choco install reshack --no-progress - name: Set up Node uses: actions/setup-node@v1 with: node-version: '10.x' - - name: Install pkg-fetch - run: | - $fetchedUrl = "https://github.com/vercel/pkg-fetch/releases/download/v2.5/uploaded-v2.5-node-v10.4.1-win-x64" - - New-Item -ItemType directory -Path .pkg-cache - Invoke-RestMethod -Uri $fetchedUrl -OutFile ".pkg-cache/fetched-v10.4.1-win-x64" - dir - dir .pkg-cache - - - name: Download & Install RH - shell: pwsh - run: | - choco install reshack - #Invoke-WebRequest -Uri http://www.angusj.com/resourcehacker/resource_hacker.zip -OutFile "resource_hacker.zip" - #Expand-Archive -Path resource_hacker.zip -DestinationPath scripts/resource_hacker - #echo "D:/a/cli/cli/scripts/resource_hacker" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append - - name: Set PACKAGE_VERSION & VER_INFO run: | - $env:pkgVersion = (Get-Content -Raw -Path ./package.json | ConvertFrom-Json).version + $env:pkgVersion = (Get-Content -Raw -Path .\src\package.json | ConvertFrom-Json).version echo "PACKAGE_VERSION=$env:pkgVersion" | Out-File -FilePath $env:GITHUB_ENV -Encoding utf8 -Append echo "WIN_PKG=$env:WIN_PKG" | Out-File -FilePath $env:GITHUB_ENV -Encoding utf8 -Append echo "version: $env:pkgVersion" - - dir - if(Test-Path -Path $env:WIN_PKG) { - Write-Host "Path exists $env:WIN_PKG" - echo "VER_INFO=true" | Out-File -FilePath $env:GITHUB_ENV -Encoding utf8 -Append - } - - exit 1 env: - WIN_PKG: .pkg-cache/v2.5/fetched-v10.4.1-win-x64 + WIN_PKG: C:\Users\runneradmin\.pkg-cache\v2.5\fetched-v10.4.1-win-x64 + + - name: get pkg-fetch + shell: pwsh + run: | + cd $HOME + $fetchedUrl = "https://github.com/vercel/pkg-fetch/releases/download/v2.5/uploaded-v2.5-node-v10.4.1-win-x64" + + New-Item -ItemType directory -Path .\.pkg-cache + New-Item -ItemType directory -Path .\.pkg-cache\v2.5 + Invoke-RestMethod -Uri $fetchedUrl -OutFile ".\.pkg-cache\v2.5\fetched-v10.4.1-win-x64" + env: + WIN_PKG: C:\Users\runneradmin\.pkg-cache\v2.5\fetched-v10.4.1-win-x64 - name: Setup Version Info shell: pwsh run: ./scripts/make-versioninfo.ps1 - - name: ResourceHacker + - name: Resource Hacker shell: cmd run: | - echo "ver_info: %VER_INFO%" - if defined VER_INFO ResourceHacker -open %WIN_PKG% -save %WIN_PKG% -action delete -mask ICONGROUP,1, - if defined VER_INFO ResourceHacker -open version-info.rc -save version-info.res -action compile - if defined VER_INFO ResourceHacker -open %WIN_PKG% -save %WIN_PKG% -action addoverwrite -resource version-info.res + set PATH=%PATH%;C:\Program Files (x86)\Resource Hacker + ResourceHacker -open %WIN_PKG% -save %WIN_PKG% -action delete -mask ICONGROUP,1, + ResourceHacker -open version-info.rc -save version-info.res -action compile + ResourceHacker -open %WIN_PKG% -save %WIN_PKG% -action addoverwrite -resource version-info.res - name: Install run: npm install @@ -90,20 +76,8 @@ jobs: - name: Setup sub-module run: npm run sub:init - - name: Build - run: npm run build:prod - - - name: Clean Build - run: npm run clean - - - name: Package Windows - run: npm run package:win - - - name: Package Mac - run: npm run package:mac - - - name: Package Linux - run: npm run package:lin + - name: Build & Package + run: npm run dist - name: Package Chocolatey shell: pwsh @@ -134,6 +108,7 @@ jobs: } - name: Create checksums + if: github.ref == 'refs/heads/master' run: | checksum -f="./dist/bw-windows-${env:PACKAGE_VERSION}.zip" ` -t sha256 | Out-File -Encoding ASCII ./dist/bw-windows-sha256-${env:PACKAGE_VERSION}.txt @@ -143,88 +118,56 @@ jobs: -t sha256 | Out-File -Encoding ASCII ./dist/bw-linux-sha256-${env:PACKAGE_VERSION}.txt - name: Publish windows zip to GitHub + if: github.ref == 'refs/heads/master' uses: actions/upload-artifact@v2 with: name: bw-windows-${{ env.PACKAGE_VERSION }}.zip path: ./dist/bw-windows-${{ env.PACKAGE_VERSION }}.zip - name: Publish windows checksum to GitHub + if: github.ref == 'refs/heads/master' uses: actions/upload-artifact@v2 with: name: bw-windows-sha256-${{ env.PACKAGE_VERSION }}.txt path: ./dist/bw-windows-sha256-${{ env.PACKAGE_VERSION }}.txt - name: Publish macos zip to GitHub + if: github.ref == 'refs/heads/master' uses: actions/upload-artifact@v2 with: name: bw-macos-${{ env.PACKAGE_VERSION }}.zip path: ./dist/bw-macos-${{ env.PACKAGE_VERSION }}.zip - name: Publish macos checksum to GitHub + if: github.ref == 'refs/heads/master' uses: actions/upload-artifact@v2 with: name: bw-macos-sha256-${{ env.PACKAGE_VERSION }}.txt path: ./dist/bw-macos-sha256-${{ env.PACKAGE_VERSION }}.txt - name: Publish linux zip to GitHub + if: github.ref == 'refs/heads/master' uses: actions/upload-artifact@v2 with: name: bw-linux-${{ env.PACKAGE_VERSION }}.zip path: ./dist/bw-linux-${{ env.PACKAGE_VERSION }}.zip - name: Publish linux checksum to GitHub + if: github.ref == 'refs/heads/master' uses: actions/upload-artifact@v2 with: name: bw-linux-sha256-${{ env.PACKAGE_VERSION }}.txt path: ./dist/bw-linux-sha256-${{ env.PACKAGE_VERSION }}.txt - name: Publish Chocolatey CLI + if: github.ref == 'refs/heads/master' uses: actions/upload-artifact@v2 with: name: bitwarden-cli.${{ env.PACKAGE_VERSION }}.nupkg path: ./dist/chocolatey/bitwarden-cli.${{ env.PACKAGE_VERSION }}.nupkg - publish_windows: - name: Publish Windows - runs-on: windows-latest - needs: build - if: github.event_name == 'release' - steps: - - name: Checkout repo - uses: actions/checkout@v2 - - - name: Set PACKAGE_VERSION - run: | - $env:pkgVersion = (Get-Content -Raw -Path ./package.json | ConvertFrom-Json).version - echo "PACKAGE_VERSION=$env:pkgVersion" | Out-File -FilePath $env:GITHUB_ENV -Encoding utf8 -Append - - - name: Download Windows Nuget - uses: actions/download-artifact@v2 - with: - name: bitwarden-cli.${{ env.PACKAGE_VERSION }}.nupkg - path: ./dist/bitwarden-cli.${{ env.PACKAGE_VERSION }}.nupkg - - - name: Setup Chocolatey - run: choco apikey --key $env:CHOCO_API_KEY --source https://push.chocolatey.org/ - env: - CHOCO_API_KEY: ${{ secrets.CHOCO_API_KEY }} - - - name: Publish - run: | - ./scripts/choco-update.ps1 -version $env:PACKAGE_VERSION - Get-ChildItem dist - - - name: Publish - shell: pwsh - run: | - # In place of ./scripts/choco-update.ps1 - cd ./dist - choco push - - - # This process seems independent from the others - build_snap: + linux: name: Build Snap if: false runs-on: ubuntu-latest @@ -280,79 +223,15 @@ jobs: sudo snap remove bw - name: Publish snap to GitHub + if: github.ref == 'refs/heads/master' uses: actions/upload-artifact@v2 with: name: bw_${{ env.PACKAGE_VERSION }}_amd64.snap path: ./dist/snap/bw_${{ env.PACKAGE_VERSION }}_amd64.snap - - name: Publish snap to GitHub + - name: Publish snap checksum to GitHub + if: github.ref == 'refs/heads/master' uses: actions/upload-artifact@v2 with: name: bw-snap-sha256-${{ env.PACKAGE_VERSION }}.txt path: ./dist/snap/bw-snap-sha256-${{ env.PACKAGE_VERSION }}.txt - - - publish_snap: - name: Publish Snap - runs-on: ubuntu-latest - needs: build_snap - if: github.event_name == 'release' - steps: - - name: Checkout repo - uses: actions/checkout@v2 - - - name: Set PACKAGE_VERSION - shell: pwsh - run: | - $env:pkgVersion = (Get-Content -Raw -Path ./package.json | ConvertFrom-Json).version - echo "PACKAGE_VERSION=$env:pkgVersion" | Out-File -FilePath $env:GITHUB_ENV -Encoding utf8 -Append - - - name: Install Snapcraft - uses: samuelmeuli/action-snapcraft@v1 - with: - snapcraft_token: ${{ secrets.SNAP_TOKEN }} - - - name: Download snap - uses: actions/download-artifact@v2 - with: - name: bw_${{ env.PACKAGE_VERSION }}_amd64.snap - path: ./bw_${{ env.PACKAGE_VERSION }}_amd64.snap - - - name: Print environment - run: | - whoami - snapcraft --version - echo "GitHub ref: $GITHUB_REF" - echo "GitHub event: $GITHUB_EVENT" - echo "BW Package Version: $PACKAGE_VERSION" - env: - GITHUB_REF: ${{ github.ref }} - GITHUB_EVENT: ${{ github.event_name }} - - - name: Checksum Snap & Publish Snap - run: snapcraft push ./bw_${{ env.PACKAGE_VERSION }}_amd64.snap --release stable - - - name: Snap Logout - run: snapcraft logout - - - # This job is independent: it reruns 'npm run build:prod' - # Could be moved out a level - publish_npm: - name: Publish NPM - runs-on: ubuntu-latest - needs: build - if: github.event_name == 'release' - steps: - - name: Checkout repo - uses: actions/checkout@v2 - - - name: Setup NPM - shell: pwsh - run: | - "//registry.npmjs.org/:_authToken=${env:NPM_TOKEN}" | Out-File ".npmrc" -Encoding UTF8 - env: - NPM_TOKEN: ${{ secrets.NPM_TOKEN }} - - - name: Publish NPM - run: npm run publish:npm diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml new file mode 100644 index 0000000000..b9a664989c --- /dev/null +++ b/.github/workflows/deploy.yml @@ -0,0 +1,121 @@ +name: Deploy + +on: + release: + types: + - prereleased + workflow_dispatch: + inputs: + + +jobs: + setup: + runs-on: ubuntu-latest + outputs: + package_version: ${{ steps.get_pkg_version.outputs.package_version }} + tag_version: ${{ steps.get_pkg_version.outputs.tag_version }} + steps: + - name: Checkout Repo + uses: actions/checkout@v2 + + - name: Get package version + id: get_pkg_version + run: | + TAG_VERSION=$(echo ${{ github.ref }} | cut -d "/" -f 3) + PKG_VERSION=${TAG_VERSION:1} + + echo "::set-output name=package_version::$PKG_VERSION" + echo "::set-output name=tag_version::$TAG_VERSION" + + + snap: + name: Publish Snap + runs-on: ubuntu-latest + needs: setup + steps: + - name: Checkout repo + uses: actions/checkout@v2 + + - name: Install Snapcraft + uses: samuelmeuli/action-snapcraft@v1 + #with: + # snapcraft_token: ${{ secrets.SNAP_TOKEN }} + + - name: Get snap release asset + uses: dsaltares/fetch-gh-release-asset@0.0.5 + with: + version: tags/${{ env.TAG_VERSION }} + file: bw_${{ env.PKG_VERSION }}_amd64.snap + env: + PKG_VERSION: ${{ needs.setup.outputs.package_version }} + TAG_VERSION: ${{ needs.setup.outputs.tag_version }} + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: move assets + run: | + echo "Hopefully this is temporary until release 0.0.6 of the fetch-gh-release-asset is released" + mkdir dist + mv bw_${{ env.PKG_VERSION }}_amd64.snap -t dist + + - name: test + run: ls -alht dist + + #- name: Publish Snap & logout + # run: | + # snapcraft push ./dist/bw_${{ env.PACKAGE_VERSION }}_amd64.snap --release stable + # snapcraft logout + + + choco: + name: Publish Choco + runs-on: windows-latest + needs: setup + steps: + - name: Checkout repo + uses: actions/checkout@v2 + + - name: Setup Chocolatey + run: choco apikey --key $env:CHOCO_API_KEY --source https://push.chocolatey.org/ + env: + CHOCO_API_KEY: ${{ secrets.CHOCO_API_KEY }} + + - name: Get choco release asset + uses: dsaltares/fetch-gh-release-asset@0.0.5 + with: + version: tags/${{ env.TAG_VERSION }} + file: bitwarden.${{ env.PKG_VERSION }}.nupkg + env: + PKG_VERSION: ${{ needs.setup.outputs.package_version }} + TAG_VERSION: ${{ needs.setup.outputs.tag_version }} + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: Push to Chocolatey + shell: pwsh + run: | + # In place of ./scripts/choco-update.ps1 + New-Item -ItemType directory -Path ./dist + Move-Item -Path bitwarden.${{ env.PKG_VERSION }}.nupkg -Destination ./dist + cd ./dist + #choco push + + - name: test + run: ls -atlh dist + + + npm: + name: Publish NPM + if: false + runs-on: ubuntu-latest + steps: + - name: Checkout repo + uses: actions/checkout@v2 + + - name: Setup NPM + shell: pwsh + run: | + "//registry.npmjs.org/:_authToken=${env:NPM_TOKEN}" | Out-File ".npmrc" -Encoding UTF8 + env: + NPM_TOKEN: ${{ secrets.NPM_TOKEN }} + + - name: Publish NPM + run: npm run publish:npm diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000000..42cc021460 --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,290 @@ +name: Release + +on: + workflow_dispatch: + inputs: + release_tag_name_input: + description: "Release Tag Name " + required: true + + +jobs: + setup: + runs-on: ubuntu-latest + outputs: + release_upload_url: ${{ steps.create_release.outputs.upload_url }} + steps: + - name: Checkout repo + uses: actions/checkout@v2 + + - name: Create Release Vars + id: create_tags + run: | + case "${RELEASE_TAG_NAME_INPUT:0:1}" in + v) + echo "RELEASE_NAME=${RELEASE_TAG_NAME_INPUT:1}" >> $GITHUB_ENV + echo "RELEASE_TAG_NAME=$RELEASE_TAG_NAME_INPUT" >> $GITHUB_ENV + ;; + [0-9]) + echo "RELEASE_NAME=$RELEASE_TAG_NAME_INPUT" >> $GITHUB_ENV + echo "RELEASE_TAG_NAME=v$RELEASE_TAG_NAME_INPUT" >> $GITHUB_ENV + ;; + *) + exit 1 + ;; + esac + env: + RELEASE_TAG_NAME_INPUT: ${{ github.event.inputs.release_tag_name_input }} + + - name: Create Draft Release + id: create_release + uses: actions/create-release@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + tag_name: ${{ env.RELEASE_TAG_NAME }} + release_name: ${{ env.RELEASE_NAME }} + draft: true + prerelease: false + + + windows: + name: Build CLI + runs-on: windows-latest + needs: setup + steps: + - name: Checkout repo + uses: actions/checkout@v2 + + - name: Setup Windows builder + run: | + choco install checksum --no-progress + choco install reshack --no-progress + + - name: Set up Node + uses: actions/setup-node@v1 + with: + node-version: '10.x' + + - name: Set PACKAGE_VERSION & VER_INFO + run: | + $env:pkgVersion = (Get-Content -Raw -Path .\src\package.json | ConvertFrom-Json).version + echo "PACKAGE_VERSION=$env:pkgVersion" | Out-File -FilePath $env:GITHUB_ENV -Encoding utf8 -Append + echo "WIN_PKG=$env:WIN_PKG" | Out-File -FilePath $env:GITHUB_ENV -Encoding utf8 -Append + echo "version: $env:pkgVersion" + env: + WIN_PKG: C:\Users\runneradmin\.pkg-cache\v2.5\fetched-v10.4.1-win-x64 + + - name: get pkg-fetch + shell: pwsh + run: | + cd $HOME + $fetchedUrl = "https://github.com/vercel/pkg-fetch/releases/download/v2.5/uploaded-v2.5-node-v10.4.1-win-x64" + + New-Item -ItemType directory -Path .\.pkg-cache + New-Item -ItemType directory -Path .\.pkg-cache\v2.5 + Invoke-RestMethod -Uri $fetchedUrl -OutFile ".\.pkg-cache\v2.5\fetched-v10.4.1-win-x64" + env: + WIN_PKG: C:\Users\runneradmin\.pkg-cache\v2.5\fetched-v10.4.1-win-x64 + + - name: Setup Version Info + shell: pwsh + run: ./scripts/make-versioninfo.ps1 + + - name: Resource Hacker + shell: cmd + run: | + set PATH=%PATH%;C:\Program Files (x86)\Resource Hacker + ResourceHacker -open %WIN_PKG% -save %WIN_PKG% -action delete -mask ICONGROUP,1, + ResourceHacker -open version-info.rc -save version-info.res -action compile + ResourceHacker -open %WIN_PKG% -save %WIN_PKG% -action addoverwrite -resource version-info.res + + - name: Install + run: npm install + + - name: Setup sub-module + run: npm run sub:init + + - name: Build & Package + run: npm run dist + + - name: Package Chocolatey + shell: pwsh + run: | + Copy-Item -Path stores/chocolatey -Destination dist/chocolatey -Recurse + Copy-Item dist/windows/bw.exe -Destination dist/chocolatey/tools + Copy-Item LICENSE.txt -Destination dist/chocolatey/tools + + choco pack dist/chocolatey/bitwarden-cli.nuspec --version ${{ env.PACKAGE_VERSION }} --out dist/chocolatey + + - name: Zip + shell: cmd + run: | + 7z a ./dist/bw-windows-%PACKAGE_VERSION%.zip ./dist/windows/bw.exe + 7z a ./dist/bw-macos-%PACKAGE_VERSION%.zip ./dist/macos/bw + 7z a ./dist/bw-linux-%PACKAGE_VERSION%.zip ./dist/linux/bw + + - name: Version Test + run: | + dir ./dist/ + Expand-Archive -Path "./dist/bw-windows-${env:PACKAGE_VERSION}.zip" -DestinationPath "./test/windows" + $testVersion = Invoke-Expression '& ./test/windows/bw.exe -v' + + echo "version: $env:PACKAGE_VERSION" + echo "testVersion: $testVersion" + if($testVersion -ne $env:PACKAGE_VERSION) { + Throw "Version test failed." + } + + - name: Create checksums + run: | + checksum -f="./dist/bw-windows-${env:PACKAGE_VERSION}.zip" ` + -t sha256 | Out-File -Encoding ASCII ./dist/bw-windows-sha256-${env:PACKAGE_VERSION}.txt + checksum -f="./dist/bw-macos-${env:PACKAGE_VERSION}.zip" ` + -t sha256 | Out-File -Encoding ASCII ./dist/bw-macos-sha256-${env:PACKAGE_VERSION}.txt + checksum -f="./dist/bw-linux-${env:PACKAGE_VERSION}.zip" ` + -t sha256 | Out-File -Encoding ASCII ./dist/bw-linux-sha256-${env:PACKAGE_VERSION}.txt + + - name: upload windows zip release asset + id: upload-windows-zip + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ needs.setup.outputs.release_upload_url }} + asset_name: bw-windows-${{ env.PACKAGE_VERSION }}.zip + asset_path: ./dist/bw-windows-${{ env.PACKAGE_VERSION }}.zip + + - name: upload macos zip release asset + id: upload-macos-zip + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ needs.setup.outputs.release_upload_url }} + asset_name: bw-macos-${{ env.PACKAGE_VERSION }}.zip + asset_path: ./dist/bw-macos-${{ env.PACKAGE_VERSION }}.zip + + - name: upload linux zip release asset + id: upload-linux-zip + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ needs.setup.outputs.release_upload_url }} + asset_name: bw-linux-${{ env.PACKAGE_VERSION }}.zip + asset_path: ./dist/bw-linux-${{ env.PACKAGE_VERSION }}.zip + + - name: Upload windows checksum release asset + id: upload-windows-checksum + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ needs.setup.outputs.release_upload_url }} + asset_name: bw-windows-sha256-${{ env.PACKAGE_VERSION }}.txt + asset_path: ./dist/bw-windows-sha256-${{ env.PACKAGE_VERSION }}.txt + + - name: Upload macos checksum release asset + id: upload-macos-checksum + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ needs.setup.outputs.release_upload_url }} + asset_name: bw-macos-sha256-${{ env.PACKAGE_VERSION }}.txt + asset_path: ./dist/bw-macos-sha256-${{ env.PACKAGE_VERSION }}.txt + + - name: Upload linux checksum release asset + id: upload-linux-checksum + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ needs.setup.outputs.release_upload_url }} + asset_name: bw-linux-sha256-${{ env.PACKAGE_VERSION }}.txt + asset_path: ./dist/bw-linux-sha256-${{ env.PACKAGE_VERSION }}.txt + + - name: Upload chocolatey nupkg release asset + id: upload-choco-nupkg + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ needs.setup.outputs.release_upload_url }} + asset_name: bitwarden-cli.${{ env.PACKAGE_VERSION }}.nupkg + asset_path: ./dist/chocolatey/bitwarden-cli.${{ env.PACKAGE_VERSION }}.nupkg + + + linux: + name: Publish Snap + runs-on: ubuntu-latest + need: setup + steps: + - name: Checkout repo + uses: actions/checkout@v2 + + - name: Set PACKAGE_VERSION + shell: pwsh + run: | + $env:pkgVersion = (Get-Content -Raw -Path ./package.json | ConvertFrom-Json).version + echo "PACKAGE_VERSION=$env:pkgVersion" | Out-File -FilePath $env:GITHUB_ENV -Encoding utf8 -Append + + - name: Install Snapcraft + uses: samuelmeuli/action-snapcraft@v1 + + - name: Print environment + run: | + whoami + snapcraft --version + echo "GitHub ref: $GITHUB_REF" + echo "GitHub event: $GITHUB_EVENT" + echo "BW Package Version: $PACKAGE_VERSION" + env: + GITHUB_REF: ${{ github.ref }} + GITHUB_EVENT: ${{ github.event_name }} + + - name: Build Snap Package + run: | + mkdir ./dist + cp -r ./stores/snap -t ./dist + sed -i s/__version__/${{ env.PACKAGE_VERSION }}/g ./dist/snap/snapcraft.yaml + + cd ./dist/snap + snapcraft + + sha256sum bw_${{ env.PACKAGE_VERSION }}_amd64.snap | awk '{split($0, a); print a[1]}' > bw-snap-sha256-${{ env.PACKAGE_VERSION }}.txt + + - name: Install Snap + run: sudo snap install ./dist/snap/bw*.snap --dangerous + + - name: Test Snap + shell: pwsh + run: | + $testVersion = Invoke-Expression '& bw -v' + if($testVersion -ne $env:PACKAGE_VERSION) { + Throw "Version test failed." + } + + - name: Cleanup Test & Update Snap for Publish + shell: pwsh + run: | + sudo snap remove bw + + - name: Upload snap release asset + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ needs.setup.outputs.release_upload_url }} + asset_name: bw_${{ env.PACKAGE_VERSION }}_amd64.snap + asset_path: ./dist/snap/bw_${{ env.PACKAGE_VERSION }}_amd64.snap + + - name: Upload snap checksum release asset + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ needs.setup.outputs.release_upload_url }} + asset_name: bw-snap-sha256-${{ env.PACKAGE_VERSION }}.txt + asset_path: ./dist/snap/bw-snap-sha256-${{ env.PACKAGE_VERSION }}.txt diff --git a/package.json b/package.json index 7c6f203615..dbe309d52d 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "@bitwarden/cli", "description": "A secure and free password manager for all of your devices.", - "version": "1.13.3", + "version": "1.13.4", "keywords": [ "bitwarden", "password", @@ -13,7 +13,7 @@ "homepage": "https://bitwarden.com", "repository": { "type": "git", - "url": "https://github.com/bitwarden/cli" + "url": "https://github.com/joseph-flinn/cli" }, "license": "GPL-3.0", "scripts": {