Skip to content

Commit

Permalink
i/builtin: allow @ in custom-device filepaths (#14651)
Browse files Browse the repository at this point in the history
* i/builtin: allow @ in custom-device filepaths

Signed-off-by: Oliver Calder <[email protected]>

* i/builtin: disallow @{ in custom-device file paths

AppArmor variables take the form @{foo} in rules, so we cannot allow a
specified filepath to contain substrings of this form. Such paths should
never be necessary.

Signed-off-by: Oliver Calder <[email protected]>

---------

Signed-off-by: Oliver Calder <[email protected]>
  • Loading branch information
olivercalder authored Nov 14, 2024
1 parent 1d38c1c commit db0e079
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 7 deletions.
12 changes: 9 additions & 3 deletions interfaces/builtin/custom_device.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// -*- Mode: Go; indent-tabs-mode: t -*-

/*
* Copyright (C) 2022 Canonical Ltd
* Copyright (C) 2022-2024 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
Expand Down Expand Up @@ -51,8 +51,14 @@ var (
// A cryptic, uninformative error message that we use only on impossible code paths
customDeviceInternalError = errors.New(`custom-device interface internal error`)

// Validating regexp for filesystem paths
customDevicePathRegexp = regexp.MustCompile(`^/[^"@]*$`)
// Validating regexp for filesystem paths. @ can appear in paths under
// /sys/devices for devices that are defined in the device tree (of the
// form device@address), so we need to support @ characters in paths.
// However, @{foo} is the format for variables in AppArmor, so we must
// disallow `@{`. For completeness, we allow paths with a trailing @ as
// well. This is not the case for common-files-derived interfaces, since
// these append {,/,/**} pattern to the end of filepath.
customDevicePathRegexp = regexp.MustCompile(`^/([^"@]|@[^{])*@?$`)

// Validating regexp for udev device names.
// We forbid:
Expand Down
18 changes: 14 additions & 4 deletions interfaces/builtin/custom_device_test.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// -*- Mode: Go; indent-tabs-mode: t -*-

/*
* Copyright (C) 2022 Canonical Ltd
* Copyright (C) 2022-2024 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
Expand Down Expand Up @@ -72,9 +72,11 @@ slots:
read-devices:
- /dev/js*
files:
write: [ /bar ]
write: [ /bar, /baz@qux, /trailing@ ]
read:
- /dev/input/by-id/*
- /dev/dma_heap/qcom,qseecom
- /sys/devices/platform/soc@0/soc@0:bus@30000000/30350000.ocotp-ctrl/imx-ocotp0/nvmem
udev-tagging:
- kernel: input/mice
subsystem: input
Expand Down Expand Up @@ -209,8 +211,12 @@ apps:
`custom-device "devices" path contains invalid glob pattern "\*\*"`,
},
{
"devices: [/dev/@foo]",
`custom-device "devices" path must start with / and cannot contain special characters.*`,
`devices: ["/dev/@{foo}"]`,
`custom-device "devices" path must start with /dev/ and cannot contain special characters.*`,
},
{
`devices: ["/dev/@{foo"]`,
`custom-device "devices" path must start with /dev/ and cannot contain special characters.*`,
},
{
"devices: [/dev/foo|bar]",
Expand Down Expand Up @@ -405,7 +411,11 @@ func (s *CustomDeviceInterfaceSuite) TestAppArmorSpec(c *C) {
c.Check(plugSnippet, testutil.Contains, `"/dev/input/mice" rwk,`)
c.Check(plugSnippet, testutil.Contains, `"/dev/js*" r,`)
c.Check(plugSnippet, testutil.Contains, `"/bar" rw,`)
c.Check(plugSnippet, testutil.Contains, `"/baz@qux" rw,`)
c.Check(plugSnippet, testutil.Contains, `"/trailing@" rw,`)
c.Check(plugSnippet, testutil.Contains, `"/dev/input/by-id/*" r,`)
c.Check(plugSnippet, testutil.Contains, `"/dev/dma_heap/qcom,qseecom" r,`)
c.Check(plugSnippet, testutil.Contains, `"/sys/devices/platform/soc@0/soc@0:bus@30000000/30350000.ocotp-ctrl/imx-ocotp0/nvmem" r,`)
c.Check(slotSnippet, HasLen, 0)
}

Expand Down

0 comments on commit db0e079

Please sign in to comment.