feat(aa): use profile guideline to sort file rules.

This commit is contained in:
Alexandre Pujol 2023-09-30 13:54:04 +01:00
parent 4dfc1388e3
commit c0bc903101
Failed to generate hash of commit
4 changed files with 57 additions and 11 deletions

View file

@ -219,7 +219,7 @@ var (
"operation": "open", "operation": "open",
"class": "file", "class": "file",
"profile": "gsd-print-notifications", "profile": "gsd-print-notifications",
"name": "/proc/4163/cgroup", "name": "@{PROC}/4163/cgroup",
"comm": "gsd-print-notif", "comm": "gsd-print-notif",
"requested_mask": "r", "requested_mask": "r",
"denied_mask": "r", "denied_mask": "r",
@ -236,7 +236,7 @@ var (
} }
file2 = &File{ file2 = &File{
Qualifier: Qualifier{Owner: true, NoNewPrivs: true}, Qualifier: Qualifier{Owner: true, NoNewPrivs: true},
Path: "/proc/4163/cgroup", Path: "@{PROC}/4163/cgroup",
Access: "r", Access: "r",
Target: "", Target: "",
} }

View file

@ -4,6 +4,10 @@
package aa package aa
import (
"strings"
)
type File struct { type File struct {
Qualifier Qualifier
Path string Path string
@ -22,16 +26,30 @@ func FileFromLog(log map[string]string) ApparmorRule {
func (r *File) Less(other any) bool { func (r *File) Less(other any) bool {
o, _ := other.(*File) o, _ := other.(*File)
if r.Qualifier.Equals(o.Qualifier) { letterR := ""
letterO := ""
for _, letter := range fileAlphabet {
if strings.HasPrefix(r.Path, letter) {
letterR = letter
}
if strings.HasPrefix(o.Path, letter) {
letterO = letter
}
}
if fileWeights[letterR] == fileWeights[letterO] || letterR == "" || letterO == "" {
if r.Path == o.Path { if r.Path == o.Path {
if r.Qualifier.Equals(o.Qualifier) {
if r.Access == o.Access { if r.Access == o.Access {
return r.Target < o.Target return r.Target < o.Target
} }
return r.Access < o.Access return r.Access < o.Access
} }
return r.Qualifier.Less(o.Qualifier)
}
return r.Path < o.Path return r.Path < o.Path
} }
return r.Qualifier.Less(o.Qualifier) return fileWeights[letterR] < fileWeights[letterO]
} }
func (r *File) Equals(other any) bool { func (r *File) Equals(other any) bool {
@ -39,4 +57,3 @@ func (r *File) Equals(other any) bool {
return r.Path == o.Path && r.Access == o.Access && return r.Path == o.Path && r.Access == o.Access &&
r.Target == o.Target && r.Qualifier.Equals(o.Qualifier) r.Target == o.Target && r.Qualifier.Equals(o.Qualifier)
} }

View file

@ -139,8 +139,38 @@ func TestRule_Less(t *testing.T) {
name: "file", name: "file",
rule: file1, rule: file1,
other: file2, other: file2,
want: true,
},
{
name: "file/empty",
rule: &File{},
other: &File{},
want: false, want: false,
}, },
{
name: "file/equal",
rule: &File{Path: "/usr/share/poppler/cMap/Identity-H"},
other: &File{Path: "/usr/share/poppler/cMap/Identity-H"},
want: false,
},
{
name: "file/owner",
rule: &File{Path: "/usr/share/poppler/cMap/Identity-H", Qualifier: Qualifier{Owner: true}},
other: &File{Path: "/usr/share/poppler/cMap/Identity-H"},
want: true,
},
{
name: "file/access",
rule: &File{Path: "/usr/share/poppler/cMap/Identity-H", Access: "r"},
other: &File{Path: "/usr/share/poppler/cMap/Identity-H", Access: "w"},
want: true,
},
{
name: "file/close",
rule: &File{Path: "/usr/share/poppler/cMap/"},
other: &File{Path: "/usr/share/poppler/cMap/Identity-H"},
want: true,
},
} }
for _, tt := range tests { for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) { t.Run(tt.name, func(t *testing.T) {

View file

@ -90,9 +90,8 @@ var (
"/opt", // 2.3 opt binaries & libraries "/opt", // 2.3 opt binaries & libraries
"/usr/share", // 3. shared data "/usr/share", // 3. shared data
"/etc", // 4. system configuration "/etc", // 4. system configuration
"/", // 5.1 system data "/var", // 5.1 system read/write data
"/var", // 5.2 system data read/write data "/boot", // 5.2 boot files
"/boot", // 5.3 boot files
"/home", // 6.1 user data "/home", // 6.1 user data
"@{HOME}", // 6.2 home files "@{HOME}", // 6.2 home files
"@{user_cache_dirs}", // 7.1 user caches "@{user_cache_dirs}", // 7.1 user caches