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 (
|
|
|
|
"github.com/roddhjav/apparmor.d/pkg/prebuild/cfg"
|
|
|
|
"github.com/roddhjav/apparmor.d/pkg/util"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
regFullSystemPolicy = util.ToRegexRepl([]string{
|
|
|
|
`r(PU|U)x,`, `rPx,`,
|
|
|
|
})
|
|
|
|
)
|
|
|
|
|
|
|
|
type FullSystemPolicy struct {
|
|
|
|
cfg.Base
|
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
RegisterBuilder(&FullSystemPolicy{
|
|
|
|
Base: cfg.Base{
|
|
|
|
Keyword: "fsp",
|
|
|
|
Msg: "Prevent unconfined transitions in profile rules",
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-05-25 23:32:10 +02:00
|
|
|
func (b FullSystemPolicy) Apply(opt *Option, profile string) (string, error) {
|
2024-05-25 23:30:20 +02:00
|
|
|
return regFullSystemPolicy.Replace(profile), nil
|
2024-03-26 00:16:00 +01:00
|
|
|
}
|