name: Build Companion Agent on: push: tags: - 'v*.*.*' # Trigger on version tags (v1.0.0, v1.2.3, etc.) jobs: build: runs-on: ubuntu-latest steps: - name: Checkout code uses: actions/checkout@v4 - name: Set up Go uses: actions/setup-go@v4 with: go-version: '1.21' - name: Get version from tag id: version run: echo "VERSION=${GITHUB_REF#refs/tags/}" >> $GITHUB_OUTPUT - name: Build Linux AMD64 run: | cd companion-agent mkdir -p bin GOOS=linux GOARCH=amd64 go build -ldflags "-s -w -X main.version=${{ steps.version.outputs.VERSION }}" -o bin/corrosion-companion-linux-amd64 ./cmd/agent chmod +x bin/corrosion-companion-linux-amd64 - name: Build Windows AMD64 run: | cd companion-agent GOOS=windows GOARCH=amd64 go build -ldflags "-s -w -X main.version=${{ steps.version.outputs.VERSION }}" -o bin/corrosion-companion-windows-amd64.exe ./cmd/agent - name: Generate checksums run: | cd companion-agent/bin sha256sum corrosion-companion-linux-amd64 > checksums.txt sha256sum corrosion-companion-windows-amd64.exe >> checksums.txt cat checksums.txt - name: Create Release env: RELEASE_TOKEN: ${{ secrets.RELEASE_TOKEN }} run: | VERSION=${{ steps.version.outputs.VERSION }} REPO="vantzs/corrosion-admin-panel" API_URL="https://git.corrosionmgmt.com/api/v1" # Create release (parse ID without jq) RESPONSE=$(curl -s -X POST \ -H "Authorization: token ${RELEASE_TOKEN}" \ -H "Content-Type: application/json" \ -d "{\"tag_name\": \"${VERSION}\", \"name\": \"Companion Agent ${VERSION}\", \"body\": \"Companion Agent release ${VERSION}\", \"draft\": false, \"prerelease\": false}" \ "${API_URL}/repos/${REPO}/releases") RELEASE_ID=$(echo "$RESPONSE" | grep -o '"id":[0-9]*' | head -1 | grep -o '[0-9]*') if [ -z "$RELEASE_ID" ]; then echo "ERROR: Failed to create release. Response:" echo "$RESPONSE" exit 1 fi echo "Release created with ID: ${RELEASE_ID}" # Upload Linux binary curl -s -X POST \ -H "Authorization: token ${RELEASE_TOKEN}" \ -H "Content-Type: application/octet-stream" \ --data-binary @companion-agent/bin/corrosion-companion-linux-amd64 \ "${API_URL}/repos/${REPO}/releases/${RELEASE_ID}/assets?name=corrosion-companion-linux-amd64" # Upload Windows binary curl -s -X POST \ -H "Authorization: token ${RELEASE_TOKEN}" \ -H "Content-Type: application/octet-stream" \ --data-binary @companion-agent/bin/corrosion-companion-windows-amd64.exe \ "${API_URL}/repos/${REPO}/releases/${RELEASE_ID}/assets?name=corrosion-companion-windows-amd64.exe" # Upload checksums curl -s -X POST \ -H "Authorization: token ${RELEASE_TOKEN}" \ -H "Content-Type: application/octet-stream" \ --data-binary @companion-agent/bin/checksums.txt \ "${API_URL}/repos/${REPO}/releases/${RELEASE_ID}/assets?name=checksums.txt" - name: Build Summary run: | echo "## Companion Agent Build Complete" >> $GITHUB_STEP_SUMMARY echo "" >> $GITHUB_STEP_SUMMARY echo "**Version:** ${{ steps.version.outputs.VERSION }}" >> $GITHUB_STEP_SUMMARY echo "**Commit:** ${GITHUB_SHA:0:7}" >> $GITHUB_STEP_SUMMARY echo "" >> $GITHUB_STEP_SUMMARY echo "### Built Artifacts:" >> $GITHUB_STEP_SUMMARY echo "- Linux AMD64 ($(stat -c%s companion-agent/bin/corrosion-companion-linux-amd64) bytes)" >> $GITHUB_STEP_SUMMARY echo "- Windows AMD64 ($(stat -c%s companion-agent/bin/corrosion-companion-windows-amd64.exe) bytes)" >> $GITHUB_STEP_SUMMARY echo "- SHA256 checksums" >> $GITHUB_STEP_SUMMARY