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

Non-Root User Configuration to Dockerfile #769

Closed
wants to merge 0 commits into from

Conversation

dave90
Copy link
Contributor

@dave90 dave90 commented Apr 2, 2024

Description

Updates Dockerfile to improve container security by introducing non-root user configurations.

  • Parameterization of User and Group IDs: build-time arguments (USER_ONBUILD, UID_ONBUILD, GROUP_ONBUILD, GID_ONBUILD) to dynamically set the user ID (UID) and group ID (GID) along with the corresponding user and group names.
  • User and Group Creation: creation of a non-root user (USER_ONBUILD) and group (GROUP_ONBUILD) with the specified UID and GID
  • Directory Ownership: The ownership of the /app directory is changed to the newly created non-root user and group

Related to issue #765

Type of change

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to not work as expected)
  • This change requires a documentation update

Checklist:

  • My code follows the style guidelines of this project
  • I have performed a self-review of my own code
  • I have commented my code, particularly in hard-to-understand areas

@pieroit
Copy link
Member

pieroit commented Apr 2, 2024

Thanks for this PR @dave90, a few questions:

  • what happens when the cat installs plugin dependencies and the user is not root? See here
  • what happens if the dev changes volumes ownership and a non root user tries to overwrote them from within the container?

Maybe the last is not an issue

@dave90
Copy link
Contributor Author

dave90 commented Apr 2, 2024

installation of plugin dependencies occurs before the switch to a non-root user, eliminating any potential issues. Following the snippet:

...
RUN python3 install_plugin_dependencies.py

### ADD USER ###
RUN groupadd -g ${GID_ONBUILD} ${GROUP_ONBUILD} && \
   useradd -m -u ${UID_ONBUILD} -g ${GROUP_ONBUILD} ${USER_ONBUILD} \
   && chown -R ${GROUP_ONBUILD}:${USER_ONBUILD} /app

USER ${GROUP_ONBUILD}:${USER_ONBUILD}
...

@pieroit
Copy link
Member

pieroit commented Apr 2, 2024

installation of plugin dependencies occurs before the switch to a non-root user, eliminating any potential issues. Following the snippet:

...
RUN python3 install_plugin_dependencies.py

### ADD USER ###
RUN groupadd -g ${GID_ONBUILD} ${GROUP_ONBUILD} && \
   useradd -m -u ${UID_ONBUILD} -g ${GROUP_ONBUILD} ${USER_ONBUILD} \
   && chown -R ${GROUP_ONBUILD}:${USER_ONBUILD} /app

USER ${GROUP_ONBUILD}:${USER_ONBUILD}
...

Plugins can also be installed and activated after the image has been built:

self._install_requirements()

That makes things more complicated :(
P.S.: thanks for reasoning over this issue

@dave90
Copy link
Contributor Author

dave90 commented Apr 3, 2024

Good point :). Therefore, I've updated the Dockerfile to include a local bin directory in the user's PATH. This modification enables the installation of python packages in a local directory allowing users to install new packages at runtime.

@pieroit
Copy link
Member

pieroit commented Apr 3, 2024

Good point :). Therefore, I've updated the Dockerfile to include a local bin directory in the user's PATH. This modification enables the installation of python packages in a local directory allowing users to install new packages at runtime.

Thanks I'm going to try this out

@dave90
Copy link
Contributor Author

dave90 commented Apr 24, 2024

Closed this pull request and created a new one: -> #790

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

2 participants