-
Notifications
You must be signed in to change notification settings - Fork 87
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
support running .nbgitpuller.script.{init,update} on start #291
base: main
Are you sure you want to change the base?
Conversation
Thanks for submitting your first pull request! You are awesome! 🤗 |
Ah, this is an interesting idea with fun security implications (see autorun.inf) :D I would say we can probably do this in the following cases:
I think under these conditions, I would be thrilled to add this functionality! |
Sounds reasonable, I'll take a stab at this over the next few weeks when I find some time and get back to you. Thanks for the fast feedback and suggestions! |
@yuvipanda Would you be willing to drop this requirement? Asking as (for us) it is also important to not litter the project with files students do not need to interact with or be aware of; we already have In the case of a bad actor, this countermeasure would be trivially neutered with an For visibility I think this would be covered by (3). What do you think? Just negotiating here, as if I don't ask... :) |
I think I'd like the default to not be hidden, but can be allowed to be hidden with a server-side setting via a traitlet. That way, admins can opt-in to it being hidden, but by default it's visible. I think |
Works for Me(tm) Thanks |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hey!
I'm triaging some PRs pending a release and see that there are review requests in #291 (comment) not yet implemented.
My take is that this can be a useful feature, but I agree with Yuvi that this must be very secure to be accepted.
I figure nbgitpuller is not jupyterhub aware, only the link generator is. So how could the jupyterhub admin disable this by default or similar? Also if the jupyterhub admin would enable this, how would users know its enabled - are we relying on the jupyterhub admin to successfully communicate this to all users?
I think I lean towards not wanting to accept a feature like this unless the individual user that has clicked the link and pulled content is prompted to do something after pulling. The complexity of supporting that may not be something I think is in scope for nbgitpuller as a project, depending on how its proposed to be accomplished.
@yuvipanda do you think my proposed security requirement to have a user confirm they want to execute something after they have clicked a link is too strict? And if not, do you think it is in scope to pursue for this project that needs to maintain such functionality long term if added?
Trying to understand the actual risk here. I acutely understand the 'security' problem and the proposed solutions that could be applied to mitigate this, but struggling to understand how this ultimately applies to the environments it will be deployed to. Understand, I am outlining my assumptions here and my reasoning, not dictating this is how this should be. My understanding for the majority of JupyterHub deployments the user is not the administrator of the deployment. The user is choosing to use the service offered in the same way they choose to use an educational institution or company provided workstation. The user is not the decision maker on what runs on those environments. Right? Should we also be considering extending these proposals to users attempting to run My aim is to provide an option for a course author to use nbgitpuller for their deployment of JupyterHub where they need a bootstrapping script to be executed to get things working. For my platform, we have tried clear instructions, but for some reason people still keep tripping up and making a mess of cut'n'pasting. The only solution I see here is that the service solves this for them...somehow. I find it hard to believe that a user is going to be generating nbgitpuller links and passing them around when they can also ask people to type I think @yuvipanda's suggestion of placing this behind an administrator flag (disabled by default) is prudent. Asking the user to make a choice on a platform as a guest is peculiar, especially when those same users struggle with "please cut'n'paste verbatim...". Did no one else suffer Windows 7 and those security popups? :) Maybe what is needed here is to make the administrative flag behave more like |
b99e625
to
bc09520
Compare
I don't think it's necessary for the end user to make the choice here. In #291 (comment) I described this as being behind a traitlet flag, that can be enabled by JupyterHub admin (or end user, if they're using it without JupyterHub). I think that's the right place for this security setup. It should be opt-in as well. So I'm happy to accept this with the following security requirements:
|
be65b82
to
da48a81
Compare
@yuvipanda okay, so this now seems to work as we discussed Of note, this PR also migrates the extension to the style described in the Jupyter Server - Server Extensions page as it seems generally to be a configurable extension you need to be a fully fledged This also probably has an impact on the discussions in #242 (review) and #248. |
Proposal for fixing #122
.nbgitpuller.script.{init,update}
placed at the top of the repo contains a list of shell commands to run when the project is checked out or refreshed respectively.Let me know what you think, and if this has legs I can add some spit, polish and documentation to this.