Skip to content
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

UID/GID support for container #144

Closed
halkeye opened this issue Mar 9, 2024 · 8 comments · Fixed by #188 · May be fixed by #145 or #199
Closed

UID/GID support for container #144

halkeye opened this issue Mar 9, 2024 · 8 comments · Fixed by #188 · May be fixed by #145 or #199
Labels
contributing Request to contribute enhancement Request for a feature or improvement

Comments

@halkeye
Copy link

halkeye commented Mar 9, 2024

Description of the bug

I like running my images as non root so in the case of downloaders, they have the right uid and gid for the downloaders/dbs. But also generally to prevent a container from having root access to the outerside filesystem.

When I try to do it for kapowarr i get permission denied

To Reproduce

docker run -it --rm mrcas/kapowarr:v1.0.0-beta-4 ls -ltr
total 20
-rwxrwx--- 1 root root  163 Jul 11  2023 requirements.txt
drwxrwx--- 2 root root 4096 Nov 29 14:12 temp_downloads
-rwxrwx--- 1 root root 1251 Dec 27 14:19 Kapowarr.py
drwxrwx--- 5 root root 4096 Dec 31 16:52 frontend
drwxrwx--- 5 root root 4096 Jan  3 17:03 backend
docker run -it -u 1026:100 --rm mrcas/kapowarr:v1.0.0-beta-4
python3: can't open file '/app/Kapowarr.py': [Errno 13] Permission denied

Expected behaviour

It runs :)

Eg: (I added a chmod 755 to the container)

docker run -it -u 1026:100 --rm halkeye
[2024-03-09 19:19:04][MainThread][INFO] Starting up Kapowarr
Traceback (most recent call last):
  File "/app/Kapowarr.py", line 52, in <module>
    Kapowarr()
  File "/app/Kapowarr.py", line 23, in Kapowarr
    set_db_location(folder_path(*__DATABASE_FILEPATH__))
  File "/app/backend/db.py", line 106, in set_db_location
    makedirs(dirname(db_file_location), exist_ok=True)
  File "/usr/local/lib/python3.8/os.py", line 223, in makedirs
    mkdir(name, mode)
PermissionError: [Errno 13] Permission denied: '/app/db'
@halkeye halkeye added the bug Report of something not working as expected label Mar 9, 2024
halkeye added a commit to halkeye/Kapowarr-1 that referenced this issue Mar 9, 2024
@Casvt
Copy link
Owner

Casvt commented Mar 9, 2024

We already had an attempt at this in a seperate branch but that didn't work for users on certain OS'es. I'm pretty sure your one liner won't cut it either for a good part of the users.

I don't have a GH action for building docker images because I want manual control over when it happens. The script that I use also does some extra stuff around the building of the images.

However, maybe together we can make it work for everyone. IIRC, our attempt worked well for Linux, MacOS and similar OS'es. I can't remember how it did on Windows. And it would crash on special ones like for those pre built NAS OS'es.

@Casvt Casvt changed the title Docker - Image has /app set as only user/group of root, which means non root can't run it UID/GID support for container Mar 9, 2024
@Casvt Casvt added enhancement Request for a feature or improvement contributing Request to contribute and removed bug Report of something not working as expected labels Mar 9, 2024
@Casvt Casvt moved this to In Progress in Kapowarr plans Mar 9, 2024
@halkeye
Copy link
Author

halkeye commented Mar 9, 2024

Thats not quite the problem I'm having. That tries to allow PGID/PUID (which are usually runtime env varibles) in compile time docker land.

All i'm doing is removing the restriction that is -->has<-- to be run as root, but allowing non uid 0 to execute /app

https://github.com/halkeye/kapowarr/blob/main/Dockerfile works just fine as root and non root

rwxrwx--- is only allow uid (0) and gid (0) to read/write/execute the files, other (the last 3) can't read or execute even

To reproduce what you have you could do 775 but 755 is usually the standard so only the file owner can write to it.

@Casvt
Copy link
Owner

Casvt commented Mar 9, 2024

I still think you're describing the same problem. You want to run the container with a different user so that the downloaded files are also owned by that user instead of the root user. And you make sure that the container only has access to what you want by running it with a different user than root.

That's exactly what UID/GID support is for. It will run the application using the given user; isn't that exactly what you want?

All i'm doing is removing the restriction that is -->has<-- to be run as root, but by allowing non uid 0 to execute /app

I interpret this as you wanting to run the application using >0 UID. So we need to add support for setting the user that will run the application.

@halkeye
Copy link
Author

halkeye commented Mar 9, 2024

That's exactly what UID/GID support is for. It will run the application using the given user; isn't that exactly what you want?

I don't need a user to be created, docker lets you set the uid and gid via -u, really the only reason for pid/gid env variables that people use is to do setup, and then switch to non root. I don't want the container to ever have root access, so it doesn't need to su (via gosu or su or whatever else)

By setting the filesystem properly so "other" (as in non file owner) can read/execute the binary, its still essentially a read only container, but non root user can run the software.

It won't cause an issue with unraid and all the others, because its not messing with uid/gid at all, inside or outside the container, its just removing the root restriction.

I interpret this as you wanting to run the application using >0 UID. So we need to add support for setting the user that will run the application.

I don't want or need it. Docker can handle it, I don't need the binary to handle it.

see https://github.com/Casvt/Kapowarr/pull/145/files

all it needs is a single chmod to allow any other uid to run the application. By default it'll still be root, and still have the same behavior, but won't lock out non root.

@Keatingfish
Copy link

I would say this. Currently I have to manually do new perms on every new folder that Kapowarr creates for a volume if I want to manually move a file into it, and I have the docker set to 99/100 for perms so something isn't allowing it to be open by default to outside root

@byrnesem
Copy link

byrnesem commented Aug 5, 2024

I am seeing the same thing as @Keatingfish on Unraid. @halkeye 's suggestions would be huge for me. Right now I have to manually reset permissions to access folders, and files with my comic tagger.

@fscorrupt
Copy link

fscorrupt commented Oct 12, 2024

@Casvt

I recently had the same issue with my docker container, what i did to accomplish the cross platform Compatibility with uid/pid was to use lsio as base image with s6-overlayer.

For example in your case the alpine image: https://github.com/linuxserver/docker-baseimage-alpine/tree/master

Then you can add all your requirements to it and create a run(service) file that starts python as the lsio abc user which has the uid/pid from the user via env, we can have a chat if you have questions! Just hit me on discord: fs.corrupt

@Casvt
Copy link
Owner

Casvt commented Oct 13, 2024

Hey I've contacted you via Discord

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
contributing Request to contribute enhancement Request for a feature or improvement
Projects
Archived in project
5 participants