2024-03-26 00:16:00 +01:00
|
|
|
// apparmor.d - Full set of apparmor profiles
|
|
|
|
// Copyright (C) 2021-2024 Alexandre Pujol <alexandre@pujol.io>
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
|
|
|
|
|
|
|
package builder
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2024-10-23 15:48:47 +02:00
|
|
|
"slices"
|
|
|
|
"strings"
|
2024-03-26 00:16:00 +01:00
|
|
|
|
2024-05-30 20:29:34 +02:00
|
|
|
"github.com/roddhjav/apparmor.d/pkg/paths"
|
2024-10-02 17:22:46 +02:00
|
|
|
"github.com/roddhjav/apparmor.d/pkg/prebuild"
|
2024-03-26 00:16:00 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
// Build the profiles with the following directive applied
|
|
|
|
Builds = []Builder{}
|
|
|
|
|
|
|
|
// Available builders
|
|
|
|
Builders = map[string]Builder{}
|
|
|
|
)
|
|
|
|
|
|
|
|
// Main directive interface
|
|
|
|
type Builder interface {
|
2024-10-02 17:22:46 +02:00
|
|
|
prebuild.BaseInterface
|
2024-05-25 23:32:10 +02:00
|
|
|
Apply(opt *Option, profile string) (string, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Builder options
|
|
|
|
type Option struct {
|
|
|
|
Name string
|
|
|
|
File *paths.Path
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewOption(file *paths.Path) *Option {
|
|
|
|
return &Option{
|
2024-10-23 15:48:47 +02:00
|
|
|
Name: strings.TrimSuffix(file.Base(), ".apparmor.d"),
|
2024-05-25 23:32:10 +02:00
|
|
|
File: file,
|
|
|
|
}
|
2024-03-26 00:16:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func Register(names ...string) {
|
|
|
|
for _, name := range names {
|
|
|
|
if b, present := Builders[name]; present {
|
2024-10-23 15:48:47 +02:00
|
|
|
if !slices.Contains(Builds, b) {
|
|
|
|
Builds = append(Builds, b)
|
|
|
|
}
|
2024-03-26 00:16:00 +01:00
|
|
|
} else {
|
|
|
|
panic(fmt.Sprintf("Unknown builder: %s", name))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-10-23 15:48:47 +02:00
|
|
|
func Unregister(names ...string) {
|
|
|
|
for _, name := range names {
|
|
|
|
for i, b := range Builds {
|
|
|
|
if b.Name() == name {
|
|
|
|
Builds = slices.Delete(Builds, i, i+1)
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-26 00:16:00 +01:00
|
|
|
func RegisterBuilder(d Builder) {
|
|
|
|
Builders[d.Name()] = d
|
|
|
|
}
|
2024-05-25 23:32:10 +02:00
|
|
|
|
|
|
|
func Run(file *paths.Path, profile string) (string, error) {
|
|
|
|
var err error
|
|
|
|
opt := NewOption(file)
|
|
|
|
for _, b := range Builds {
|
|
|
|
profile, err = b.Apply(opt, profile)
|
|
|
|
if err != nil {
|
2024-05-29 22:12:54 +02:00
|
|
|
return "", fmt.Errorf("%s %s: %w", b.Name(), opt.File, err)
|
2024-05-25 23:32:10 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return profile, nil
|
|
|
|
}
|