Accepting request 1208394 from devel:microos
OBS-URL: https://build.opensuse.org/request/show/1208394 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/podman?expand=0&rev=143
This commit is contained in:
commit
6c033a57ba
68
0001-Properly-validate-cache-IDs-and-sources.patch
Normal file
68
0001-Properly-validate-cache-IDs-and-sources.patch
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
From fe456eed5ac0647250fa5249e663ddb236b2adfb Mon Sep 17 00:00:00 2001
|
||||||
|
From: Danish Prakash <contact@danishpraka.sh>
|
||||||
|
Date: Tue, 15 Oct 2024 22:14:55 +0530
|
||||||
|
Subject: [PATCH] Properly validate cache IDs and sources
|
||||||
|
|
||||||
|
The `--mount type=cache` argument to the `RUN` instruction in
|
||||||
|
Dockerfiles was using `filepath.Join` on user input, allowing
|
||||||
|
crafted paths to be used to gain access to paths on the host,
|
||||||
|
when the command should normally be limited only to Buildah;s own
|
||||||
|
cache and context directories. Switch to `filepath.SecureJoin` to
|
||||||
|
resolve the issue.
|
||||||
|
|
||||||
|
Fixes CVE-2024-9675
|
||||||
|
|
||||||
|
Signed-off-by: Matt Heon <mheon@redhat.com>
|
||||||
|
Signed-off-by: Danish Prakash <contact@danishpraka.sh>
|
||||||
|
---
|
||||||
|
.../buildah/internal/volumes/volumes.go | 19 ++++++++++++++-----
|
||||||
|
1 file changed, 14 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/vendor/github.com/containers/buildah/internal/volumes/volumes.go b/vendor/github.com/containers/buildah/internal/volumes/volumes.go
|
||||||
|
index da6b768fdc21..610e9fcf11b2 100644
|
||||||
|
--- a/vendor/github.com/containers/buildah/internal/volumes/volumes.go
|
||||||
|
+++ b/vendor/github.com/containers/buildah/internal/volumes/volumes.go
|
||||||
|
@@ -23,6 +23,7 @@ import (
|
||||||
|
"github.com/containers/storage/pkg/idtools"
|
||||||
|
"github.com/containers/storage/pkg/lockfile"
|
||||||
|
"github.com/containers/storage/pkg/unshare"
|
||||||
|
+ digest "github.com/opencontainers/go-digest"
|
||||||
|
specs "github.com/opencontainers/runtime-spec/specs-go"
|
||||||
|
selinux "github.com/opencontainers/selinux/go-selinux"
|
||||||
|
)
|
||||||
|
@@ -374,7 +375,11 @@ func GetCacheMount(args []string, store storage.Store, imageMountLabel string, a
|
||||||
|
return newMount, nil, fmt.Errorf("no stage found with name %s", fromStage)
|
||||||
|
}
|
||||||
|
// path should be /contextDir/specified path
|
||||||
|
- newMount.Source = filepath.Join(mountPoint, filepath.Clean(string(filepath.Separator)+newMount.Source))
|
||||||
|
+ evaluated, err := copier.Eval(mountPoint, string(filepath.Separator)+newMount.Source, copier.EvalOptions{})
|
||||||
|
+ if err != nil {
|
||||||
|
+ return newMount, nil, err
|
||||||
|
+ }
|
||||||
|
+ newMount.Source = evaluated
|
||||||
|
} else {
|
||||||
|
// we need to create cache on host if no image is being used
|
||||||
|
|
||||||
|
@@ -391,11 +396,15 @@ func GetCacheMount(args []string, store storage.Store, imageMountLabel string, a
|
||||||
|
}
|
||||||
|
|
||||||
|
if id != "" {
|
||||||
|
- newMount.Source = filepath.Join(cacheParent, filepath.Clean(id))
|
||||||
|
- buildahLockFilesDir = filepath.Join(BuildahCacheLockfileDir, filepath.Clean(id))
|
||||||
|
+ // Don't let the user control where we place the directory.
|
||||||
|
+ dirID := digest.FromString(id).Encoded()[:16]
|
||||||
|
+ newMount.Source = filepath.Join(cacheParent, dirID)
|
||||||
|
+ buildahLockFilesDir = filepath.Join(BuildahCacheLockfileDir, dirID)
|
||||||
|
} else {
|
||||||
|
- newMount.Source = filepath.Join(cacheParent, filepath.Clean(newMount.Destination))
|
||||||
|
- buildahLockFilesDir = filepath.Join(BuildahCacheLockfileDir, filepath.Clean(newMount.Destination))
|
||||||
|
+ // Don't let the user control where we place the directory.
|
||||||
|
+ dirID := digest.FromString(newMount.Destination).Encoded()[:16]
|
||||||
|
+ newMount.Source = filepath.Join(cacheParent, dirID)
|
||||||
|
+ buildahLockFilesDir = filepath.Join(BuildahCacheLockfileDir, dirID)
|
||||||
|
}
|
||||||
|
idPair := idtools.IDPair{
|
||||||
|
UID: uid,
|
||||||
|
--
|
||||||
|
2.46.0
|
||||||
|
|
@ -1,3 +1,14 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Oct 16 07:00:30 UTC 2024 - Alexandre Vicenzi <alexandre.vicenzi@suse.com>
|
||||||
|
|
||||||
|
- Load ip_tables kernel module (bsc#1214612)
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Oct 15 16:48:36 UTC 2024 - Danish Prakash <danish.prakash@suse.com>
|
||||||
|
|
||||||
|
- Add patch for CVE-2024-9675 (bsc#1231499):
|
||||||
|
* 0001-Properly-validate-cache-IDs-and-sources.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Tue Oct 08 07:05:58 UTC 2024 - madhankumar.chellamuthu@suse.com
|
Tue Oct 08 07:05:58 UTC 2024 - madhankumar.chellamuthu@suse.com
|
||||||
|
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
# Load br_netfilter module at boot
|
# Load br_netfilter module at boot
|
||||||
br_netfilter
|
br_netfilter
|
||||||
# ip6_tables module is required if netavark is using iptables on an ipv6
|
# A rootless user has no permsissions to load iptables modules and these are not loaded by default.
|
||||||
# network, which is currently the default in Tumbleweed
|
# netarvark defaults to iptables, but it will soon default to nftables.
|
||||||
|
# CNI defaults to iptables.
|
||||||
|
# If iptables is using nftables as a backend this might not be needed.
|
||||||
|
ip_tables
|
||||||
ip6_tables
|
ip6_tables
|
||||||
|
@ -30,6 +30,7 @@ Group: System/Management
|
|||||||
URL: https://%{project}
|
URL: https://%{project}
|
||||||
Source0: %{name}-%{version}.tar.gz
|
Source0: %{name}-%{version}.tar.gz
|
||||||
Source1: podman.conf
|
Source1: podman.conf
|
||||||
|
Patch0: 0001-Properly-validate-cache-IDs-and-sources.patch
|
||||||
BuildRequires: man
|
BuildRequires: man
|
||||||
BuildRequires: bash-completion
|
BuildRequires: bash-completion
|
||||||
BuildRequires: device-mapper-devel
|
BuildRequires: device-mapper-devel
|
||||||
|
Loading…
Reference in New Issue
Block a user