From 2528b758e496b0913c89090372c8a1f184849fc1 Mon Sep 17 00:00:00 2001 From: Ward Nakchbandi Date: Sat, 25 Feb 2023 11:26:00 +0300 Subject: [PATCH] add github builder --- .github/workflows/release.yml | 40 +++++++++++++++++++++++++++++++++++ main.sh | 19 +++++++++++++++++ release.sh | 14 ++++++++++++ 3 files changed, 73 insertions(+) create mode 100644 .github/workflows/release.yml create mode 100755 main.sh create mode 100755 release.sh diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000..46b480c --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,40 @@ +name: PikaOS Package Release + +on: + workflow_dispatch + +jobs: + build: + runs-on: self-hosted + container: + image: ubuntu:22.10 + volumes: + - /proc:/proc + options: --privileged -it + + steps: + - uses: actions/checkout@v3 + + - name: Install needed packages + run: apt update && apt install software-properties-common sudo git bc gpg gpg-agent bison build-essential ccache cpio fakeroot flex git kmod libelf-dev libncurses5-dev libssl-dev lz4 qtbase5-dev rsync schedtool wget zstd tar reprepro dpkg-sig devscripts -y + + - name: Import GPG key + id: import_gpg + uses: crazy-max/ghaction-import-gpg@v5 + with: + gpg_private_key: ${{ secrets.GPG_PRIVATE_KEY }} + passphrase: ${{ secrets.PASSPHRASE }} + + - name: Install SSH key + uses: shimataro/ssh-key-action@v2 + with: + key: ${{ secrets.SSH_KEY }} + name: id_rsa + known_hosts: ${{ secrets.KNOWN_HOSTS }} + if_key_exists: replace + + - name: Build Package + run: ./main.sh + + - name: Release Package + run: ./release.sh diff --git a/main.sh b/main.sh new file mode 100755 index 0000000..311fd0e --- /dev/null +++ b/main.sh @@ -0,0 +1,19 @@ +# Add dependent repositories +wget -q -O - https://ppa.pika-os.com/key.gpg | sudo apt-key add - +add-apt-repository https://ppa.pika-os.com +add-apt-repository ppa:pikaos/pika +add-apt-repository ppa:kubuntu-ppa/backports +# Clone Upstream +cd ./pika-kde-settings + +# Get build deps +apt-get build-dep ./ -y + +# Build package +dh_make --createorig +dpkg-buildpackage + +# Move the debs to output +cd ../ +mkdir -p ./output +mv ./*.deb ./output/ diff --git a/release.sh b/release.sh new file mode 100755 index 0000000..b927db0 --- /dev/null +++ b/release.sh @@ -0,0 +1,14 @@ +# Sign the packages +dpkg-sig --sign builder ./output/pika-kde-settings*.deb + +# Pull down existing ppa repo db files etc +rsync -azP --exclude '*.deb' ferreo@direct.pika-os.com:/srv/www/pikappa/ ./output/repo + +# Remove our existing package from the repo +reprepro -V --basedir ./output/repo/ removefilter kinetic 'Package (% pika-kde-settings*)' + +# Add the new package to the repo +reprepro -V --basedir ./output/repo/ includedeb kinetic ./output/pika-kde-settings*.deb + +# Push the updated ppa repo to the server +rsync -azP ./output/repo/ ferreo@direct.pika-os.com:/srv/www/pikappa/