diff options
author | Michał Górny <mgorny@gentoo.org> | 2020-01-19 13:39:34 +0100 |
---|---|---|
committer | Michał Górny <mgorny@gentoo.org> | 2020-01-19 21:09:53 +0100 |
commit | acb2659d5d3c67579105d0b297dfda4bc92edf47 (patch) | |
tree | b4a7c3e9cf9f2218bfdfb5dc4224ff4f42bb5372 | |
parent | Rekeywording & stabilization rules (diff) | |
download | policy-guide-acb2659d5d3c67579105d0b297dfda4bc92edf47.tar.gz policy-guide-acb2659d5d3c67579105d0b297dfda4bc92edf47.tar.bz2 policy-guide-acb2659d5d3c67579105d0b297dfda4bc92edf47.zip |
filesystem: Policy against absolute symlink targets
Closes: https://bugs.gentoo.org/705830
Closes: https://github.com/gentoo/policy-guide/pull/5
Signed-off-by: Michał Górny <mgorny@gentoo.org>
-rw-r--r-- | filesystem.rst | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/filesystem.rst b/filesystem.rst index 9173042..081ab99 100644 --- a/filesystem.rst +++ b/filesystem.rst @@ -154,3 +154,29 @@ inconsistent with the use in other distributions where it was used to share data files. Since the latter implied users must not be added to the games group, a new group (gamestat) needed to be created to fulfill that purpose. + + +.. index:: symbolic link; absolute target + +Absolute symbolic link targets +------------------------------ +:Source: QA +:Reported: by repoman and pkgcheck (when ebuild-generated) + +Packages must not install symbolic links with absolute targets. +Instead, relative paths must be used. An exception is granted +for symlinks to specially mounted filesystems (such as /proc, /run) +when symlinks are supposed to always reference the running host system. + +*Example*:: + + # BAD: + dosym /usr/lib/frobnicate/frobnicate /usr/bin/frobnicate + # GOOD: + dosym ../lib/frobnicate/frobnicate /usr/bin/frobnicate + # ACCEPTABLE EXCEPTION: + dosym /proc/self/mounts /etc/mtab + +*Rationale*: absolute symlinks work correctly only when the root +filesystem is mounted at /. They point at the wrong location whenever +it is mounted in another location, e.g. for the purposes of recovery. |