Skip to content
name: Build and Upload HSM Engine
on:
push:
branches:
- main
jobs:
build:
runs-on: ubuntu-24.04
steps:
- name: Checkout repository
uses: actions/checkout@v2
- name: Install Dependencies
run: |
sudo apt-get update
sudo apt-get install -y build-essential libssl-dev libcurl4-openssl-dev libjson-c-dev cmake devscripts dpkg-dev gnupg lintian
- name: Build HSM Engine
run: |
cd src
mkdir -p build
cd build
cmake ..
make
- name: Create DEBIAN Directory and Control File
run: |
mkdir -p ~/hsm-engine-deb/DEBIAN
echo "Package: hsm-engine" > ~/hsm-engine-deb/DEBIAN/control
echo "Version: 1.0-1" >> ~/hsm-engine-deb/DEBIAN/control
echo "Section: utils" >> ~/hsm-engine-deb/DEBIAN/control
echo "Priority: optional" >> ~/hsm-engine-deb/DEBIAN/control
echo "Architecture: amd64" >> ~/hsm-engine-deb/DEBIAN/control
echo "Maintainer: Andrey V <[email protected]>" >> ~/hsm-engine-deb/DEBIAN/control
echo "Description: Azure Key Vault and Managed HSM Engine for OpenSSL" >> ~/hsm-engine-deb/DEBIAN/control
- name: Install HSM Engine and Package
run: |
cd src/build
make install DESTDIR=~/hsm-engine-deb
- name: Build Source Package
run: |
cd ~/hsm-engine-deb
debuild -S -sa
- name: Sign and Upload to PPA
env:
GPG_KEY: ${{ secrets.GPG_PRIVATE_KEY }}
GPG_PASSPHRASE: ${{ secrets.GPG_PASSPHRASE }}
LAUNCHPAD_USERNAME: ${{ secrets.LAUNCHPAD_USERNAME }}
run: |
echo "${GPG_KEY}" | gpg --batch --import
echo "passphrase=${GPG_PASSPHRASE}" > ~/.gnupg/gpg.conf
echo "use-agent" >> ~/.gnupg/gpg.conf
debsign --re-sign -k${{ secrets.GPG_KEY_ID }} hsm-engine_1.0-1_amd64.changes
dput ppa:${{ secrets.LAUNCHPAD_USERNAME }}/kima-hsm-ppa hsm-engine_1.0-1_amd64.changes