2015-07-16 17:14:58 -04:00
|
|
|
package daemon
|
|
|
|
|
2017-03-15 14:29:12 -04:00
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
|
|
|
|
containertypes "github.com/docker/docker/api/types/container"
|
|
|
|
"github.com/docker/docker/container"
|
|
|
|
)
|
2015-11-12 14:55:17 -05:00
|
|
|
|
2015-07-16 17:14:58 -04:00
|
|
|
// checkIfPathIsInAVolume checks if the path is in a volume. If it is, it
|
|
|
|
// cannot be in a read-only volume. If it is not in a volume, the container
|
|
|
|
// cannot be configured with a read-only rootfs.
|
|
|
|
//
|
2015-11-13 15:51:05 -05:00
|
|
|
// This is a no-op on Windows which does not support read-only volumes, or
|
2016-04-06 15:01:29 -04:00
|
|
|
// extracting to a mount point inside a volume. TODO Windows: FIXME Post-TP5
|
2015-11-12 14:55:17 -05:00
|
|
|
func checkIfPathIsInAVolume(container *container.Container, absPath string) (bool, error) {
|
2015-07-16 17:14:58 -04:00
|
|
|
return false, nil
|
|
|
|
}
|
2016-01-20 18:32:02 -05:00
|
|
|
|
|
|
|
func fixPermissions(source, destination string, uid, gid int, destExisted bool) error {
|
|
|
|
// chown is not supported on Windows
|
|
|
|
return nil
|
|
|
|
}
|
2017-03-15 14:29:12 -04:00
|
|
|
|
|
|
|
// isOnlineFSOperationPermitted returns an error if an online filesystem operation
|
|
|
|
// is not permitted (such as stat or for copying). Running Hyper-V containers
|
|
|
|
// cannot have their file-system interrogated from the host as the filter is
|
|
|
|
// loaded inside the utility VM, not the host.
|
|
|
|
// IMPORTANT: The container lock must NOT be held when calling this function.
|
|
|
|
func (daemon *Daemon) isOnlineFSOperationPermitted(container *container.Container) error {
|
|
|
|
if !container.IsRunning() {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Determine isolation. If not specified in the hostconfig, use daemon default.
|
|
|
|
actualIsolation := container.HostConfig.Isolation
|
|
|
|
if containertypes.Isolation.IsDefault(containertypes.Isolation(actualIsolation)) {
|
|
|
|
actualIsolation = daemon.defaultIsolation
|
|
|
|
}
|
|
|
|
if containertypes.Isolation.IsHyperV(actualIsolation) {
|
|
|
|
return errors.New("filesystem operations against a running Hyper-V container are not supported")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|