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

["FEAT"] Be able to incorporate custom packages #41

Closed
fgosew opened this issue Oct 10, 2023 · 1 comment · Fixed by #42
Closed

["FEAT"] Be able to incorporate custom packages #41

fgosew opened this issue Oct 10, 2023 · 1 comment · Fixed by #42
Assignees
Labels
enhancement New feature or request

Comments

@fgosew
Copy link

fgosew commented Oct 10, 2023

Is your feature request related to a problem? Please describe.
The problem is that the current documentation for the CodeJail plugin within Tutor does not provide any guidance on how to add additional Python packages or Conda virtual environments (venvs) to the CodeJail sandbox. This lack of information makes it challenging for users to incorporate custom packages or tools like SageMath, which may have unique dependencies, into the CodeJail environment.

Describe the solution you'd like
I would like to have the ability to add custom Python packages and Conda venvs to the CodeJail sandbox directly from the Tutor-CodeJail project. This means introducing new configuration options in the Tutor-CodeJail settings that allow users to specify the additional Python packages and Conda venvs they want to include. These packages and venvs should be isolated from the host system, ensuring security and preventing conflicts.

Describe alternatives you've considered
One alternative could be manually modifying the apparmor filterfile to include additional packages, but this approach lacks user-friendliness and may not provide the desired isolation. Another alternative could be running CodeJail inside an existing Conda venv, but this may not be feasible for all use cases and could still lead to dependency conflicts.

Additional context
This feature request aims to enhance the usability and flexibility of Tutor-CodeJail by addressing the need for custom Python packages and Conda venvs within the CodeJail sandbox. It would make Tutor-CodeJail a more versatile tool for educational and research purposes and help users work with specialized packages like SageMath effectively while maintaining isolation from the host system.

@fgosew fgosew added the enhancement New feature or request label Oct 10, 2023
@MaferMazu MaferMazu changed the title ["FEAT"] ["FEAT"] Be able to incorporate custom packages Oct 21, 2023
@MaferMazu
Copy link
Contributor

Hello @fgosew, thanks for this proposal; it sounds interesting.

I think the ability to add extra requirements for the sandbox is a good feature because some instructors want to use certain packages, and we don't have a standard way to do it. I was thinking it would be good to have a patch in the Dockerfile. I don't think it's a crazy idea. I will tag our PM to make a product review of this feature because it sounds good, but I think we have other priorities on our plate right now. cc @santiagosuarezedunext

About having Conda or venv, I think that is another story. But a workaround for that is to clone this repo and edit the Dockerfile to have the environments you need, then build the codejail image (tutor images build codejail), and then run the init command (tutor local do init --limit codejail).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
4 participants