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

Resolve symlinks in cp #3214

Merged
merged 9 commits into from
May 30, 2019

Conversation

mheon
Copy link
Member

@mheon mheon commented May 28, 2019

Fixes CVE-2018-15664 and #3211

Still needs manpage updates, bash completion updates, and a test

@openshift-ci-robot openshift-ci-robot added approved Indicates a PR has been approved by an approver from all required OWNERS files. size/M labels May 28, 2019
@mheon mheon force-pushed the resolve_symlinks_in_cp branch from dc13dfc to 259224c Compare May 28, 2019 17:17
@vrothberg
Copy link
Member

vrothberg commented May 28, 2019

That looks very painless 👍 Changes LGTM but I'd love to have some tests for #3211.

@QiWang19
Copy link
Contributor

LGTM

@baude
Copy link
Member

baude commented May 28, 2019

lgtm, test would be nth

@mheon
Copy link
Member Author

mheon commented May 28, 2019

Added a test

Copy link
Member

@vrothberg vrothberg left a comment

Choose a reason for hiding this comment

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

LGTM, thanks @mheon

@mheon mheon force-pushed the resolve_symlinks_in_cp branch from c436e03 to c959e14 Compare May 29, 2019 13:48
@baude
Copy link
Member

baude commented May 29, 2019

/lgtm

@openshift-ci-robot openshift-ci-robot added the lgtm Indicates that a PR is ready to be merged. label May 29, 2019
@baude
Copy link
Member

baude commented May 29, 2019

/hold

@openshift-ci-robot openshift-ci-robot added the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label May 29, 2019
@mheon mheon force-pushed the resolve_symlinks_in_cp branch from c959e14 to ea7739f Compare May 29, 2019 16:26
@openshift-ci-robot openshift-ci-robot removed the lgtm Indicates that a PR is ready to be merged. label May 29, 2019
@openshift-ci-robot
Copy link
Collaborator

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: mheon

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@mheon
Copy link
Member Author

mheon commented May 29, 2019

Update: fix here is still vulnerable to races. I need to move copy code inside libpod to avoid them (so we can grab the container lock while copying)

@mheon
Copy link
Member Author

mheon commented May 29, 2019

Alright, I think this is "good enough" for a release. There's further work to be done, but that will require a much larger refactor.

@rhatdan
Copy link
Member

rhatdan commented May 29, 2019

/lgtm
/hold

@openshift-ci-robot openshift-ci-robot added lgtm Indicates that a PR is ready to be merged. and removed lgtm Indicates that a PR is ready to be merged. labels May 29, 2019
@mheon
Copy link
Member Author

mheon commented May 30, 2019

Hm. Rootless containers don't have CGroups, so we can't pause them.

As such, we can't really mitigate for them... Hm.

@mheon
Copy link
Member Author

mheon commented May 30, 2019

With any luck, tests will go green now.

mheon added 2 commits May 29, 2019 22:53
Securejoin ensures that paths are resolved in the container, not
on the host.

Fixes containers#3211

Signed-off-by: Matthew Heon <[email protected]>
Should fix CVE-2018-15664 for Podman.

Signed-off-by: Matthew Heon <[email protected]>
mheon added 5 commits May 29, 2019 22:53
Rootless containers can't be paused (no CGroups, so no freezer).

We could try and emulate this with a SIGSTOP to all PIDs in the
container, but that's inherently racy, so let's avoid it for now.

Signed-off-by: Matthew Heon <[email protected]>
@rhatdan
Copy link
Member

rhatdan commented May 30, 2019

@mheon How about we fail and say you can not copy on a running container when in rootless mode?

We can't pause them, so if that's requested, throw an error.

Signed-off-by: Matthew Heon <[email protected]>
@mheon mheon force-pushed the resolve_symlinks_in_cp branch from c1291b3 to 57d4093 Compare May 30, 2019 13:23
@mheon
Copy link
Member Author

mheon commented May 30, 2019

Good idea - pushed another commit. We now error on trying to copy into running rootless container with --pause set (which is the default).

You can still do this with --pause=false

Signed-off-by: Matthew Heon <[email protected]>
@mheon
Copy link
Member Author

mheon commented May 30, 2019

OK, tests mostly passing. Restarted one flake.
@baude @rhatdan Someone want to LGTM again?

@baude
Copy link
Member

baude commented May 30, 2019

/lgtm

@openshift-ci-robot openshift-ci-robot added the lgtm Indicates that a PR is ready to be merged. label May 30, 2019
@mheon
Copy link
Member Author

mheon commented May 30, 2019

/hold cancel

@openshift-ci-robot openshift-ci-robot removed the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label May 30, 2019
@openshift-merge-robot openshift-merge-robot merged commit 2dcfd3d into containers:master May 30, 2019
@sfowl
Copy link

sfowl commented May 31, 2019

CVE-2019-10152 has been assigned for this issue:

https://bugzilla.redhat.com/show_bug.cgi?id=1715667

@ret2libc
Copy link

What about the problems outlined in moby/moby#39252 (comment) ? It seems docker is not going to pause containers, for what I understand, because it is a breaking change (e.g. copying big files may stop the process for too long and breaking network connections).

Is podman affected by the same issue?

} else if err == nil {
// Only add the defer if we actually paused
defer func() {
if err := ctr.Unpause(); err != nil {
Copy link
Member

Choose a reason for hiding this comment

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

is it possible that two processes are cp'ing at the same time and one of them unpause the container while the other process is still resolving the symlinks?

Copy link
Member Author

Choose a reason for hiding this comment

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

Yep. That's part of why I was looking to move cp into the container.

Copy link
Member Author

Choose a reason for hiding this comment

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

Into libpod, rather

@mheon
Copy link
Member Author

mheon commented May 31, 2019

@ret2libc Hm. We should be able to grab that - it's definitely a more elegant solution than this. We'll keep this in for now, but I'll avoid cutting a release with it until we verify if we can swap to the alternative fix - in which case we can revert this.

@rhatdan
Copy link
Member

rhatdan commented Jun 2, 2019

Yes I like the Moby Solution better, and we need to back port that ASAP as soon as it is merged.

@mheon mheon mentioned this pull request Sep 9, 2019
@github-actions github-actions bot added the locked - please file new issue/PR Assist humans wanting to comment on an old issue or PR with locked comments. label Sep 26, 2023
@github-actions github-actions bot locked as resolved and limited conversation to collaborators Sep 26, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. lgtm Indicates that a PR is ready to be merged. locked - please file new issue/PR Assist humans wanting to comment on an old issue or PR with locked comments.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

10 participants