apparmor.d/PKGBUILD
2022-10-06 20:56:41 +01:00

65 lines
1.7 KiB
Bash

# Maintainer: Alexandre Pujol <alexandre@pujol.io>
# shellcheck disable=SC2034,SC2154,SC2164
# Warning: for development only, use https://aur.archlinux.org/packages/apparmor.d-git
# for production use.
pkgname=apparmor.d
pkgver=0.001
pkgrel=1
pkgdesc="Full set of apparmor profiles"
arch=("x86_64")
url="https://github.com/roddhjav/$pkgname"
license=('GPL2')
depends=('apparmor')
makedepends=('go' 'git' 'rsync' 'lsb-release')
conflicts=("$pkgname-git")
pkgver() {
cd "$srcdir/$pkgname"
echo "0.$(git rev-list --count HEAD)"
}
prepare() {
rsync -a --delete "$startdir" "$srcdir"
cd "$srcdir/$pkgname"
./configure --complain
}
build() {
cd "$srcdir/$pkgname/"
export CGO_CPPFLAGS="${CPPFLAGS}"
export CGO_CFLAGS="${CFLAGS}"
export CGO_CXXFLAGS="${CXXFLAGS}"
export CGO_LDFLAGS="${LDFLAGS}"
export GOFLAGS="-buildmode=pie -trimpath -ldflags=-linkmode=external -mod=readonly -modcacherw"
go build -o .build/ ./cmd/aa-log
}
package() {
local _build='.build'
cd "$srcdir/$pkgname"
# Install all system files
mapfile -t root < <(find "$_build/root" -type f -printf "%P\n")
for file in "${root[@]}"; do
install -Dm0644 "$_build/root/$file" "$pkgdir/$file"
done
# Install all apparmor profiles
mapfile -t profiles < <(find "$_build/apparmor.d" -type f -printf "%P\n")
for file in "${profiles[@]}"; do
install -Dm0644 "$_build/apparmor.d/$file" "$pkgdir/etc/apparmor.d/$file"
done
# Ensure some systemd services do not start before apparmor rules are loaded
for file in systemd/*; do
service=$(basename "$file")
install -Dm0644 "$file" \
"$pkgdir/usr/lib/systemd/system/$service.d/apparmor.conf"
done
# Internal tool
install -Dm755 .build/aa-log "$pkgdir"/usr/bin/aa-log
}