mirror of
https://github.com/linuxkit/linuxkit.git
synced 2025-07-21 10:09:07 +00:00
Merge pull request #75 from justincormack/perm
Allow setting of mode in files section
This commit is contained in:
commit
35ee128bfd
@ -518,6 +518,9 @@ func tarAppend(iw *tar.Writer, tr *tar.Reader) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func filesystem(m Moby, tw *tar.Writer) error {
|
func filesystem(m Moby, tw *tar.Writer) error {
|
||||||
|
// TODO also include the files added in other parts of the build
|
||||||
|
var addedFiles = map[string]bool{}
|
||||||
|
|
||||||
if len(m.Files) != 0 {
|
if len(m.Files) != 0 {
|
||||||
log.Infof("Add files:")
|
log.Infof("Add files:")
|
||||||
}
|
}
|
||||||
@ -526,6 +529,27 @@ func filesystem(m Moby, tw *tar.Writer) error {
|
|||||||
if f.Path == "" {
|
if f.Path == "" {
|
||||||
return errors.New("Did not specify path for file")
|
return errors.New("Did not specify path for file")
|
||||||
}
|
}
|
||||||
|
mode := int64(0600)
|
||||||
|
if f.Directory {
|
||||||
|
mode = 0700
|
||||||
|
}
|
||||||
|
if f.Mode != "" {
|
||||||
|
var err error
|
||||||
|
mode, err = strconv.ParseInt(f.Mode, 8, 32)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("Cannot parse file mode as octal value: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dirMode := mode
|
||||||
|
if dirMode&0700 != 0 {
|
||||||
|
dirMode |= 0100
|
||||||
|
}
|
||||||
|
if dirMode&0070 != 0 {
|
||||||
|
dirMode |= 0010
|
||||||
|
}
|
||||||
|
if dirMode&0007 != 0 {
|
||||||
|
dirMode |= 0001
|
||||||
|
}
|
||||||
if !f.Directory && f.Contents == "" && f.Symlink == "" {
|
if !f.Directory && f.Contents == "" && f.Symlink == "" {
|
||||||
if f.Source == "" {
|
if f.Source == "" {
|
||||||
return errors.New("Contents of file not specified")
|
return errors.New("Contents of file not specified")
|
||||||
@ -550,17 +574,20 @@ func filesystem(m Moby, tw *tar.Writer) error {
|
|||||||
} else {
|
} else {
|
||||||
root = root + "/" + p
|
root = root + "/" + p
|
||||||
}
|
}
|
||||||
|
if !addedFiles[root] {
|
||||||
hdr := &tar.Header{
|
hdr := &tar.Header{
|
||||||
Name: root,
|
Name: root,
|
||||||
Typeflag: tar.TypeDir,
|
Typeflag: tar.TypeDir,
|
||||||
Mode: 0700,
|
Mode: dirMode,
|
||||||
}
|
}
|
||||||
err := tw.WriteHeader(hdr)
|
err := tw.WriteHeader(hdr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
addedFiles[root] = true
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
addedFiles[f.Path] = true
|
||||||
if f.Directory {
|
if f.Directory {
|
||||||
if f.Contents != "" {
|
if f.Contents != "" {
|
||||||
return errors.New("Directory with contents not allowed")
|
return errors.New("Directory with contents not allowed")
|
||||||
@ -568,7 +595,7 @@ func filesystem(m Moby, tw *tar.Writer) error {
|
|||||||
hdr := &tar.Header{
|
hdr := &tar.Header{
|
||||||
Name: f.Path,
|
Name: f.Path,
|
||||||
Typeflag: tar.TypeDir,
|
Typeflag: tar.TypeDir,
|
||||||
Mode: 0700,
|
Mode: mode,
|
||||||
}
|
}
|
||||||
err := tw.WriteHeader(hdr)
|
err := tw.WriteHeader(hdr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -578,7 +605,7 @@ func filesystem(m Moby, tw *tar.Writer) error {
|
|||||||
hdr := &tar.Header{
|
hdr := &tar.Header{
|
||||||
Name: f.Path,
|
Name: f.Path,
|
||||||
Typeflag: tar.TypeSymlink,
|
Typeflag: tar.TypeSymlink,
|
||||||
Mode: 0600,
|
Mode: mode,
|
||||||
Linkname: f.Symlink,
|
Linkname: f.Symlink,
|
||||||
}
|
}
|
||||||
err := tw.WriteHeader(hdr)
|
err := tw.WriteHeader(hdr)
|
||||||
@ -588,7 +615,7 @@ func filesystem(m Moby, tw *tar.Writer) error {
|
|||||||
} else {
|
} else {
|
||||||
hdr := &tar.Header{
|
hdr := &tar.Header{
|
||||||
Name: f.Path,
|
Name: f.Path,
|
||||||
Mode: 0600,
|
Mode: mode,
|
||||||
Size: int64(len(f.Contents)),
|
Size: int64(len(f.Contents)),
|
||||||
}
|
}
|
||||||
err := tw.WriteHeader(hdr)
|
err := tw.WriteHeader(hdr)
|
||||||
|
@ -32,6 +32,7 @@ type Moby struct {
|
|||||||
Symlink string
|
Symlink string
|
||||||
Contents string
|
Contents string
|
||||||
Source string
|
Source string
|
||||||
|
Mode string
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,7 +22,8 @@ var schema = string(`
|
|||||||
"directory": {"type": "boolean"},
|
"directory": {"type": "boolean"},
|
||||||
"symlink": {"type": "string"},
|
"symlink": {"type": "string"},
|
||||||
"contents": {"type": "string"},
|
"contents": {"type": "string"},
|
||||||
"source": {"type": "string"}
|
"source": {"type": "string"},
|
||||||
|
"mode": {"type": "string"}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"files": {
|
"files": {
|
||||||
|
Loading…
Reference in New Issue
Block a user