Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Provide secrets using environment variables #3524

Closed
skorhone opened this issue Sep 18, 2021 · 10 comments · Fixed by #3598
Closed

Provide secrets using environment variables #3524

skorhone opened this issue Sep 18, 2021 · 10 comments · Fixed by #3598
Assignees
Labels
In Progress This issue is actively being worked by the assignee, please do not work on this at this time. locked - please file new issue/PR

Comments

@skorhone
Copy link

Currently the only supported mechanism for passing secrets is to store them on filesystem. I'd like to see something like --secret id=secret,env=FOO that could be used to expose secret as environment variable.

The reason for this request is that most CI services pass secrets as environment variables. Creating a temporary file on persistent storage just doesn't feel right (or safe)

Build kit has this feature: https://pythonspeed.com/articles/docker-build-secrets/

This is extension to #1684

@rhatdan
Copy link
Member

rhatdan commented Sep 20, 2021

@ashley-cui PTAL

@skorhone
Copy link
Author

Also, if possible, let user select whether secret from environment variable is exposed as file or environment variable. If target RUN command supports secret from environment, reading it from file with FOO=$(cat /secrets/foo) doesn't make much sense

@rhatdan
Copy link
Member

rhatdan commented Sep 21, 2021

@skorhone interested in opening a PR?

@skorhone
Copy link
Author

skorhone commented Sep 30, 2021

@rhatdan I think resolving this properly is beyond my current abilities. If a solution that isn't 100% compatible or solution that isn't safe in all environments is fine, then I might be able to contribute.

In unsafe implementation secrets would get stored as files in a temporary layer on a persistent storage. This would inherit all the problems that current solution using secret files does. (I guess that the current implementation doesn't take in account that even for files secrets could very well be coming from non persistent storage, e.g. kubernetes secrets)

An ideal solution should use memory backed storage that gets wiped. Theoretically a tmpfs in a system that is configured without swap should work. Ramfs would be far safer, but as far as I know that's not supported for non root users (fuse).

Or if you don't mind that solution isn't buildkit/docker compatible, then I guess I could pass environment variables directly to builder rather than storing them on filesystem as files. This would solve problem for use cases, where secrets can be passed without using files. e.g. from security standpoint, it should be acceptable (while not ideal) to pass an encrypted RSA private key as a file through persistent storage, if encryption passphrase is passed using non-persistent storage such as environment variable.

Any thoughts? Security or compatibility?

@ashley-cui
Copy link
Member

@skorhone I think we definitely have to create the file somewhere as you said, whether it be in a temporary layer, persistent storage, or tmpfs. Let me take a look at what docker does and report back

@rhatdan
Copy link
Member

rhatdan commented Sep 30, 2021

You can create it in /run or mount a tmpfs with the secrets in it, that goes away when the container exits.

@skorhone
Copy link
Author

skorhone commented Oct 1, 2021

Assuming that current location used to store secret isn't necessarily located in tmpfs, work could be split to two parts. First part would be storing secrets from environment using the same method that is used for files.

The second part would be to move all secrets to a location that is guaranteed to be on tmpfs. Or if default is tmpfs then maybe it would be enough, if user was warned about possible security issue when secrets are used and default is overridden with persistent storage (non tmpfs / ramfs). Now that I think of, I kind of like the second option. It allows end-user to choose storage type.

Is run mount used during build process by default on tmpfs? If not, is there a tmpfs location created for each container run command that I can reuse without creating new location? If not, I guess I can create one that is not dedicated just for secrets.

This is what secrets are currently using. Documentation says that it's persistent storage, but is it really?

	// After this point we need to know the per-container persistent storage directory.
	cdir, err := b.store.ContainerDirectory(b.ContainerID)

In store there's option to get ContainerRunDirectory. Would it be safe enough? This location is bound to lifecycle of container, not the run command.

@rhatdan
Copy link
Member

rhatdan commented Oct 1, 2021

I talked to @ashley-cui about storing this temporary secret file on /dev/shm as a random tmp file and then remove it when we are finished. If the machine crashes then the file disappears.

@ashley-cui ashley-cui self-assigned this Oct 12, 2021
@ashley-cui ashley-cui added the In Progress This issue is actively being worked by the assignee, please do not work on this at this time. label Oct 12, 2021
ashley-cui added a commit to ashley-cui/buildah that referenced this issue Oct 25, 2021
Run secrets can now be created from an environment variable. The
environment variable is read and is briefly stored as a file on /dev/shm
when it's being used, and the file is removed after the RUN command is
finished.

Fixes: containers#3524

Signed-off-by: Ashley Cui <acui@redhat.com>
ashley-cui added a commit to ashley-cui/buildah that referenced this issue Oct 25, 2021
Run secrets can now be created from an environment variable. The
environment variable is read and is briefly stored as a file on /dev/shm
when it's being used, and the file is removed after the RUN command is
finished.

Fixes: containers#3524

Signed-off-by: Ashley Cui <acui@redhat.com>
ashley-cui added a commit to ashley-cui/buildah that referenced this issue Oct 26, 2021
Run secrets can now be created from an environment variable. The
environment variable is read and is briefly stored as a file on /dev/shm
when it's being used, and the file is removed after the RUN command is
finished.

Fixes: containers#3524

Signed-off-by: Ashley Cui <acui@redhat.com>
@skorhone
Copy link
Author

@ashley-cui @rhatdan Documentation should be updated to reflect this change.

@rhatdan
Copy link
Member

rhatdan commented Nov 1, 2021

Please open a PR to fix documentation.

@github-actions github-actions bot locked as resolved and limited conversation to collaborators Sep 3, 2023
# for free to subscribe to this conversation on GitHub. Already have an account? #.
Labels
In Progress This issue is actively being worked by the assignee, please do not work on this at this time. locked - please file new issue/PR
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants