Skip to content

Merge pull request #1 from BloodHoundAD/dev #3

Merge pull request #1 from BloodHoundAD/dev

Merge pull request #1 from BloodHoundAD/dev #3

Workflow file for this run

name: Release
on:
push:
tags: ["v[0-9]+.[0-9]+.[0-9]+"]
branches: ["dev"]
jobs:
linux-windows-build:
name: CSharp Build
if: startsWith( github.ref, 'refs/tags/v')
runs-on: windows-latest
timeout-minutes: 45
steps:
- name: Add msbuild to PATH
uses: microsoft/setup-msbuild@v1.1
- name: Check out code
uses: actions/checkout@v3
- uses: actions/setup-dotnet@v3
with:
dotnet-version: '5.0.x'
- name: Git Fetch Tags
run: git fetch --prune --unshallow --tags -f
- name: Download Tools
run: |
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
Invoke-WebRequest -Uri https://github.com/stedolan/jq/releases/download/jq-1.6/jq-win64.exe -OutFile jq.exe
Invoke-WebRequest -Uri https://github.com/moloch--/minisign/releases/download/v0.2.1/minisign.exe -OutFile minisign.exe
- name: dotnet build
run: |
dotnet restore
dotnet build -c Release
mkdir compiled
cp .\bin\Release\net462\SharpHound.exe .\compiled
- name: Build Package
# Powershell is utter fucking trash.
run: |
$Version = git.exe describe --tags --abbrev=0
$Version = "`"$Version`""
Get-Content -Path alias.json | .\jq.exe ".version |= `"$Version`"" > .\compiled\alias.json
cd .\compiled
tar.exe -czvf ..\sharp-hound-4.tar.gz .\alias.json .\SharpHound.exe
- name: Sign Package
run: |
Write-Output "${{ secrets.MINISIGN_PRIVATE_KEY }}" > minisign.key
$Content1 = Get-Content -Path .\compiled\alias.json
$Bytes = [System.Text.Encoding]::UTF8.GetBytes($Content1)
$Encoded = [System.Convert]::ToBase64String($Bytes)
.\minisign.exe -s minisign.key -S -m sharp-hound-4.tar.gz -t "$Encoded" -x sharp-hound-4.minisig
- name: "Publish Release"
uses: "marvinpinto/action-automatic-releases@latest"
with:
repo_token: "${{ secrets.GITHUB_TOKEN }}"
prerelease: false
files: |
sharp-hound-4.minisig
sharp-hound-4.tar.gz