-
Notifications
You must be signed in to change notification settings - Fork 48
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Manpages (/usr/share/man/man3) owned by wrong user after install #93
Comments
Thanks for the pointer, I did not see that so far - perhaps because packaging tools like rpm and deb have the habit to have a seperate list of files to be grabbed and they name the target owner and permissions alongside. And well, you are right, the tar generation is a bit archaic from a time that "xmlto" was required to generate the manpages. The xmlto xsl stylesheets were always a bit quirky so that the tar file was committed into the source code tree whenever it was successful on my system having checked that with my bare eyes. As the man3 directory is still in the build directory, its content could just as well be copied over to the target area as such. |
Here your are, the install(DIRECTORY man3) is appended to install.cmake when the option is enabled. |
Thanks you for taking the time to look at this, this should make package mantainer's life a bit easier :) Just as a last note, running the install procedure in the first post on the develop branch, the |
After double checking for a new release, the outdir needs to be there. I had some old man3/ in the source tree which did allow me to rebuild many times before I did hit that error myself. Thanks again. |
Description:
When installing a package system-wide on Linux systems, it is common that the build step (
make
) is run as a different user than the install step (make install
). Typically the build step is run as a regular (non-root) user and the install step is run as the root user.In general, the files that are deployed by the installation should be owned by the user who ran the install step. However, zziplib's installation scripts do not respect this for the manpages (typically deployed on
/usr/share/man/man3
), which are deployed as the user who ran the build.Steps to reproduce:
Run the following script in order to download, build, and install zziplib, generating a package file similarly to how Linux distributions do. Pay attention to the output of the last command:
Expected result:
All files in the generated package are owned by root.
Actual result:
In the generated package, the manpages are owned by the user who did the build instead of by root:
Reproduced on:
Discussion / technical details:
The cause of the problem is that the procedure for installing the manpages involves creating a
manpages.tar
file during the build step, which is unpacked during the install step. However, tar (or at least GNU tar) defaults to setting the ownership of the unpacked files to the user who packed them when run as root, thus the files are unpacked as the user who built zziplib and not root. Fromman tar
:A quick fix for GNU tar is passing the
--no-same-owner
flag to the extract command indocs/CMakeLists.txt
so it looks like this:However, I believe this
--no-same-owner
flag is a GNU tar extension so this is not a solid solution. If possible I believe that avoiding themanpages.tar
entirely and using a CMakeinstall(DIRECTORY ...)
should take care of this, but I'm not sure if there's some reasonmanpages.tar
is used or rather is mostly legacy from old build scripts.--
Currently Arch Linux's package fixes the permissions after install ( https://git.archlinux.org/svntogit/packages.git/commit/trunk/PKGBUILD?h=packages/zziplib&id=820c6821cc79a029d40710152dd3295f35bf8b99 , https://bugs.archlinux.org/task/66270 ). However this is really a upstream issue.
The text was updated successfully, but these errors were encountered: