diff options
| author | Chris Lu <chrislusf@users.noreply.github.com> | 2021-01-28 01:01:31 -0800 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-01-28 01:01:31 -0800 |
| commit | 30cd8c4168ac57c104204258bcda1ef8ec3bcbc0 (patch) | |
| tree | 10c7a4fd2488253ee2b495ac7038abbd1d3ad862 | |
| parent | 5c89ac3f8846a8373b2c503e867df8d0b70501e7 (diff) | |
| parent | ca767fdce1caa6e25d68979266f4c065051f5912 (diff) | |
| download | seaweedfs-csi-driver-30cd8c4168ac57c104204258bcda1ef8ec3bcbc0.tar.xz seaweedfs-csi-driver-30cd8c4168ac57c104204258bcda1ef8ec3bcbc0.zip | |
Merge pull request #12 from danlsgiga/add-volume-mount-params
Add map.uid and map.gid volume mount params via volume context
| -rw-r--r-- | pkg/driver/mounter.go | 7 | ||||
| -rw-r--r-- | pkg/driver/mounter_seaweedfs.go | 18 | ||||
| -rw-r--r-- | pkg/driver/nodeserver.go | 6 |
3 files changed, 23 insertions, 8 deletions
diff --git a/pkg/driver/mounter.go b/pkg/driver/mounter.go index 9aaa84a..5085b49 100644 --- a/pkg/driver/mounter.go +++ b/pkg/driver/mounter.go @@ -4,8 +4,9 @@ import ( "fmt" "time" - "github.com/chrislusf/seaweedfs/weed/glog" "os/exec" + + "github.com/chrislusf/seaweedfs/weed/glog" "k8s.io/utils/mount" ) @@ -19,8 +20,8 @@ type Mounter interface { Mount(target string) error } -func newMounter(bucketName string, driver *SeaweedFsDriver) (Mounter, error) { - return newSeaweedFsMounter(bucketName, driver) +func newMounter(bucketName string, driver *SeaweedFsDriver, volContext map[string]string) (Mounter, error) { + return newSeaweedFsMounter(bucketName, driver, volContext) } func fuseMount(path string, command string, args []string) error { diff --git a/pkg/driver/mounter_seaweedfs.go b/pkg/driver/mounter_seaweedfs.go index d93e736..9d34b5d 100644 --- a/pkg/driver/mounter_seaweedfs.go +++ b/pkg/driver/mounter_seaweedfs.go @@ -10,21 +10,23 @@ import ( type seaweedFsMounter struct { bucketName string driver *SeaweedFsDriver + volContext map[string]string } const ( seaweedFsCmd = "weed" ) -func newSeaweedFsMounter(bucketName string, driver *SeaweedFsDriver) (Mounter, error) { +func newSeaweedFsMounter(bucketName string, driver *SeaweedFsDriver, volContext map[string]string) (Mounter, error) { return &seaweedFsMounter{ bucketName: bucketName, - driver: driver, + driver: driver, + volContext: volContext, }, nil } func (seaweedFs *seaweedFsMounter) Mount(target string) error { - glog.V(0).Infof("mounting %s%s to %s", seaweedFs.driver.filer, seaweedFs.bucketName, target) + glog.V(0).Infof("mounting %s %s to %s", seaweedFs.driver.filer, seaweedFs.bucketName, target) args := []string{ "mount", @@ -35,6 +37,16 @@ func (seaweedFs *seaweedFsMounter) Mount(target string) error { fmt.Sprintf("-filer=%s", seaweedFs.driver.filer), fmt.Sprintf("-filer.path=/buckets/%s", seaweedFs.bucketName), } + + for arg, value := range seaweedFs.volContext { + switch arg { + case "map.uid": + args = append(args, fmt.Sprintf("-map.uid=%s", value)) + case "map.gid": + args = append(args, fmt.Sprintf("-map.gid=%s", value)) + } + } + if seaweedFs.driver.ConcurrentWriters > 0 { args = append(args, fmt.Sprintf("-concurrentWriters=%d", seaweedFs.driver.ConcurrentWriters)) } diff --git a/pkg/driver/nodeserver.go b/pkg/driver/nodeserver.go index 0509f79..71f40ba 100644 --- a/pkg/driver/nodeserver.go +++ b/pkg/driver/nodeserver.go @@ -55,7 +55,9 @@ func (ns *NodeServer) NodePublishVolume(ctx context.Context, req *csi.NodePublis mo = append(mo, "ro") } - mounter, err := newMounter(volumeID, ns.Driver) + volContext := req.GetVolumeContext() + + mounter, err := newMounter(volumeID, ns.Driver, volContext) if err != nil { return nil, err } @@ -163,4 +165,4 @@ func checkMount(targetPath string) (bool, error) { } } return notMnt, nil -}
\ No newline at end of file +} |
