Commit 2ce811e632f1b17a9c6786603231e6957942363e migrated the use of the
userns package to the github.com/moby/sys/user module.
After further discussion with maintainers, it was decided to move the
userns package to a separate module, as it has no direct relation with
"user" operations (other than having "user" in its name).
This patch migrates our code to use the new module.
Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
| ... | ... |
@@ -69,9 +69,9 @@ linters-settings: |
| 69 | 69 |
- pkg: "github.com/containerd/containerd/log" |
| 70 | 70 |
desc: The logs package has moved to a separate module, https://github.com/containerd/log |
| 71 | 71 |
- pkg: "github.com/containerd/containerd/pkg/userns" |
| 72 |
- desc: Use github.com/moby/sys/user/userns instead. |
|
| 72 |
+ desc: Use github.com/moby/sys/userns instead. |
|
| 73 | 73 |
- pkg: "github.com/opencontainers/runc/libcontainer/userns" |
| 74 |
- desc: Use github.com/moby/sys/user/userns instead. |
|
| 74 |
+ desc: Use github.com/moby/sys/userns instead. |
|
| 75 | 75 |
revive: |
| 76 | 76 |
rules: |
| 77 | 77 |
# FIXME make sure all packages have a description. Currently, there's many packages without. |
| ... | ... |
@@ -79,7 +79,7 @@ import ( |
| 79 | 79 |
resolverconfig "github.com/moby/buildkit/util/resolver/config" |
| 80 | 80 |
"github.com/moby/buildkit/util/tracing" |
| 81 | 81 |
"github.com/moby/locker" |
| 82 |
- "github.com/moby/sys/user/userns" |
|
| 82 |
+ "github.com/moby/sys/userns" |
|
| 83 | 83 |
"github.com/pkg/errors" |
| 84 | 84 |
"go.etcd.io/bbolt" |
| 85 | 85 |
"go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc" |
| ... | ... |
@@ -42,7 +42,7 @@ import ( |
| 42 | 42 |
"github.com/docker/docker/pkg/parsers" |
| 43 | 43 |
units "github.com/docker/go-units" |
| 44 | 44 |
"github.com/moby/sys/mount" |
| 45 |
- "github.com/moby/sys/user/userns" |
|
| 45 |
+ "github.com/moby/sys/userns" |
|
| 46 | 46 |
"github.com/opencontainers/selinux/go-selinux/label" |
| 47 | 47 |
"github.com/pkg/errors" |
| 48 | 48 |
"golang.org/x/sys/unix" |
| ... | ... |
@@ -26,7 +26,7 @@ import ( |
| 26 | 26 |
"github.com/docker/docker/pkg/parsers/kernel" |
| 27 | 27 |
"github.com/moby/locker" |
| 28 | 28 |
"github.com/moby/sys/mount" |
| 29 |
- "github.com/moby/sys/user/userns" |
|
| 29 |
+ "github.com/moby/sys/userns" |
|
| 30 | 30 |
"github.com/opencontainers/selinux/go-selinux/label" |
| 31 | 31 |
"github.com/pkg/errors" |
| 32 | 32 |
"golang.org/x/sys/unix" |
| ... | ... |
@@ -12,7 +12,7 @@ import ( |
| 12 | 12 |
"github.com/containerd/containerd/mount" |
| 13 | 13 |
"github.com/docker/docker/daemon/graphdriver/overlayutils" |
| 14 | 14 |
"github.com/docker/docker/pkg/system" |
| 15 |
- "github.com/moby/sys/user/userns" |
|
| 15 |
+ "github.com/moby/sys/userns" |
|
| 16 | 16 |
"github.com/pkg/errors" |
| 17 | 17 |
"golang.org/x/sys/unix" |
| 18 | 18 |
) |
| ... | ... |
@@ -31,7 +31,7 @@ import ( |
| 31 | 31 |
units "github.com/docker/go-units" |
| 32 | 32 |
"github.com/moby/locker" |
| 33 | 33 |
"github.com/moby/sys/mount" |
| 34 |
- "github.com/moby/sys/user/userns" |
|
| 34 |
+ "github.com/moby/sys/userns" |
|
| 35 | 35 |
"github.com/opencontainers/selinux/go-selinux/label" |
| 36 | 36 |
"golang.org/x/sys/unix" |
| 37 | 37 |
) |
| ... | ... |
@@ -28,7 +28,7 @@ import ( |
| 28 | 28 |
"github.com/containerd/containerd/mount" |
| 29 | 29 |
"github.com/containerd/log" |
| 30 | 30 |
"github.com/docker/docker/pkg/parsers/kernel" |
| 31 |
- "github.com/moby/sys/user/userns" |
|
| 31 |
+ "github.com/moby/sys/userns" |
|
| 32 | 32 |
) |
| 33 | 33 |
|
| 34 | 34 |
// NeedsUserXAttr returns whether overlayfs should be mounted with the "userxattr" mount option. |
| ... | ... |
@@ -28,7 +28,7 @@ import ( |
| 28 | 28 |
"github.com/moby/sys/mount" |
| 29 | 29 |
"github.com/moby/sys/mountinfo" |
| 30 | 30 |
"github.com/moby/sys/user" |
| 31 |
- "github.com/moby/sys/user/userns" |
|
| 31 |
+ "github.com/moby/sys/userns" |
|
| 32 | 32 |
"github.com/opencontainers/runc/libcontainer/cgroups" |
| 33 | 33 |
specs "github.com/opencontainers/runtime-spec/specs-go" |
| 34 | 34 |
"github.com/pkg/errors" |
| ... | ... |
@@ -11,7 +11,7 @@ import ( |
| 11 | 11 |
|
| 12 | 12 |
"github.com/docker/docker/pkg/system" |
| 13 | 13 |
"github.com/google/go-cmp/cmp/cmpopts" |
| 14 |
- "github.com/moby/sys/user/userns" |
|
| 14 |
+ "github.com/moby/sys/userns" |
|
| 15 | 15 |
"golang.org/x/sys/unix" |
| 16 | 16 |
"gotest.tools/v3/assert" |
| 17 | 17 |
is "gotest.tools/v3/assert/cmp" |
| ... | ... |
@@ -19,7 +19,7 @@ import ( |
| 19 | 19 |
|
| 20 | 20 |
"github.com/docker/docker/pkg/idtools" |
| 21 | 21 |
"github.com/docker/docker/pkg/ioutils" |
| 22 |
- "github.com/moby/sys/user/userns" |
|
| 22 |
+ "github.com/moby/sys/userns" |
|
| 23 | 23 |
"gotest.tools/v3/assert" |
| 24 | 24 |
is "gotest.tools/v3/assert/cmp" |
| 25 | 25 |
"gotest.tools/v3/skip" |
| ... | ... |
@@ -13,7 +13,7 @@ import ( |
| 13 | 13 |
"github.com/docker/docker/internal/rootless/mountopts" |
| 14 | 14 |
"github.com/docker/docker/internal/sliceutil" |
| 15 | 15 |
"github.com/docker/docker/oci" |
| 16 |
- "github.com/moby/sys/user/userns" |
|
| 16 |
+ "github.com/moby/sys/userns" |
|
| 17 | 17 |
specs "github.com/opencontainers/runtime-spec/specs-go" |
| 18 | 18 |
"github.com/pkg/errors" |
| 19 | 19 |
) |
| ... | ... |
@@ -75,7 +75,8 @@ require ( |
| 75 | 75 |
github.com/moby/sys/sequential v0.6.0 |
| 76 | 76 |
github.com/moby/sys/signal v0.7.1 |
| 77 | 77 |
github.com/moby/sys/symlink v0.3.0 |
| 78 |
- github.com/moby/sys/user v0.2.0 |
|
| 78 |
+ github.com/moby/sys/user v0.3.0 |
|
| 79 |
+ github.com/moby/sys/userns v0.1.0 |
|
| 79 | 80 |
github.com/moby/term v0.5.0 |
| 80 | 81 |
github.com/morikuni/aec v1.0.0 |
| 81 | 82 |
github.com/opencontainers/go-digest v1.0.0 |
| ... | ... |
@@ -500,8 +500,10 @@ github.com/moby/sys/signal v0.7.1 h1:PrQxdvxcGijdo6UXXo/lU/TvHUWyPhj7UOpSo8tuvk0 |
| 500 | 500 |
github.com/moby/sys/signal v0.7.1/go.mod h1:Se1VGehYokAkrSQwL4tDzHvETwUZlnY7S5XtQ50mQp8= |
| 501 | 501 |
github.com/moby/sys/symlink v0.3.0 h1:GZX89mEZ9u53f97npBy4Rc3vJKj7JBDj/PN2I22GrNU= |
| 502 | 502 |
github.com/moby/sys/symlink v0.3.0/go.mod h1:3eNdhduHmYPcgsJtZXW1W4XUJdZGBIkttZ8xKqPUJq0= |
| 503 |
-github.com/moby/sys/user v0.2.0 h1:OnpapJsRp25vkhw8TFG6OLJODNh/3rEwRWtJ3kakwRM= |
|
| 504 |
-github.com/moby/sys/user v0.2.0/go.mod h1:RYstrcWOJpVh+6qzUqp2bU3eaRpdiQeKGlKitaH0PM8= |
|
| 503 |
+github.com/moby/sys/user v0.3.0 h1:9ni5DlcW5an3SvRSx4MouotOygvzaXbaSrc/wGDFWPo= |
|
| 504 |
+github.com/moby/sys/user v0.3.0/go.mod h1:bG+tYYYJgaMtRKgEmuueC0hJEAZWwtIbZTB+85uoHjs= |
|
| 505 |
+github.com/moby/sys/userns v0.1.0 h1:tVLXkFOxVu9A64/yh59slHVv9ahO9UIev4JZusOLG/g= |
|
| 506 |
+github.com/moby/sys/userns v0.1.0/go.mod h1:IHUYgu/kao6N8YZlp9Cf444ySSvCmDlmzUcYfDHOl28= |
|
| 505 | 507 |
github.com/moby/term v0.5.0 h1:xt8Q1nalod/v7BqbG21f8mQPqH+xAaC9C3N3wfWbVP0= |
| 506 | 508 |
github.com/moby/term v0.5.0/go.mod h1:8FzsFHVUBGZdbDsJw/ot+X+d5HLUbvklYLJ9uGfcI3Y= |
| 507 | 509 |
github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= |
| 508 | 510 |
deleted file mode 100644 |
| ... | ... |
@@ -1,16 +0,0 @@ |
| 1 |
-// Package userns provides utilities to detect whether we are currently running |
|
| 2 |
-// in a Linux user namespace. |
|
| 3 |
-// |
|
| 4 |
-// This code was migrated from [libcontainer/runc], which based its implementation |
|
| 5 |
-// on code from [lcx/incus]. |
|
| 6 |
-// |
|
| 7 |
-// [libcontainer/runc]: https://github.com/opencontainers/runc/blob/3778ae603c706494fd1e2c2faf83b406e38d687d/libcontainer/userns/userns_linux.go#L12-L49 |
|
| 8 |
-// [lcx/incus]: https://github.com/lxc/incus/blob/e45085dd42f826b3c8c3228e9733c0b6f998eafe/shared/util.go#L678-L700 |
|
| 9 |
-package userns |
|
| 10 |
- |
|
| 11 |
-// RunningInUserNS detects whether we are currently running in a Linux |
|
| 12 |
-// user namespace and memoizes the result. It returns false on non-Linux |
|
| 13 |
-// platforms. |
|
| 14 |
-func RunningInUserNS() bool {
|
|
| 15 |
- return inUserNS() |
|
| 16 |
-} |
| 17 | 1 |
deleted file mode 100644 |
| ... | ... |
@@ -1,53 +0,0 @@ |
| 1 |
-package userns |
|
| 2 |
- |
|
| 3 |
-import ( |
|
| 4 |
- "bufio" |
|
| 5 |
- "fmt" |
|
| 6 |
- "os" |
|
| 7 |
- "sync" |
|
| 8 |
-) |
|
| 9 |
- |
|
| 10 |
-var inUserNS = sync.OnceValue(runningInUserNS) |
|
| 11 |
- |
|
| 12 |
-// runningInUserNS detects whether we are currently running in a user namespace. |
|
| 13 |
-// |
|
| 14 |
-// This code was migrated from [libcontainer/runc] and based on an implementation |
|
| 15 |
-// from [lcx/incus]. |
|
| 16 |
-// |
|
| 17 |
-// [libcontainer/runc]: https://github.com/opencontainers/runc/blob/3778ae603c706494fd1e2c2faf83b406e38d687d/libcontainer/userns/userns_linux.go#L12-L49 |
|
| 18 |
-// [lcx/incus]: https://github.com/lxc/incus/blob/e45085dd42f826b3c8c3228e9733c0b6f998eafe/shared/util.go#L678-L700 |
|
| 19 |
-func runningInUserNS() bool {
|
|
| 20 |
- file, err := os.Open("/proc/self/uid_map")
|
|
| 21 |
- if err != nil {
|
|
| 22 |
- // This kernel-provided file only exists if user namespaces are supported. |
|
| 23 |
- return false |
|
| 24 |
- } |
|
| 25 |
- defer file.Close() |
|
| 26 |
- |
|
| 27 |
- buf := bufio.NewReader(file) |
|
| 28 |
- l, _, err := buf.ReadLine() |
|
| 29 |
- if err != nil {
|
|
| 30 |
- return false |
|
| 31 |
- } |
|
| 32 |
- |
|
| 33 |
- return uidMapInUserNS(string(l)) |
|
| 34 |
-} |
|
| 35 |
- |
|
| 36 |
-func uidMapInUserNS(uidMap string) bool {
|
|
| 37 |
- if uidMap == "" {
|
|
| 38 |
- // File exist but empty (the initial state when userns is created, |
|
| 39 |
- // see user_namespaces(7)). |
|
| 40 |
- return true |
|
| 41 |
- } |
|
| 42 |
- |
|
| 43 |
- var a, b, c int64 |
|
| 44 |
- if _, err := fmt.Sscanf(uidMap, "%d %d %d", &a, &b, &c); err != nil {
|
|
| 45 |
- // Assume we are in a regular, non user namespace. |
|
| 46 |
- return false |
|
| 47 |
- } |
|
| 48 |
- |
|
| 49 |
- // As per user_namespaces(7), /proc/self/uid_map of |
|
| 50 |
- // the initial user namespace shows 0 0 4294967295. |
|
| 51 |
- initNS := a == 0 && b == 0 && c == 4294967295 |
|
| 52 |
- return !initNS |
|
| 53 |
-} |
| 7 | 1 |
new file mode 100644 |
| ... | ... |
@@ -0,0 +1,202 @@ |
| 0 |
+ |
|
| 1 |
+ Apache License |
|
| 2 |
+ Version 2.0, January 2004 |
|
| 3 |
+ http://www.apache.org/licenses/ |
|
| 4 |
+ |
|
| 5 |
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION |
|
| 6 |
+ |
|
| 7 |
+ 1. Definitions. |
|
| 8 |
+ |
|
| 9 |
+ "License" shall mean the terms and conditions for use, reproduction, |
|
| 10 |
+ and distribution as defined by Sections 1 through 9 of this document. |
|
| 11 |
+ |
|
| 12 |
+ "Licensor" shall mean the copyright owner or entity authorized by |
|
| 13 |
+ the copyright owner that is granting the License. |
|
| 14 |
+ |
|
| 15 |
+ "Legal Entity" shall mean the union of the acting entity and all |
|
| 16 |
+ other entities that control, are controlled by, or are under common |
|
| 17 |
+ control with that entity. For the purposes of this definition, |
|
| 18 |
+ "control" means (i) the power, direct or indirect, to cause the |
|
| 19 |
+ direction or management of such entity, whether by contract or |
|
| 20 |
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the |
|
| 21 |
+ outstanding shares, or (iii) beneficial ownership of such entity. |
|
| 22 |
+ |
|
| 23 |
+ "You" (or "Your") shall mean an individual or Legal Entity |
|
| 24 |
+ exercising permissions granted by this License. |
|
| 25 |
+ |
|
| 26 |
+ "Source" form shall mean the preferred form for making modifications, |
|
| 27 |
+ including but not limited to software source code, documentation |
|
| 28 |
+ source, and configuration files. |
|
| 29 |
+ |
|
| 30 |
+ "Object" form shall mean any form resulting from mechanical |
|
| 31 |
+ transformation or translation of a Source form, including but |
|
| 32 |
+ not limited to compiled object code, generated documentation, |
|
| 33 |
+ and conversions to other media types. |
|
| 34 |
+ |
|
| 35 |
+ "Work" shall mean the work of authorship, whether in Source or |
|
| 36 |
+ Object form, made available under the License, as indicated by a |
|
| 37 |
+ copyright notice that is included in or attached to the work |
|
| 38 |
+ (an example is provided in the Appendix below). |
|
| 39 |
+ |
|
| 40 |
+ "Derivative Works" shall mean any work, whether in Source or Object |
|
| 41 |
+ form, that is based on (or derived from) the Work and for which the |
|
| 42 |
+ editorial revisions, annotations, elaborations, or other modifications |
|
| 43 |
+ represent, as a whole, an original work of authorship. For the purposes |
|
| 44 |
+ of this License, Derivative Works shall not include works that remain |
|
| 45 |
+ separable from, or merely link (or bind by name) to the interfaces of, |
|
| 46 |
+ the Work and Derivative Works thereof. |
|
| 47 |
+ |
|
| 48 |
+ "Contribution" shall mean any work of authorship, including |
|
| 49 |
+ the original version of the Work and any modifications or additions |
|
| 50 |
+ to that Work or Derivative Works thereof, that is intentionally |
|
| 51 |
+ submitted to Licensor for inclusion in the Work by the copyright owner |
|
| 52 |
+ or by an individual or Legal Entity authorized to submit on behalf of |
|
| 53 |
+ the copyright owner. For the purposes of this definition, "submitted" |
|
| 54 |
+ means any form of electronic, verbal, or written communication sent |
|
| 55 |
+ to the Licensor or its representatives, including but not limited to |
|
| 56 |
+ communication on electronic mailing lists, source code control systems, |
|
| 57 |
+ and issue tracking systems that are managed by, or on behalf of, the |
|
| 58 |
+ Licensor for the purpose of discussing and improving the Work, but |
|
| 59 |
+ excluding communication that is conspicuously marked or otherwise |
|
| 60 |
+ designated in writing by the copyright owner as "Not a Contribution." |
|
| 61 |
+ |
|
| 62 |
+ "Contributor" shall mean Licensor and any individual or Legal Entity |
|
| 63 |
+ on behalf of whom a Contribution has been received by Licensor and |
|
| 64 |
+ subsequently incorporated within the Work. |
|
| 65 |
+ |
|
| 66 |
+ 2. Grant of Copyright License. Subject to the terms and conditions of |
|
| 67 |
+ this License, each Contributor hereby grants to You a perpetual, |
|
| 68 |
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable |
|
| 69 |
+ copyright license to reproduce, prepare Derivative Works of, |
|
| 70 |
+ publicly display, publicly perform, sublicense, and distribute the |
|
| 71 |
+ Work and such Derivative Works in Source or Object form. |
|
| 72 |
+ |
|
| 73 |
+ 3. Grant of Patent License. Subject to the terms and conditions of |
|
| 74 |
+ this License, each Contributor hereby grants to You a perpetual, |
|
| 75 |
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable |
|
| 76 |
+ (except as stated in this section) patent license to make, have made, |
|
| 77 |
+ use, offer to sell, sell, import, and otherwise transfer the Work, |
|
| 78 |
+ where such license applies only to those patent claims licensable |
|
| 79 |
+ by such Contributor that are necessarily infringed by their |
|
| 80 |
+ Contribution(s) alone or by combination of their Contribution(s) |
|
| 81 |
+ with the Work to which such Contribution(s) was submitted. If You |
|
| 82 |
+ institute patent litigation against any entity (including a |
|
| 83 |
+ cross-claim or counterclaim in a lawsuit) alleging that the Work |
|
| 84 |
+ or a Contribution incorporated within the Work constitutes direct |
|
| 85 |
+ or contributory patent infringement, then any patent licenses |
|
| 86 |
+ granted to You under this License for that Work shall terminate |
|
| 87 |
+ as of the date such litigation is filed. |
|
| 88 |
+ |
|
| 89 |
+ 4. Redistribution. You may reproduce and distribute copies of the |
|
| 90 |
+ Work or Derivative Works thereof in any medium, with or without |
|
| 91 |
+ modifications, and in Source or Object form, provided that You |
|
| 92 |
+ meet the following conditions: |
|
| 93 |
+ |
|
| 94 |
+ (a) You must give any other recipients of the Work or |
|
| 95 |
+ Derivative Works a copy of this License; and |
|
| 96 |
+ |
|
| 97 |
+ (b) You must cause any modified files to carry prominent notices |
|
| 98 |
+ stating that You changed the files; and |
|
| 99 |
+ |
|
| 100 |
+ (c) You must retain, in the Source form of any Derivative Works |
|
| 101 |
+ that You distribute, all copyright, patent, trademark, and |
|
| 102 |
+ attribution notices from the Source form of the Work, |
|
| 103 |
+ excluding those notices that do not pertain to any part of |
|
| 104 |
+ the Derivative Works; and |
|
| 105 |
+ |
|
| 106 |
+ (d) If the Work includes a "NOTICE" text file as part of its |
|
| 107 |
+ distribution, then any Derivative Works that You distribute must |
|
| 108 |
+ include a readable copy of the attribution notices contained |
|
| 109 |
+ within such NOTICE file, excluding those notices that do not |
|
| 110 |
+ pertain to any part of the Derivative Works, in at least one |
|
| 111 |
+ of the following places: within a NOTICE text file distributed |
|
| 112 |
+ as part of the Derivative Works; within the Source form or |
|
| 113 |
+ documentation, if provided along with the Derivative Works; or, |
|
| 114 |
+ within a display generated by the Derivative Works, if and |
|
| 115 |
+ wherever such third-party notices normally appear. The contents |
|
| 116 |
+ of the NOTICE file are for informational purposes only and |
|
| 117 |
+ do not modify the License. You may add Your own attribution |
|
| 118 |
+ notices within Derivative Works that You distribute, alongside |
|
| 119 |
+ or as an addendum to the NOTICE text from the Work, provided |
|
| 120 |
+ that such additional attribution notices cannot be construed |
|
| 121 |
+ as modifying the License. |
|
| 122 |
+ |
|
| 123 |
+ You may add Your own copyright statement to Your modifications and |
|
| 124 |
+ may provide additional or different license terms and conditions |
|
| 125 |
+ for use, reproduction, or distribution of Your modifications, or |
|
| 126 |
+ for any such Derivative Works as a whole, provided Your use, |
|
| 127 |
+ reproduction, and distribution of the Work otherwise complies with |
|
| 128 |
+ the conditions stated in this License. |
|
| 129 |
+ |
|
| 130 |
+ 5. Submission of Contributions. Unless You explicitly state otherwise, |
|
| 131 |
+ any Contribution intentionally submitted for inclusion in the Work |
|
| 132 |
+ by You to the Licensor shall be under the terms and conditions of |
|
| 133 |
+ this License, without any additional terms or conditions. |
|
| 134 |
+ Notwithstanding the above, nothing herein shall supersede or modify |
|
| 135 |
+ the terms of any separate license agreement you may have executed |
|
| 136 |
+ with Licensor regarding such Contributions. |
|
| 137 |
+ |
|
| 138 |
+ 6. Trademarks. This License does not grant permission to use the trade |
|
| 139 |
+ names, trademarks, service marks, or product names of the Licensor, |
|
| 140 |
+ except as required for reasonable and customary use in describing the |
|
| 141 |
+ origin of the Work and reproducing the content of the NOTICE file. |
|
| 142 |
+ |
|
| 143 |
+ 7. Disclaimer of Warranty. Unless required by applicable law or |
|
| 144 |
+ agreed to in writing, Licensor provides the Work (and each |
|
| 145 |
+ Contributor provides its Contributions) on an "AS IS" BASIS, |
|
| 146 |
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or |
|
| 147 |
+ implied, including, without limitation, any warranties or conditions |
|
| 148 |
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A |
|
| 149 |
+ PARTICULAR PURPOSE. You are solely responsible for determining the |
|
| 150 |
+ appropriateness of using or redistributing the Work and assume any |
|
| 151 |
+ risks associated with Your exercise of permissions under this License. |
|
| 152 |
+ |
|
| 153 |
+ 8. Limitation of Liability. In no event and under no legal theory, |
|
| 154 |
+ whether in tort (including negligence), contract, or otherwise, |
|
| 155 |
+ unless required by applicable law (such as deliberate and grossly |
|
| 156 |
+ negligent acts) or agreed to in writing, shall any Contributor be |
|
| 157 |
+ liable to You for damages, including any direct, indirect, special, |
|
| 158 |
+ incidental, or consequential damages of any character arising as a |
|
| 159 |
+ result of this License or out of the use or inability to use the |
|
| 160 |
+ Work (including but not limited to damages for loss of goodwill, |
|
| 161 |
+ work stoppage, computer failure or malfunction, or any and all |
|
| 162 |
+ other commercial damages or losses), even if such Contributor |
|
| 163 |
+ has been advised of the possibility of such damages. |
|
| 164 |
+ |
|
| 165 |
+ 9. Accepting Warranty or Additional Liability. While redistributing |
|
| 166 |
+ the Work or Derivative Works thereof, You may choose to offer, |
|
| 167 |
+ and charge a fee for, acceptance of support, warranty, indemnity, |
|
| 168 |
+ or other liability obligations and/or rights consistent with this |
|
| 169 |
+ License. However, in accepting such obligations, You may act only |
|
| 170 |
+ on Your own behalf and on Your sole responsibility, not on behalf |
|
| 171 |
+ of any other Contributor, and only if You agree to indemnify, |
|
| 172 |
+ defend, and hold each Contributor harmless for any liability |
|
| 173 |
+ incurred by, or claims asserted against, such Contributor by reason |
|
| 174 |
+ of your accepting any such warranty or additional liability. |
|
| 175 |
+ |
|
| 176 |
+ END OF TERMS AND CONDITIONS |
|
| 177 |
+ |
|
| 178 |
+ APPENDIX: How to apply the Apache License to your work. |
|
| 179 |
+ |
|
| 180 |
+ To apply the Apache License to your work, attach the following |
|
| 181 |
+ boilerplate notice, with the fields enclosed by brackets "[]" |
|
| 182 |
+ replaced with your own identifying information. (Don't include |
|
| 183 |
+ the brackets!) The text should be enclosed in the appropriate |
|
| 184 |
+ comment syntax for the file format. We also recommend that a |
|
| 185 |
+ file or class name and description of purpose be included on the |
|
| 186 |
+ same "printed page" as the copyright notice for easier |
|
| 187 |
+ identification within third-party archives. |
|
| 188 |
+ |
|
| 189 |
+ Copyright [yyyy] [name of copyright owner] |
|
| 190 |
+ |
|
| 191 |
+ Licensed under the Apache License, Version 2.0 (the "License"); |
|
| 192 |
+ you may not use this file except in compliance with the License. |
|
| 193 |
+ You may obtain a copy of the License at |
|
| 194 |
+ |
|
| 195 |
+ http://www.apache.org/licenses/LICENSE-2.0 |
|
| 196 |
+ |
|
| 197 |
+ Unless required by applicable law or agreed to in writing, software |
|
| 198 |
+ distributed under the License is distributed on an "AS IS" BASIS, |
|
| 199 |
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
| 200 |
+ See the License for the specific language governing permissions and |
|
| 201 |
+ limitations under the License. |
| 0 | 202 |
new file mode 100644 |
| ... | ... |
@@ -0,0 +1,16 @@ |
| 0 |
+// Package userns provides utilities to detect whether we are currently running |
|
| 1 |
+// in a Linux user namespace. |
|
| 2 |
+// |
|
| 3 |
+// This code was migrated from [libcontainer/runc], which based its implementation |
|
| 4 |
+// on code from [lcx/incus]. |
|
| 5 |
+// |
|
| 6 |
+// [libcontainer/runc]: https://github.com/opencontainers/runc/blob/3778ae603c706494fd1e2c2faf83b406e38d687d/libcontainer/userns/userns_linux.go#L12-L49 |
|
| 7 |
+// [lcx/incus]: https://github.com/lxc/incus/blob/e45085dd42f826b3c8c3228e9733c0b6f998eafe/shared/util.go#L678-L700 |
|
| 8 |
+package userns |
|
| 9 |
+ |
|
| 10 |
+// RunningInUserNS detects whether we are currently running in a Linux |
|
| 11 |
+// user namespace and memoizes the result. It returns false on non-Linux |
|
| 12 |
+// platforms. |
|
| 13 |
+func RunningInUserNS() bool {
|
|
| 14 |
+ return inUserNS() |
|
| 15 |
+} |
| 0 | 16 |
new file mode 100644 |
| ... | ... |
@@ -0,0 +1,53 @@ |
| 0 |
+package userns |
|
| 1 |
+ |
|
| 2 |
+import ( |
|
| 3 |
+ "bufio" |
|
| 4 |
+ "fmt" |
|
| 5 |
+ "os" |
|
| 6 |
+ "sync" |
|
| 7 |
+) |
|
| 8 |
+ |
|
| 9 |
+var inUserNS = sync.OnceValue(runningInUserNS) |
|
| 10 |
+ |
|
| 11 |
+// runningInUserNS detects whether we are currently running in a user namespace. |
|
| 12 |
+// |
|
| 13 |
+// This code was migrated from [libcontainer/runc] and based on an implementation |
|
| 14 |
+// from [lcx/incus]. |
|
| 15 |
+// |
|
| 16 |
+// [libcontainer/runc]: https://github.com/opencontainers/runc/blob/3778ae603c706494fd1e2c2faf83b406e38d687d/libcontainer/userns/userns_linux.go#L12-L49 |
|
| 17 |
+// [lcx/incus]: https://github.com/lxc/incus/blob/e45085dd42f826b3c8c3228e9733c0b6f998eafe/shared/util.go#L678-L700 |
|
| 18 |
+func runningInUserNS() bool {
|
|
| 19 |
+ file, err := os.Open("/proc/self/uid_map")
|
|
| 20 |
+ if err != nil {
|
|
| 21 |
+ // This kernel-provided file only exists if user namespaces are supported. |
|
| 22 |
+ return false |
|
| 23 |
+ } |
|
| 24 |
+ defer file.Close() |
|
| 25 |
+ |
|
| 26 |
+ buf := bufio.NewReader(file) |
|
| 27 |
+ l, _, err := buf.ReadLine() |
|
| 28 |
+ if err != nil {
|
|
| 29 |
+ return false |
|
| 30 |
+ } |
|
| 31 |
+ |
|
| 32 |
+ return uidMapInUserNS(string(l)) |
|
| 33 |
+} |
|
| 34 |
+ |
|
| 35 |
+func uidMapInUserNS(uidMap string) bool {
|
|
| 36 |
+ if uidMap == "" {
|
|
| 37 |
+ // File exist but empty (the initial state when userns is created, |
|
| 38 |
+ // see user_namespaces(7)). |
|
| 39 |
+ return true |
|
| 40 |
+ } |
|
| 41 |
+ |
|
| 42 |
+ var a, b, c int64 |
|
| 43 |
+ if _, err := fmt.Sscanf(uidMap, "%d %d %d", &a, &b, &c); err != nil {
|
|
| 44 |
+ // Assume we are in a regular, non user namespace. |
|
| 45 |
+ return false |
|
| 46 |
+ } |
|
| 47 |
+ |
|
| 48 |
+ // As per user_namespaces(7), /proc/self/uid_map of |
|
| 49 |
+ // the initial user namespace shows 0 0 4294967295. |
|
| 50 |
+ initNS := a == 0 && b == 0 && c == 4294967295 |
|
| 51 |
+ return !initNS |
|
| 52 |
+} |
| ... | ... |
@@ -968,10 +968,12 @@ github.com/moby/sys/signal |
| 968 | 968 |
# github.com/moby/sys/symlink v0.3.0 |
| 969 | 969 |
## explicit; go 1.17 |
| 970 | 970 |
github.com/moby/sys/symlink |
| 971 |
-# github.com/moby/sys/user v0.2.0 |
|
| 972 |
-## explicit; go 1.21 |
|
| 971 |
+# github.com/moby/sys/user v0.3.0 |
|
| 972 |
+## explicit; go 1.17 |
|
| 973 | 973 |
github.com/moby/sys/user |
| 974 |
-github.com/moby/sys/user/userns |
|
| 974 |
+# github.com/moby/sys/userns v0.1.0 |
|
| 975 |
+## explicit; go 1.21 |
|
| 976 |
+github.com/moby/sys/userns |
|
| 975 | 977 |
# github.com/moby/term v0.5.0 |
| 976 | 978 |
## explicit; go 1.18 |
| 977 | 979 |
github.com/moby/term |