|  |  | @ -128,59 +128,28 @@ func (dir *Dir) newDirectory(fullpath util.FullPath, entry *filer_pb.Entry) fs.N | 
			
		
	
		
			
				
					|  |  |  | func (dir *Dir) Create(ctx context.Context, req *fuse.CreateRequest, | 
			
		
	
		
			
				
					|  |  |  | 	resp *fuse.CreateResponse) (fs.Node, fs.Handle, error) { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 	request, err := dir.doCreateEntry(req.Name, req.Mode, req.Uid, req.Gid, req.Flags&fuse.OpenExclusive != 0) | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 	if err != nil { | 
			
		
	
		
			
				
					|  |  |  | 		return nil, nil, err | 
			
		
	
		
			
				
					|  |  |  | 	} | 
			
		
	
		
			
				
					|  |  |  | 	var node fs.Node | 
			
		
	
		
			
				
					|  |  |  | 	if request.Entry.IsDirectory { | 
			
		
	
		
			
				
					|  |  |  | 		node = dir.newDirectory(util.NewFullPath(dir.FullPath(), req.Name), request.Entry) | 
			
		
	
		
			
				
					|  |  |  | 		return node, nil, nil | 
			
		
	
		
			
				
					|  |  |  | 	} | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 	node = dir.newFile(req.Name, request.Entry) | 
			
		
	
		
			
				
					|  |  |  | 	file := node.(*File) | 
			
		
	
		
			
				
					|  |  |  | 	fh := dir.wfs.AcquireHandle(file, req.Uid, req.Gid) | 
			
		
	
		
			
				
					|  |  |  | 	return file, fh, nil | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | func (dir *Dir) Mknod(ctx context.Context, req *fuse.MknodRequest) (fs.Node, error) { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 	request, err := dir.doCreateEntry(req.Name, req.Mode, req.Uid, req.Gid, false) | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 	if err != nil { | 
			
		
	
		
			
				
					|  |  |  | 		return nil, err | 
			
		
	
		
			
				
					|  |  |  | 	} | 
			
		
	
		
			
				
					|  |  |  | 	var node fs.Node | 
			
		
	
		
			
				
					|  |  |  | 	node = dir.newFile(req.Name, request.Entry) | 
			
		
	
		
			
				
					|  |  |  | 	return node, nil | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | func (dir *Dir) doCreateEntry(name string, mode os.FileMode, uid, gid uint32, exlusive bool) (*filer_pb.CreateEntryRequest, error) { | 
			
		
	
		
			
				
					|  |  |  | 	request := &filer_pb.CreateEntryRequest{ | 
			
		
	
		
			
				
					|  |  |  | 		Directory: dir.FullPath(), | 
			
		
	
		
			
				
					|  |  |  | 		Entry: &filer_pb.Entry{ | 
			
		
	
		
			
				
					|  |  |  | 			Name:        name, | 
			
		
	
		
			
				
					|  |  |  | 			IsDirectory: mode&os.ModeDir > 0, | 
			
		
	
		
			
				
					|  |  |  | 			Name:        req.Name, | 
			
		
	
		
			
				
					|  |  |  | 			IsDirectory: req.Mode&os.ModeDir > 0, | 
			
		
	
		
			
				
					|  |  |  | 			Attributes: &filer_pb.FuseAttributes{ | 
			
		
	
		
			
				
					|  |  |  | 				Mtime:       time.Now().Unix(), | 
			
		
	
		
			
				
					|  |  |  | 				Crtime:      time.Now().Unix(), | 
			
		
	
		
			
				
					|  |  |  | 				FileMode:    uint32(mode &^ dir.wfs.option.Umask), | 
			
		
	
		
			
				
					|  |  |  | 				Uid:         uid, | 
			
		
	
		
			
				
					|  |  |  | 				Gid:         gid, | 
			
		
	
		
			
				
					|  |  |  | 				FileMode:    uint32(req.Mode &^ dir.wfs.option.Umask), | 
			
		
	
		
			
				
					|  |  |  | 				Uid:         req.Uid, | 
			
		
	
		
			
				
					|  |  |  | 				Gid:         req.Gid, | 
			
		
	
		
			
				
					|  |  |  | 				Collection:  dir.wfs.option.Collection, | 
			
		
	
		
			
				
					|  |  |  | 				Replication: dir.wfs.option.Replication, | 
			
		
	
		
			
				
					|  |  |  | 				TtlSec:      dir.wfs.option.TtlSec, | 
			
		
	
		
			
				
					|  |  |  | 			}, | 
			
		
	
		
			
				
					|  |  |  | 		}, | 
			
		
	
		
			
				
					|  |  |  | 		OExcl: exlusive, | 
			
		
	
		
			
				
					|  |  |  | 		OExcl:      req.Flags&fuse.OpenExclusive != 0, | 
			
		
	
		
			
				
					|  |  |  | 		Signatures: []int32{dir.wfs.signature}, | 
			
		
	
		
			
				
					|  |  |  | 	} | 
			
		
	
		
			
				
					|  |  |  | 	glog.V(1).Infof("create %s/%s: %v", dir.FullPath(), name) | 
			
		
	
		
			
				
					|  |  |  | 	glog.V(1).Infof("create %s/%s: %v", dir.FullPath(), req.Name, req.Flags) | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 	err := dir.wfs.WithFilerClient(func(client filer_pb.SeaweedFilerClient) error { | 
			
		
	
		
			
				
					|  |  |  | 	if err := dir.wfs.WithFilerClient(func(client filer_pb.SeaweedFilerClient) error { | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 		dir.wfs.mapPbIdFromLocalToFiler(request.Entry) | 
			
		
	
		
			
				
					|  |  |  | 		defer dir.wfs.mapPbIdFromFilerToLocal(request.Entry) | 
			
		
	
	
		
			
				
					|  |  | @ -189,15 +158,41 @@ func (dir *Dir) doCreateEntry(name string, mode os.FileMode, uid, gid uint32, ex | 
			
		
	
		
			
				
					|  |  |  | 			if strings.Contains(err.Error(), "EEXIST") { | 
			
		
	
		
			
				
					|  |  |  | 				return fuse.EEXIST | 
			
		
	
		
			
				
					|  |  |  | 			} | 
			
		
	
		
			
				
					|  |  |  | 			glog.V(0).Infof("create %s/%s: %v", dir.FullPath(), name, err) | 
			
		
	
		
			
				
					|  |  |  | 			glog.V(0).Infof("create %s/%s: %v", dir.FullPath(), req.Name, err) | 
			
		
	
		
			
				
					|  |  |  | 			return fuse.EIO | 
			
		
	
		
			
				
					|  |  |  | 		} | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 		dir.wfs.metaCache.InsertEntry(context.Background(), filer.FromPbEntry(request.Directory, request.Entry)) | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 		return nil | 
			
		
	
		
			
				
					|  |  |  | 	}) | 
			
		
	
		
			
				
					|  |  |  | 	return request, err | 
			
		
	
		
			
				
					|  |  |  | 	}); err != nil { | 
			
		
	
		
			
				
					|  |  |  | 		return nil, nil, err | 
			
		
	
		
			
				
					|  |  |  | 	} | 
			
		
	
		
			
				
					|  |  |  | 	var node fs.Node | 
			
		
	
		
			
				
					|  |  |  | 	if request.Entry.IsDirectory { | 
			
		
	
		
			
				
					|  |  |  | 		node = dir.newDirectory(util.NewFullPath(dir.FullPath(), req.Name), request.Entry) | 
			
		
	
		
			
				
					|  |  |  | 		return node, nil, nil | 
			
		
	
		
			
				
					|  |  |  | 	} | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 	node = dir.newFile(req.Name, request.Entry) | 
			
		
	
		
			
				
					|  |  |  | 	file := node.(*File) | 
			
		
	
		
			
				
					|  |  |  | 	fh := dir.wfs.AcquireHandle(file, req.Uid, req.Gid) | 
			
		
	
		
			
				
					|  |  |  | 	return file, fh, nil | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | func (dir *Dir) Mknod(ctx context.Context, req *fuse.MknodRequest) (fs.Node, error) { | 
			
		
	
		
			
				
					|  |  |  | 	if req.Mode&os.ModeNamedPipe != 0 { | 
			
		
	
		
			
				
					|  |  |  | 		glog.V(1).Infof("mknod named pipe %s", req.String()) | 
			
		
	
		
			
				
					|  |  |  | 		return nil, fuse.ENOSYS | 
			
		
	
		
			
				
					|  |  |  | 	} | 
			
		
	
		
			
				
					|  |  |  | 	if req.Mode&req.Mode&os.ModeSocket != 0 { | 
			
		
	
		
			
				
					|  |  |  | 		glog.V(1).Infof("mknod socket %s", req.String()) | 
			
		
	
		
			
				
					|  |  |  | 		return nil, fuse.ENOSYS | 
			
		
	
		
			
				
					|  |  |  | 	} | 
			
		
	
		
			
				
					|  |  |  | 	// not going to support mknod for normal files either
 | 
			
		
	
		
			
				
					|  |  |  | 	glog.V(1).Infof("mknod %s", req.String()) | 
			
		
	
		
			
				
					|  |  |  | 	return nil, fuse.ENOSYS | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | func (dir *Dir) Mkdir(ctx context.Context, req *fuse.MkdirRequest) (fs.Node, error) { | 
			
		
	
	
		
			
				
					|  |  | 
 |