mirror of
https://github.com/roddhjav/apparmor.d.git
synced 2024-11-14 23:43:56 +01:00
62 lines
1.5 KiB
Bash
62 lines
1.5 KiB
Bash
# Maintainer: Alexandre Pujol <alexandre@pujol.io>
|
|
# shellcheck disable=SC2034,SC2154,SC2164
|
|
|
|
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')
|
|
|
|
pkgver() {
|
|
cd "$srcdir/$pkgname"
|
|
echo "0.$(git rev-list --count HEAD)"
|
|
}
|
|
|
|
prepare() {
|
|
git clone "$startdir" "$srcdir/$pkgname"
|
|
cd "$srcdir/$pkgname"
|
|
|
|
./configure
|
|
}
|
|
|
|
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
|
|
}
|