|
| 1 | +name: "kubewarden-policy-gh-action-dependencies" |
| 2 | +description: "Install all the binaries needed inside of GH action" |
| 3 | +branding: |
| 4 | + icon: "package" |
| 5 | + color: "blue" |
| 6 | +inputs: |
| 7 | + KWCTL_VERSION: |
| 8 | + description: "kwctl release to be installed" |
| 9 | + required: false |
| 10 | + default: v1.29.1 |
| 11 | + SYFT_VERSION: |
| 12 | + description: "syft release to be installed" |
| 13 | + required: false |
| 14 | + default: "1.28.0" |
| 15 | + arch: |
| 16 | + description: "syft arch to be installed" |
| 17 | + required: false |
| 18 | + default: "linux_amd64" # windows_amd64, darwin_amd64 |
| 19 | + BINARYEN_VERSION: |
| 20 | + description: "binaryen release to be installed" |
| 21 | + required: false |
| 22 | + default: "116" |
| 23 | +runs: |
| 24 | + using: "composite" |
| 25 | + steps: |
| 26 | + - name: Install cosign |
| 27 | + uses: sigstore/cosign-installer@faadad0cce49287aee09b3a48701e75088a2c6ad # v4.0.0 |
| 28 | + - name: Install kwctl |
| 29 | + shell: bash |
| 30 | + run: | |
| 31 | + #!/bin/bash |
| 32 | + set -e |
| 33 | +
|
| 34 | + # Build name of gihub release asset |
| 35 | + OS=$(echo "${{ runner.os }}" | tr '[:upper:]' '[:lower:]' | sed 's/macos/darwin/') |
| 36 | + ARCH=$(echo "${{ runner.arch }}" | sed -E 's/X64/x86_64/; s/ARM64/aarch64/') |
| 37 | + ASSET="kwctl-${OS}-${ARCH}" |
| 38 | +
|
| 39 | + INSTALL_DIR=$HOME/.kwctl |
| 40 | + RELEASE_URL="download/${{ inputs.KWCTL_VERSION }}" |
| 41 | + [ "${{ inputs.KWCTL_VERSION }}" == "latest" ] && RELEASE_URL="latest/download" |
| 42 | +
|
| 43 | + mkdir -p $INSTALL_DIR |
| 44 | + curl -sL https://github.com/kubewarden/kwctl/releases/$RELEASE_URL/$ASSET.zip -o $INSTALL_DIR/$ASSET.zip |
| 45 | + unzip -o $INSTALL_DIR/$ASSET.zip -d $INSTALL_DIR |
| 46 | + rm $INSTALL_DIR/$ASSET.zip |
| 47 | +
|
| 48 | + mv $INSTALL_DIR/$ASSET $INSTALL_DIR/kwctl |
| 49 | + chmod 755 $INSTALL_DIR/kwctl |
| 50 | + echo $INSTALL_DIR >> $GITHUB_PATH |
| 51 | +
|
| 52 | + $INSTALL_DIR/kwctl -V |
| 53 | + - name: Install bats |
| 54 | + shell: bash |
| 55 | + run: sudo apt install -y bats |
| 56 | + - name: Install SBOM generator tool |
| 57 | + shell: bash |
| 58 | + if: ${{ inputs.arch != 'windows_amd64' }} |
| 59 | + run: | |
| 60 | + #!/bin/bash |
| 61 | + set -e |
| 62 | +
|
| 63 | + INSTALL_DIR=$HOME/.syft |
| 64 | +
|
| 65 | + mkdir -p $INSTALL_DIR |
| 66 | +
|
| 67 | + curl -sL https://github.com/anchore/syft/releases/download/v${{ inputs.SYFT_VERSION }}/syft_${{ inputs.SYFT_VERSION }}_${{ inputs.arch }}.tar.gz -o $INSTALL_DIR/syft.tar.gz |
| 68 | + tar xvf $INSTALL_DIR/syft.tar.gz -C $INSTALL_DIR |
| 69 | + rm $INSTALL_DIR/syft.tar.gz |
| 70 | +
|
| 71 | + echo $INSTALL_DIR >> $GITHUB_PATH |
| 72 | +
|
| 73 | + - name: Install SBOM generator tool |
| 74 | + shell: bash |
| 75 | + if: ${{ inputs.arch == 'windows_amd64' }} |
| 76 | + run: | |
| 77 | + #!/bin/bash |
| 78 | + set -e |
| 79 | +
|
| 80 | + INSTALL_DIR=$HOME/.syft |
| 81 | +
|
| 82 | + mkdir -p $INSTALL_DIR |
| 83 | +
|
| 84 | + curl -sL https://github.com/anchore/syft/releases/download/v${{ inputs.SYFT_VERSION }}/syft_${{ inputs.SYFT_VERSION }}_windows_amd64.zip -o $INSTALL_DIR/syft.zip |
| 85 | + unzip -n $INSTALL_DIR/syft.zip -d $INSTALL_DIR |
| 86 | + rm $INSTALL_DIR/syft.zip |
| 87 | +
|
| 88 | + echo $INSTALL_DIR >> $GITHUB_PATH |
| 89 | + - name: Install binaryen tool |
| 90 | + shell: bash |
| 91 | + run: | |
| 92 | + #!/bin/bash |
| 93 | + set -e |
| 94 | +
|
| 95 | + INSTALL_DIR=$HOME/.binaryen |
| 96 | +
|
| 97 | + mkdir -p $INSTALL_DIR |
| 98 | +
|
| 99 | + curl -sL https://github.com/WebAssembly/binaryen/releases/download/version_${{ inputs.BINARYEN_VERSION }}/binaryen-version_${{ inputs.BINARYEN_VERSION }}-x86_64-linux.tar.gz -o $INSTALL_DIR/binaryen.tar.gz |
| 100 | + tar xvf $INSTALL_DIR/binaryen.tar.gz -C $INSTALL_DIR |
| 101 | + mv $INSTALL_DIR/binaryen-version_${{ inputs.BINARYEN_VERSION }}/bin/* $INSTALL_DIR |
| 102 | + rm $INSTALL_DIR/binaryen.tar.gz |
| 103 | + rm -rf $INSTALL_DIR/binaryen-version_${{ inputs.BINARYEN_VERSION }} |
| 104 | +
|
| 105 | + echo $INSTALL_DIR >> $GITHUB_PATH |
| 106 | + - name: Setup rust toolchain |
| 107 | + run: | |
| 108 | + rustup toolchain install stable --profile minimal --target wasm32-wasip1 |
| 109 | + rustup override set stable |
| 110 | + shell: bash |
| 111 | + - name: Install tinygo |
| 112 | + shell: bash |
| 113 | + run: | |
| 114 | + wget https://github.com/tinygo-org/tinygo/releases/download/v0.39.0/tinygo_0.39.0_amd64.deb |
| 115 | + sudo dpkg -i tinygo_0.39.0_amd64.deb |
| 116 | + - name: Install semver tool |
| 117 | + shell: bash |
| 118 | + run: | |
| 119 | + INSTALL_DIR="$HOME"/.semver |
| 120 | + mkdir -p "$INSTALL_DIR" |
| 121 | + wget -O "$INSTALL_DIR"/semver https://github.com/fsaintjacques/semver-tool/raw/3.4.0/src/semver |
| 122 | + chmod +x "$INSTALL_DIR"/semver |
| 123 | + echo "$INSTALL_DIR" >> "$GITHUB_PATH" |
| 124 | + - name: Install updatecli |
| 125 | + uses: updatecli/updatecli-action@719e3592d124cbf826da704cbe557e1221dd4bba # v2.94.0 |
0 commit comments