// apparmor.d - Full set of apparmor profiles // Copyright (C) 2021-2024 Alexandre Pujol // 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.Version < 3.0 { 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 } if prebuild.Version < 4.1 { // 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 }