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

Support buildkit build time secrets #7046

Closed

Conversation

antiBaconMachine
Copy link

Hi everyone. This is one possible solution to build time secret mounting. I've used the build section in the compose yaml, I think there's a good argument to be made for supporting --build-secret on the CLI as well / instead.

I'm new to this project and I don't typically write python so all feedback welcome, what do people think of using the build section like this?

    build:
      context: .
      secrets:
        - "id=secret,src=${FOO_SECRET:-secret_1}"

The use case I originally wanted this for is mounting .npmrc so I imagine I would check in something like id=npmrc,src=${FOO_SECRET:-~/.npmrc} and then anyone with their .npmrc in the "normal" place would never have to think about this again. That is is the motivation for doing it this way first before the CLI which puts more burden on user.

If this PR isn't to your liking that is fine but you should still consider the first commit which fixes an existing test which does not behave as I think it was intended.

Resolves ##6358

Ollie Edwards added 2 commits November 22, 2019 08:07
…uilder as intended

The existing test was passing DOCKER_BUILDKIT=1 as an env var but the test was passing without using buildkit

Adds buildkit only features to the Dockerfile so that it will fail unless buildkit is invoked. It also ensures that the test environment is passed to the forked native build process

Signed-off-by: Ollie Edwards <oliver.s.edwards@gmail.com>
This is done using the build section in the yaml which may look like a strange decision given build secrets are almost by definition not in a well known location. It's intended that this feature be used with env substitution.

Signed-off-by: Ollie Edwards <oliver.s.edwards@gmail.com>
@ndeloof
Copy link
Contributor

ndeloof commented Nov 22, 2019

Sounds a reasonable approach.
I'd prefer we abstract away from buildkit CLI syntax, and define build secrets as an id=>value map:

secrets:
        secret_id: "${FOO_SECRET:-secret_1}"

which possibly could be extended for later additional parameters buildKit could introduce:

secrets:
        secret_id: 
			src: "${FOO_SECRET:-secret_1}"
			x-to-be-debined: value

As a side-note, when you consider working on such an enhancement, please first report an issue so this can be discussed with maintainers, and you don't waste time working hard on code that might not be later approved.

note: should also be implemented in https://github.com/docker/buildx for consistency

@janbuchar
Copy link

Can this also be used to the pass SSH environment (e.g., docker build --ssh default) to the builder?

@ndeloof
Copy link
Contributor

ndeloof commented Nov 22, 2019

@Teyras would need to look into details, but assuming BuildKit did define distinct build args for this purpose, we probably would better introduce ssh build option for this specific use-case. See #7025

@antiBaconMachine
Copy link
Author

antiBaconMachine commented Nov 22, 2019

Thanks @ndeloof for the feedback. I've had a go at an abstract buildkit syntax let me know what you think.

It looks a bit odd as it's a list of strings or dicts. I didn't want to force people to use the full src form if all they need is id.

Thanks for the hint about opening an issue. In this case I didn't really set out to write a PR it just kinda went that way once I started reading.

Can you please clarify your comment on buildx, this feature is already implemented there, I'm not sure what action you are recommending?

@antiBaconMachine
Copy link
Author

@Teyras No this is specifically to get parity with buildkit --secret flag but if the maintainers accept this solution or one like it, no reason the same approach couldn't be used for ssh as well. I've tried to keep the buildkit string builder generic to support such an eventuality.

@ndeloof
Copy link
Contributor

ndeloof commented Nov 22, 2019

General approach looks good to me an could be used to add support for buildkit's --ssh option.
On schema update, please note the leading schema is hosted on docker/cli (see #7047). Should also avoid something generic as dict and define explicit build_secret type with single property src for the current buildkit implementation, which could evolve in future with more options. Also, for schema consistency, please mimic existing syntax in use, as services:volumes: https://github.com/docker/cli/blob/master/cli/compose/schema/data/config_schema_v3.9.json#L287

I'll discuss with maintainers on way we'd like to proceed with such schema updates.

@ndeloof ndeloof self-assigned this Nov 22, 2019
Rather than putting buildkit strings directly in compose file, use a mapping abstraction. The format is slightly odd looking string or dict as the only truly required mount arg is id but we may also want to provide a whole dict of options including source and any other flags that buildkit supports for a mount spec.

Signed-off-by: Ollie Edwards <oliver.s.edwards@gmail.com>
@antiBaconMachine
Copy link
Author

Thanks @ndeloof, have patched the last commit to be in line with volumes, thanks for pointing that out, I was looking for a good example to crib.

Shame about the schema replication issue, that does complicate things somewhat, but I'm sure there's a reasonable solution.

@antiBaconMachine antiBaconMachine changed the title Support builkit build time secrets Support buildkit build time secrets Nov 25, 2019
@maxwellsmart84
Copy link

maxwellsmart84 commented Dec 5, 2019

Do you guys know if there is a known workaround for doing ssh forwarding with docker-compose till a solution is introduced? I have tried many suggested methods but can't seem to get around password protected RSA keys.

@NinoFloris
Copy link

Would this also include a way to pass a secret as a CLI argument?

@CpuID
Copy link

CpuID commented Feb 6, 2020

Can't wait to see this PR get over the line ;)

@bilby91
Copy link

bilby91 commented Feb 10, 2020

This change would allow using mount=type=ssh ? Looking forward on this one!

@dsvictor94
Copy link

What is the behavior when building without DOCKER_BUILDKIT=1 and COMPOSE_DOCKER_CLI_BUILD=1 present?

@psigen
Copy link

psigen commented Mar 18, 2020

It appears that it should just ignore the secrets if DOCKER_BUILDKIT is not set:
https://github.com/docker/compose/pull/7046/files#diff-db70ffd20201b81c947f72fea35551d2R1812

Copy link

@psigen psigen left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it make sense to just delete the commented old code in the tests?

@@ -973,12 +974,49 @@ def test_build_cli(self):
self.addCleanup(shutil.rmtree, base_dir)

with open(os.path.join(base_dir, 'Dockerfile'), 'w') as f:
f.write("FROM busybox\n")
# f.write("FROM busybox\n")
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Remove commented code?

Suggested change
# f.write("FROM busybox\n")

secret_path_2 = os.path.join(base_dir, 'secret_2')

with open(os.path.join(base_dir, 'Dockerfile'), 'w') as f:
# f.write("FROM busybox\n")
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Remove commented code?

Suggested change
# f.write("FROM busybox\n")

@@ -88,7 +88,8 @@
"cache_from": {"$ref": "#/definitions/list_of_strings"},
"network": {"type": "string"},
"target": {"type": "string"},
"shm_size": {"type": ["integer", "string"]}
"shm_size": {"type": ["integer", "string"]},
"secrets": {"$ref": "#/definitions/build_secrets"}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Note that we can't update the 3.7 schema, as it's already been released, so to add this property to the schema, it probably has to be added to the upcoming 3.9 schema in https://github.com/docker/cli/blob/master/cli/compose/schema/data/config_schema_v3.9.json first

@thaJeztah thaJeztah mentioned this pull request Apr 2, 2020
3 tasks
@CpuID
Copy link

CpuID commented May 5, 2020

@antiBaconMachine @ndeloof next steps here...? :)

@gnagel
Copy link

gnagel commented May 12, 2020

I'm very excited to be able to use ssh secrets in the docker compose builds.

@greg-caffeine
Copy link

Just curious if anyone thinks using the existing secrets syntax (v3.1+) would be cleaner:

services:
  my-application:
    build:
      secrets:
        - my-secret

secrets:
  my-secret:
    file: /path/to/local/file

The secret name ("my-secret") would be passed in as the secret "id" and the path to the file would be passed in as the "src".

@alechirsch
Copy link

Looking forward to seeing ssh flag for compose files as well. We just started to use ssh for git keys and this is a blocker right now. Any update on a timeline for this?

@eliliam
Copy link

eliliam commented Jul 8, 2020

@antiBaconMachine could we get this finally merged in?

@alechirsch
Copy link

It looks like this PR does not address the ssh flag, and only does it for the secrets flag

@Billy-
Copy link

Billy- commented Jul 10, 2020

could we get this finally merged in?

Agreed, what do we need to do to make it happen?!

@antiBaconMachine @ndeloof next steps here...? :)

This is the question! What else needs to be done, anyone? @ndeloof ? Or @thaJeztah ?

Is it mainly this?

thaJeztah (Sebastiaan van Stijn) on 1 Apr
Note that we can't update the 3.7 schema, as it's already been released, so to add this property to the schema, it probably has to be added to the upcoming 3.9 schema in docker/cli@master/cli/compose/schema/data/config_schema_v3.9.json first
#7046 (comment)

@antiBaconMachine any chance you're still around and willing if this PR needs updates? If not, anyone else willing to contribute? I am more than willing, although may need some hand-holding 😅


Although part of me wants to say nothing and advocate merging this ASAP, I can't help but think this is a great suggestion:

Just curious if anyone thinks using the existing secrets syntax (v3.1+) would be cleaner:

services:
  my-application:
    build:
      secrets:
        - my-secret

secrets:
  my-secret:
    file: /path/to/local/file

The secret name ("my-secret") would be passed in as the secret "id" and the path to the file would be passed in as the "src".


RE

It looks like this PR does not address the ssh flag, and only does it for the secrets flag

Imo that seems out of scope for this PR.. looks like it might need a separate issue/PR based on this comment:

@Teyras would need to look into details, but assuming BuildKit did define distinct build args for this purpose, we probably would better introduce ssh build option for this specific use-case. See #7025

@TechTeam12
Copy link

Is there any update on this? Anything else that needs to be done aside from handling merge conflicts? Happy to help if needed.

@pikeas
Copy link

pikeas commented Dec 15, 2020

Would love to see support for build secrets in compose!

@otherguy
Copy link

Any update on this?

@jhagege
Copy link

jhagege commented May 6, 2021

Hi, any plans to support build time secrets ?

@devrushit
Copy link

UP, any plans ? It's a much appreciated feature

@okainov
Copy link

okainov commented Oct 22, 2021

@psigen @thaJeztah @antiBaconMachine @ndeloof is there any update here? What is still needed from this PR to be ready for merging?

@thaJeztah
Copy link
Member

@psigen @thaJeztah @antiBaconMachine @ndeloof is there any update here? What is still needed from this PR to be ready for merging?

This requires changes in the compose specification, so likely needs to wait for compose-spec/compose-spec#81 (or alternatives) to be accepted by the spec maintainers

@ndeloof
Copy link
Contributor

ndeloof commented Oct 22, 2021

best option would be for the buildx maintainers to make a proposal based on the work done with buildx bake cc @tonistiigi @crazy-max

@crazy-max
Copy link
Member

This requires changes in the compose specification

best option would be for the buildx maintainers to make a proposal based on the work done with buildx bake

Yes exactly, that's why we added the x-bake extension field: https://github.com/docker/buildx/blob/master/docs/reference/buildx_bake.md#extension-field-with-compose

@ndeloof ndeloof removed their assignment Oct 28, 2021
@ndeloof
Copy link
Contributor

ndeloof commented Nov 5, 2021

@crazy-max custom extension allow to experiment without the need to get a long debate on the spec on some abstract solution, but this doesn't mean we can't discuss on the spec while bake is used as a concrete implementation example.
Do you plan to contribute an actual proposal to the spec?

@crazy-max
Copy link
Member

@ndeloof

Do you plan to contribute an actual proposal to the spec?

I think the proposal compose-spec/compose-spec#120 from @chris-crone is already aligned with what the x-bake already offers but I agree that it should be part of the spec in the future for consistency.

@jheld
Copy link

jheld commented Jan 24, 2022

Can someone make a comment about the overall process remaining (e.g. what steps and governing bodies are involved and where those decisions are currently) since it seems like there is some positivity here but still feels like "nothing" has happened?

@ndeloof
Copy link
Contributor

ndeloof commented Jan 24, 2022

  1. changes on the compose schema MUST be debated under Compose Specification => Support for BuildKit extensions (secrets) compose-spec/compose-spec#81 (staled, mostly for missing contributors on this topics)
  2. implementation will probably only happen on Compose v2 branch (v1 is in "best-effort" maintenance mode, i.e will receive security fixes but not much)

Would be nice to get buildx contributors involved here, as they introduced custom extensions for this purpose in bake.

@ni11c
Copy link

ni11c commented Mar 25, 2022

Guys, the issue has been submitted more than two years ago, still no concrete progress on this ? Unless there is a decent tool chain that enables docker users to apply best security practices, secrets will continue to be provided in an insecure way for a long time, which is in the interest of nobody. I don't understand how such a crucial feature can take so long to make its way through the intricacies of the Compose Specification process. Thank you to all those involved to make this happen,

@dfr-exnaton
Copy link

Checkout v2 of compose: #9386

@ndeloof
Copy link
Contributor

ndeloof commented Apr 19, 2022

build.secrets support has been introduced in Compose v2, and we don't plan to have significant updates on the v1 branch (security fixes/maintenance), so better adopt the new compose generation 😇

@ndeloof ndeloof closed this Apr 19, 2022
@Kludex
Copy link

Kludex commented Apr 19, 2022

Just for reference, merged on compose-spec/compose-spec#238

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

Successfully merging this pull request may close these issues.