aboutsummaryrefslogtreecommitdiff
path: root/pkg/apparmor/apparmor_linux.go
diff options
context:
space:
mode:
authorSascha Grunert <sgrunert@suse.com>2019-07-18 10:01:45 +0200
committerSascha Grunert <sgrunert@suse.com>2019-07-18 13:14:02 +0200
commit27ebd7d6f074620992be2fe3046cc188701d439f (patch)
tree1752abc11c31b49ebb102a0fb1967d4c66738d38 /pkg/apparmor/apparmor_linux.go
parent7488ed6d9a619d86333dc1880d4df034fbb371b9 (diff)
downloadpodman-27ebd7d6f074620992be2fe3046cc188701d439f.tar.gz
podman-27ebd7d6f074620992be2fe3046cc188701d439f.tar.bz2
podman-27ebd7d6f074620992be2fe3046cc188701d439f.zip
Add DefaultContent API to retrieve apparmor profile content
The default apparmor profile is not stored on disk which causes confusion when debugging the content of the profile. To solve this, we now add an additional API which returns the profile as byte slice. Signed-off-by: Sascha Grunert <sgrunert@suse.com>
Diffstat (limited to 'pkg/apparmor/apparmor_linux.go')
-rw-r--r--pkg/apparmor/apparmor_linux.go13
1 files changed, 13 insertions, 0 deletions
diff --git a/pkg/apparmor/apparmor_linux.go b/pkg/apparmor/apparmor_linux.go
index 0d01f41e9..479600408 100644
--- a/pkg/apparmor/apparmor_linux.go
+++ b/pkg/apparmor/apparmor_linux.go
@@ -4,6 +4,7 @@ package apparmor
import (
"bufio"
+ "bytes"
"fmt"
"io"
"os"
@@ -104,6 +105,18 @@ func InstallDefault(name string) error {
return cmd.Wait()
}
+// DefaultContent returns the default profile content as byte slice. The
+// profile is named as the provided `name`. The function errors if the profile
+// generation fails.
+func DefaultContent(name string) ([]byte, error) {
+ p := profileData{Name: name}
+ var bytes bytes.Buffer
+ if err := p.generateDefault(&bytes); err != nil {
+ return nil, err
+ }
+ return bytes.Bytes(), nil
+}
+
// IsLoaded checks if a profile with the given name has been loaded into the
// kernel.
func IsLoaded(name string) (bool, error) {