123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- // +build !windows
- package dockerfile // import "github.com/docker/docker/builder/dockerfile"
- import (
- "os"
- "path/filepath"
- "github.com/docker/docker/pkg/containerfs"
- "github.com/docker/docker/pkg/idtools"
- )
- func fixPermissions(source, destination string, identity idtools.Identity, overrideSkip bool) error {
- var (
- skipChownRoot bool
- err error
- )
- if !overrideSkip {
- destEndpoint := ©Endpoint{driver: containerfs.NewLocalDriver(), path: destination}
- skipChownRoot, err = isExistingDirectory(destEndpoint)
- if err != nil {
- return err
- }
- }
- // We Walk on the source rather than on the destination because we don't
- // want to change permissions on things we haven't created or modified.
- return filepath.Walk(source, func(fullpath string, _ os.FileInfo, _ error) error {
- // Do not alter the walk root iff. it existed before, as it doesn't fall under
- // the domain of "things we should chown".
- if skipChownRoot && source == fullpath {
- return nil
- }
- // Path is prefixed by source: substitute with destination instead.
- cleaned, err := filepath.Rel(source, fullpath)
- if err != nil {
- return err
- }
- fullpath = filepath.Join(destination, cleaned)
- return os.Lchown(fullpath, identity.UID, identity.GID)
- })
- }
- func validateCopySourcePath(imageSource *imageMount, origPath, platform string) error {
- return nil
- }
|