apparmor.d/pkg/prebuild/prepare/configure.go
Alexandre Pujol e4a7e16ec0
build: add support for apparmor 4.1
Enabled when prebuild is run with the --version 4.1 argument
2025-03-14 22:07:59 +01:00

75 lines
1.6 KiB
Go

// apparmor.d - Full set of apparmor profiles
// Copyright (C) 2021-2024 Alexandre Pujol <alexandre@pujol.io>
// SPDX-License-Identifier: GPL-2.0-only
package prepare
import (
"fmt"
"github.com/roddhjav/apparmor.d/pkg/paths"
"github.com/roddhjav/apparmor.d/pkg/prebuild"
)
type Configure struct {
prebuild.Base
}
func init() {
RegisterTask(&Configure{
Base: prebuild.Base{
Keyword: "configure",
Msg: "Set distribution specificities",
},
})
}
func (p Configure) Apply() ([]string, error) {
res := []string{}
switch prebuild.Distribution {
case "arch", "opensuse":
case "ubuntu":
if err := prebuild.DebianHide.Init(); err != nil {
return res, err
}
if prebuild.ABI == 3 {
if err := paths.CopyTo(prebuild.DistDir.Join("ubuntu"), prebuild.RootApparmord); err != nil {
return res, err
}
}
case "debian", "whonix":
if err := prebuild.DebianHide.Init(); err != nil {
return res, err
}
// Copy Debian specific abstractions
if err := paths.CopyTo(prebuild.DistDir.Join("ubuntu"), prebuild.RootApparmord); err != nil {
return res, err
}
default:
return []string{}, fmt.Errorf("%s is not a supported distribution", prebuild.Distribution)
}
if prebuild.Version == "4.1" {
// Remove files upstreamed in 4.1
remove := []string{
"abstractions/devices-usb-read",
"abstractions/devices-usb",
"abstractions/nameservice-strict",
"tunables/multiarch.d/base",
"wg", // Upstream version is identical
}
for _, name := range remove {
if err := prebuild.RootApparmord.Join(name).RemoveAll(); err != nil {
return res, err
}
}
}
return res, nil
}