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

config: platform dependent reference source #310

Merged
merged 1 commit into from
Mar 9, 2016

Conversation

vbatts
Copy link
Member

@vbatts vbatts commented Jan 13, 2016

This introduces verbiage of fields that may occur in json (technically
optional), but is required on certain platforms (e.g. Linux).

Not adding a "name" string, as that is not a requirement yet.

In the event a windows runtime shows up, I could imagine an sid, but
we'll get to that when it happens.

Closes #135
Related to #166

Signed-off-by: Vincent Batts vbatts@hashbangbash.com

// User specifies linux specific user and group information for the container's
// main process.
type User struct {
// UID is the user ID the Process is executed as. (this field is platform dependent)
Copy link
Contributor

Choose a reason for hiding this comment

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

Should we use a json tag to indicate platform dependency? It will help with tooling as well.

Copy link
Member Author

Choose a reason for hiding this comment

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

Good idea

On Wed, Jan 13, 2016, 15:57 Vish Kannan notifications@github.com wrote:

In config.go
#310 (comment):

@@ -33,6 +33,17 @@ type Process struct {
Cwd string json:"cwd"
}

+// User specifies linux specific user and group information for the container's
+// main process.
+type User struct {

  • // UID is the user ID the Process is executed as. (this field is platform dependent)

Should we use a json tag to indicate platform dependency? It will help
with tooling as well.


Reply to this email directly or view it on GitHub
/~https://github.com/opencontainers/specs/pull/310/files#r49670377.

Copy link
Contributor

Choose a reason for hiding this comment

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

Should these tags be added to all Linux specific fields? It is perfectly fine to tackle that in a separate PR, if you agree.
These tags can help with validation.

@vishh
Copy link
Contributor

vishh commented Jan 13, 2016

LGTM

@wking
Copy link
Contributor

wking commented Jan 14, 2016

On Wed, Jan 13, 2016 at 03:53:12PM -0800, Vincent Batts wrote:

In the event a windows runtime shows up, I could imagine an sid,
but we'll get to that when it happens.

+1 on this PR and its punt, but until we have no platform-specific
build decisions I think #135 should stay open. #190 implies that
having *_linux.go is enough to trigger platform-specific build
decisions.

@vbatts vbatts changed the title config: platform dependent user attributes config: platform dependent reference source Jan 14, 2016
@vbatts
Copy link
Member Author

vbatts commented Jan 14, 2016

This PR now addresses all the platform dependent source, not just the User struct.
And added field tags that we can build tooling around.

@vbatts
Copy link
Member Author

vbatts commented Jan 14, 2016

PTAL

@duglin
Copy link
Contributor

duglin commented Jan 14, 2016

looks nice

"name": "proc",
"path": "/proc"
"name": "proc",
"path": "/proc"
Copy link
Contributor

Choose a reason for hiding this comment

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

Most of our other JSON examples use four-space indents, so we probably just want a blanket s/^/ / on this block instead of dropping to two-space indents.

Copy link
Contributor

Choose a reason for hiding this comment

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

And either way, this seems orthogonal to platform-dependent Go types ;).

@wking
Copy link
Contributor

wking commented Jan 14, 2016

On Thu, Jan 14, 2016 at 01:56:28PM -0800, Vincent Batts wrote:

This PR now addresses all the platform dependent source…

You squashed config-linux.md into config.md but left
runtime-config-linux.md as its own file. I'm fine either going with
platform-specific files or per-config files, but I think we should
pick one way or the other.

* **`additionalGids`** (array of ints, optional) specifies additional group ids to be added to the process.
* **`uid`** (int, required on Linux) specifies the user id.
* **`gid`** (int, required on Linux) specifies the group id.
* **`additionalGids`** (array of ints, optional on Linux) specifies additional group ids to be added to the process.
Copy link
Contributor

Choose a reason for hiding this comment

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

It's already said "For Linux-based systems the user structure has the following fields", isn't this additional change kind of redundant?

Copy link
Member Author

Choose a reason for hiding this comment

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

I'll drop that part of the sentence

@hqhq
Copy link
Contributor

hqhq commented Jan 15, 2016

Is the plan to remove *-linux.md and won't add any *-windows.md but all combined into config.md? It's gonna make it really fat, isn't there other way we can do to make specs platforms agnostic?

@vbatts
Copy link
Member Author

vbatts commented Jan 15, 2016

@hqhq that's a fair point

@wking
Copy link
Contributor

wking commented Jan 15, 2016

On Fri, Jan 15, 2016 at 01:29:00AM -0800, Qiang Huang wrote:

Is the plan to remove *-linux.md and won't add any *-windows.md
but all combined into config.md? It's gonna make it really fat,
isn't there other way we can do to make specs platforms agnostic?

Combining the Go (or just changing __linux.go to something else. Does
Go treat linux/_.go as platform-specific?) seems orthogonal to
combining the Markdown docs. We can leave *-linux.md and still have
cross-platform Go.

@wking
Copy link
Contributor

wking commented Jan 15, 2016

On the other hand, lots of folks want a single-page spec (#263), and a
single-page Markdown would make that easier (fixing links 1, etc.).

@duglin
Copy link
Contributor

duglin commented Jan 15, 2016

I have a preference for one file with sections for platform specific stuff. Less of a chance of having to duplicate things (and keep them in-sync). And it easier to then compare the differences between what each platform expects. Besides, the size of these platform specific bits should be small.

@vbatts
Copy link
Member Author

vbatts commented Jan 15, 2016

I started to do runtime*.md, but it was much longer. It was really an arbitrary decision.

@@ -33,6 +36,17 @@ type Process struct {
Cwd string `json:"cwd"`
}

// User specifies linux specific user and group information for the container's
// main process.
type User struct {
Copy link
Contributor

Choose a reason for hiding this comment

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

Should this type be named LinuxUser for the sake of readability?

Copy link
Member Author

Choose a reason for hiding this comment

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

No, because the intention is that as other platforms have their own fields, they still fall in here.

Copy link
Contributor

Choose a reason for hiding this comment

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

+1 and while in there perhaps renaming "Linux" above too - when I first saw Linux Linux ... it made me laugh.

@wking
Copy link
Contributor

wking commented Jan 15, 2016

On Fri, Jan 15, 2016 at 10:19:34AM -0800, Doug Davis wrote:

Besides, the size of these platform specific bits should be small.

Heh.

$ git describe
v0.2.0
$ wc -l config.md
39 config-linux.md
130 config.md
535 runtime-config-linux.md
122 runtime-config.md
826 total

so 70% of our config docs are Linux specific, and that's not even
counting Linux-specific examples like the process entry in config.md
and the mount entry in runtime-config.md. Of course, 1 would bring
that number down a lot, but since we still haven't landed an opt-out
like #237, I'd be surprised if cgroups are moved outside of this spec
before summer (if they get moved out at all).

 Subject: removal of cgroups from the OCI Linux spec
 Date: Wed, 28 Oct 2015 17:01:59 +0000
 Message-ID: <CAD2oYtO1RMCcUp52w-xXemzDTs+J6t4hS5Mm4mX+uBnVONGDfA@mail.gmail.com>

// SelinuxProcessLabel specifies the selinux context that the container process is run as.
SelinuxProcessLabel string `json:"selinuxProcessLabel"`
// Seccomp specifies the seccomp security settings for the container.
Seccomp Seccomp `json:"seccomp"`
Copy link
Contributor

Choose a reason for hiding this comment

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

nit: Make this optional.

Copy link
Member Author

Choose a reason for hiding this comment

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

and a pointer. got it.

@vbatts vbatts force-pushed the multi-platform branch 2 times, most recently from 3878a8d to bd8af9a Compare January 15, 2016 18:41
@wking
Copy link
Contributor

wking commented Jan 15, 2016

On Fri, Jan 15, 2016 at 10:34:21AM -0800, Vincent Batts wrote:

I started to do runtime*.md, but it was much longer.

If we're not comfortable rolling that in, that's fine with me 1, and
if we don't want to develop in a single page, but still provide a
single page view that's also fine with me 2. But if we don't want
squash *-linux.md for the runtime.json spec, I'd suggest rerolling
this series to avoid squashing *-linux.md for the config.json spec.
Otherwise we'll get odd half-squashing if/when we unify runtime.json
and config.json (#284).

@vbatts
Copy link
Member Author

vbatts commented Mar 2, 2016

will need more rebasing, with #329

@vbatts
Copy link
Member Author

vbatts commented Mar 9, 2016

Rebased

@vbatts vbatts added this to the v0.5.0 milestone Mar 9, 2016
This introduces verbiage of fields that may occur in json (technically
optional), but is required on certain platforms (e.g. Linux).

The JSON document will look the same as it presently does, but now the
reference source compiles regardless of platform.

Not adding a "name" string to the user sturct, as that is not a
requirement yet.

In the event a windows runtime shows up, I could imagine an `sid` on the
user struct, but we'll get to that when it happens.

Closes opencontainers#135
Related to opencontainers#166

Signed-off-by: Vincent Batts <vbatts@hashbangbash.com>
@vbatts
Copy link
Member Author

vbatts commented Mar 9, 2016

Rebased

@vbatts
Copy link
Member Author

vbatts commented Mar 9, 2016

@crosbymichael if you would give this a once-over. It ought not be a code/structure change at all.

@crosbymichael
Copy link
Member

LGTM

@vbatts vbatts modified the milestones: v0.4.0, v0.5.0 Mar 9, 2016
vbatts added a commit that referenced this pull request Mar 9, 2016
config: platform dependent reference source
@vbatts vbatts merged commit eea2a6c into opencontainers:master Mar 9, 2016
@vbatts vbatts deleted the multi-platform branch March 9, 2016 20:47
wking added a commit to wking/opencontainer-runtime-spec that referenced this pull request Mar 9, 2016
Through eea2a6c (Merge pull request opencontainers#310 from vbatts/multi-platform,
2016-03-09).

Signed-off-by: W. Trevor King <wking@tremily.us>
wking added a commit to wking/opencontainer-runtime-spec that referenced this pull request Mar 10, 2016
Through eea2a6c (Merge pull request opencontainers#310 from vbatts/multi-platform,
2016-03-09).

Signed-off-by: W. Trevor King <wking@tremily.us>
wking added a commit to wking/opencontainer-runtime-spec that referenced this pull request Sep 14, 2016
These comments first landed in 820131d (*: flatten platform dependent
source, 2016-03-08, opencontainers#310).  But you can tell they're platform
dependent by the platform:"..." tags.  The Go comment doesn't add
any additional information.

Signed-off-by: W. Trevor King <wking@tremily.us>
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.

6 participants