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: exec-env/-file support multiple args #1626

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

hraban
Copy link

@hraban hraban commented Sep 19, 2024

Don’t pass through sh; let the user do that if they want.

Fixes #1469

Don’t pass through sh; let the user do that if they want.

Fixes getsops#1469
@felixfontein
Copy link
Contributor

Please note that this is a breaking change and thus has no chance of being merged as-is.

@hraban
Copy link
Author

hraban commented Sep 19, 2024

Yeah I tried to somehow detect if the user passed -- after exec-env to only do it then, but I couldn't find a way to get that information out of the argv parser sops uses. Open to other ideas because this is a pretty fundamental feature that becomes particularly relevant when you want to nest multiple sops exec-env calls to allow a hierarchy of envvars (particularly if you have to do so from a bare POSIX shell rather than bash -__- ).

@felixfontein
Copy link
Contributor

Yeah I tried to somehow detect if the user passed -- after exec-env to only do it then, but I couldn't find a way to get that information out of the argv parser sops uses.

Even then it would be a breaking change, since you can already use -- now (it's handled by the argument parser).

What would be possible is to add a new parameter (probably a boolean flag) which allows to control the behavior, like --no-shell, that explicitly enables the new behavior.

@hraban
Copy link
Author

hraban commented Sep 19, 2024

One could argue that was never explicitly documented in the first place so it would only be breaking Hyrum's law / xkcd 1172 , but I'm happy either way :)

It would probably also be nice not to have {} expanded in filenames when that no-shell arg is passed. What do you think?

@hraban
Copy link
Author

hraban commented Sep 19, 2024

(for the record I was just being glib, I actually think your suggestion of a separate flag is better UX)

@felixfontein
Copy link
Contributor

Even if -- wasn't explicitly documented, it's a very common pattern for CLI parsers to that you kind of have to assume that users correctly guessed that they can use it without it being explicitly documented :)

It would probably also be nice not to have {} expanded in filenames when that no-shell arg is passed. What do you think?

Why? Or do you mean to only expand it when the whole argument is "{}", and not when {} appears as part of an argument?

This can be very annoying for programs where you have to provide paths as part of an argument. One common example is Docker's -v option, where you could use something like -v {}:/file:ro to mount the decrypted file as /file into the container. If {} isn't replaced here, you cannot use exec-file to call docker and pass the file into the container via mounts.

@hraban
Copy link
Author

hraban commented Sep 24, 2024

Why? Or do you mean to only expand it when the whole argument is "{}", and not when {} appears as part of an argument?

This can be very annoying for programs where you have to provide paths as part of an argument. One common example is Docker's -v option, where you could use something like -v {}:/file:ro to mount the decrypted file as /file into the container. If {} isn't replaced here, you cannot use exec-file to call docker and pass the file into the container via mounts.

Because it makes sops exec unsafe as an actual "transparent" exec. That's the conventional point of --: when the rest of the argument aren't vetted and potentially attacker controlled. This lets you do things like ls -- * without fearing someone inserts a file -la. Or in this case {}.

The name exec in particular I'm sure come from the exec[v][e] syscall, and from bash's exec statement, and tools like aws-vault exec .... Sops exec-env is a perfect tool to place in a transparent wrapper / trampoline script which has the job of "injecting" some safe envvars, but otherwise continuing to exec argv without any changes. If a user then calls, say, find on that, suddenly {} will be interpreted by sops.

It's a very useful feature to be sure, but if there is no way to actually disable it, it makes it very hard to use sops as a generic command wrapper.

(edit: s/exec-env/exec-file/ but you get the idea)

@felixfontein
Copy link
Contributor

sops exec-env does not (and never did) interpret {}. {} is only used by sops exec-file. Not replacing {} by the filename pretty much wrecks sops exec-file, since you don't know where the file has been written to.

@hraban
Copy link
Author

hraban commented Oct 2, 2024

Yes, I meant to type exec-file. Forcing string substitution like that reduces sops' flexibility as a transparent trampoline script and would require wrapping of potential downstream code, e.g. anything that takes arguments which might include arbitrary file names. I personally don't have enough steam to see this ticket through without buy-in from upstream so I'm going to stick to my fork and leave this here for anyone else who is facing the same issues and is interested in picking up the work. Thank you for your time 👍

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

Successfully merging this pull request may close these issues.

exec-env/exec-file: support "--" to separate command to run
2 participants