apparmor.d/pkg/prebuild/prepare/configure.go

97 lines
2 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/prebuild"
)
type Configure struct {
prebuild.Base
}
func init() {
RegisterTask(&Configure{
Base: prebuild.Base{
Keyword: "configure",
Msg: "Set distribution specificities",
},
})
}
func removeFiles(files []string) error {
for _, name := range files {
if err := prebuild.RootApparmord.Join(name).RemoveAll(); err != nil {
return err
}
}
return nil
}
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 := prebuild.DistDir.Join("ubuntu").CopyFS(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 := prebuild.DistDir.Join("ubuntu").CopyFS(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 := []string{
// Remove files upstreamed in 4.1
"abstractions/devices-usb-read",
"abstractions/devices-usb",
"abstractions/nameservice-strict",
"tunables/multiarch.d/base",
// Direct upstream contributed profiles, similar to ours
"wg",
}
if err := removeFiles(remove); err != nil {
return res, err
}
}
if prebuild.Version >= 5.0 {
remove := []string{
// Direct upstrem contributed profiles, similar to ours
"dig",
"free",
"nslookup",
"who",
}
if err := removeFiles(remove); err != nil {
return res, err
}
}
return res, nil
}