Initial commit

This commit is contained in:
Christian Schendel 2025-09-01 05:10:21 +02:00
commit 571395f63e
Signed by: doppelhelix
GPG key ID: 5874D2437CD5BBB3
9 changed files with 177 additions and 0 deletions

13
.SRCINFO Normal file
View file

@ -0,0 +1,13 @@
pkgbase = dalci-keyring
pkgdesc = dalci GPG keyring
pkgver = 20230622
pkgrel = 3
url = http:/dalci.info
install = dalci-keyring.install
arch = any
license = GPL-3.0-or-later
source = dalci-keyring-20230622.tar.xz
validpgpkeys = 47D15FC0F6AD8433CD06B4DF5874D2437CD5BBB3
b2sums = 8344190e30df709352713d73ae0beb33b35af4813e880999e4e26dbb6ee08ede64762d8645b8d774d00a3a168aba9269048f14b6494a7856300887f277752aa6
pkgname = dalci-keyring

18
.gitignore vendored Normal file
View file

@ -0,0 +1,18 @@
# Ignore everything
*
# But not these files...
!.gitignore
!PKGBUILD
!.SRCINFO
!LICENSE
!chroot-build
!.nvchecker.toml
!/keys
!/keys/pgp
!/keys/pgp/*.asc
!/LICENSES
!/LICENSES/*.txt
!REUSE.toml
!dalci-keyring-20230622.tar.xz
!*.install

12
LICENSE Normal file
View file

@ -0,0 +1,12 @@
Copyright Arch Linux Contributors
Permission to use, copy, modify, and/or distribute this software for
any purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED “AS IS” AND THE AUTHOR DISCLAIMS ALL
WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES
OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE
FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY
DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.

1
LICENSES/0BSD.txt Symbolic link
View file

@ -0,0 +1 @@
../LICENSE

24
PKGBUILD Normal file
View file

@ -0,0 +1,24 @@
# Maintainer: Christian Schendel <doppelhelix@gmail.com>
# Based on the file created for Arch Linux by:
# Pierre Schmitz <pierre@archlinux.de>
pkgname=dalci-keyring
pkgver=20230622
pkgrel=3
pkgdesc='dalci GPG keyring'
arch=('any')
url='http:/dalci.info'
license=(
GPL-3.0-or-later
)
install="${pkgname}.install"
source=('dalci-keyring-20230622.tar.xz')
b2sums=('8344190e30df709352713d73ae0beb33b35af4813e880999e4e26dbb6ee08ede64762d8645b8d774d00a3a168aba9269048f14b6494a7856300887f277752aa6')
validpgpkeys=('47D15FC0F6AD8433CD06B4DF5874D2437CD5BBB3') # christian
package() {
cd "${srcdir}"
make PREFIX=/usr DESTDIR="${pkgdir}" install
}
# vim: set ft=sh ts=4 sw=4 et:

30
REUSE.toml Normal file
View file

@ -0,0 +1,30 @@
version = 1
[[annotations]]
path = [
"PKGBUILD",
"README.md",
"keys/**",
".SRCINFO",
".nvchecker.toml",
".gitignore",
"*.install",
"*.sysusers",
"*.tmpfiles",
"*.logrotate",
"*.pam",
"*.service",
"*.socket",
"*.timer",
"*.desktop",
"*.hook",
]
SPDX-FileCopyrightText = "Arch Linux contributors"
SPDX-License-Identifier = "0BSD"
[[annotations]]
path = [
"dalci-keyring-20230622.tar.xz",
]
SPDX-FileCopyrightText = "Christian Schendel <doppelhelix@gmail.com>"
SPDX-License-Identifier = "0BSD"

65
chroot-build Executable file
View file

@ -0,0 +1,65 @@
#!/bin/bash
# SPDX-FileCopyrightText: Christian Schendel
# SPDX-License-Identifier: 0BSD
set -euo pipefail
use_tmpfs=true
CHROOT="/tmp/mkarchroot"
check_available_ram() {
if [ "$(awk '/^MemAvailable:/ { print $2; }' /proc/meminfo)" -lt 50000 ]; then
use_tmpfs=false
fi
}
create_chroot_directory() {
if [ $use_tmpfs ]; then
sudo mount --mkdir -t tmpfs -o defaults,size=20G tmpfs $CHROOT
else
sudo mkdir -p "$CHROOT"
fi
}
create_chroot_environment() {
if [[ ! -d "$CHROOT/root" ]]; then
mkarchroot -M ~/.config/pacman/makepkg.conf "$CHROOT/root" base-devel
fi
}
build_package(){
arch-nspawn "$CHROOT/root" pacman -Syu
if makechrootpkg -c -r "$CHROOT" -- -Asf . ; then
makepkg --printsrcinfo >.SRCINFO
else
delete_chroot_environment && echo -e "\n\e[1;31m==> BUILD FAILED: \e[1;37m$CHROOT removed\e[0m " && exit 1
fi
}
sign_package(){
PACKAGE="$(makepkg --packagelist)"
gpg --use-agent --output "$PACKAGE.sig" --detach-sign "$PACKAGE"
}
delete_chroot_environment() {
if [ "$(stat -f --format=%T "$CHROOT")" == "btrfs" ]; then
{
sudo btrfs subvolume delete "$CHROOT/root/var/lib/portables"
sudo btrfs subvolume delete "$CHROOT/root/var/lib/machines"
sudo btrfs subvolume delete "$CHROOT/root"
sudo rm -Rf $CHROOT
} >>/dev/null 2>&1
elif [ "$(stat -f --format=%T "$CHROOT")" == "tmpfs" ]; then
sudo umount -f $CHROOT
fi
sudo rm -Rf $CHROOT
}
check_available_ram
create_chroot_directory
create_chroot_environment
build_package
sign_package
delete_chroot_environment
# vim: set ts=4 sw=4 et:

Binary file not shown.

14
dalci-keyring.install Normal file
View file

@ -0,0 +1,14 @@
post_upgrade() {
if usr/bin/pacman-key -l >/dev/null 2>&1; then
usr/bin/pacman-key --populate dalci
else
echo " >>> Run \`pacman-key --init\` to set up your pacman keyring."
echo " >>> Then run \`pacman-key --populate dalci\` to install the dalci keyring."
fi
}
post_install() {
if [ -x usr/bin/pacman-key ]; then
post_upgrade
fi
}