Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
83 changes: 71 additions & 12 deletions .github/workflows/publish.yml
Original file line number Diff line number Diff line change
@@ -1,16 +1,14 @@
name: Publish

on:
push:
push:
tags:
- "v*.*.*"

- v*.*.*
env:
AZUREHOUND_VERSION: ${{ github.ref_name }}
jobs:
build:
runs-on: ubuntu-latest
defaults:
run:
shell: bash
strategy:
matrix:
os:
Expand All @@ -21,7 +19,7 @@ jobs:
- amd64
- arm64
steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4

- name: Setup Go
uses: actions/setup-go@v3
Expand All @@ -31,11 +29,18 @@ jobs:
cache: true

- name: Build
run: 'go build -ldflags="-s -w -X github.com/bloodhoundad/azurehound/v2/constants.Version=${{ github.ref_name }}"'
run: 'go build -ldflags="-s -w -X github.com/bloodhoundad/azurehound/v2/constants.Version=${{ env.AZUREHOUND_VERSION }}"'
env:
GOOS: ${{ matrix.os }}
GOARCH: ${{ matrix.arch }}

- name: Upload as Artifact
if: matrix.os == 'windows'
uses: actions/upload-artifact@v4
with:
name: azurehound-bin-${{ matrix.os }}-${{ matrix.arch }}
path: azurehound*

- name: Zip
run: 7z a -tzip -mx9 azurehound-${{ matrix.os }}-${{ matrix.arch }}.zip azurehound*

Expand All @@ -49,15 +54,69 @@ jobs:
azurehound-${{ matrix.os }}-${{ matrix.arch }}.zip
azurehound-${{ matrix.os }}-${{ matrix.arch }}.zip.sha256

sign:
runs-on: ubuntu-latest
needs: build
steps:
- uses: aws-actions/configure-aws-credentials@v4
with:
aws-access-key-id: ${{ secrets.BHE_AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.BHE_AWS_SECRET_ACCESS_KEY }}
aws-region: us-east-1

- uses: actions/download-artifact@v4
with:
pattern: azurehound-bin-*
path: unsigned/

- name: Install osslsigncode
run: |
sudo apt-get update
sudo apt-get install -y osslsigncode

- name: Sign Artifacts
env:
CODE_SIGN_CHAIN: ${{ secrets.CODE_SIGN_CHAIN }}
CODE_SIGN_KEY: ${{ secrets.CODE_SIGN_KEY }}
run: |
set -ex

# osslsigncode demands certs and key as file
CERT_FILE=$(mktemp)
KEY_FILE=$(mktemp)
printenv CODE_SIGN_CHAIN > $CERT_FILE
printenv CODE_SIGN_KEY > $KEY_FILE

trap 'rm $CERT_FILE $KEY_FILE' EXIT

mkdir signed
for artifact in unsigned/azurehound-bin-*/azurehound*; do
tgt=$(echo "$artifact" | sed -E 's%.*-([^-]*)/azurehound(.*)%azurehound-\1\2%')
osslsigncode sign \
-certs $CERT_FILE \
-key $KEY_FILE \
-n AzureHound \
-i https://www.specterops.io/ \
-in "$artifact" \
-out "signed/${tgt}"
done

- name: Verify Signed Artifacts
run: |
for artifact in signed/azurehound*; do
osslsigncode verify "$artifact"
done

- name: Upload Artifacts to S3
run: |
aws s3 cp --recursive signed/ s3://${{ secrets.BHE_AWS_BUCKET }}/azurehound-signed/${AZUREHOUND_VERSION}/

containerize:
runs-on: ubuntu-latest
permissions:
packages: write
defaults:
run:
shell: bash
steps:
- uses: actions/checkout@v3
- uses: actions/checkout@v4

- name: Log in to the Container registry
uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9
Expand Down
Loading