package weed_server import ( "net/http" "github.com/chrislusf/seaweedfs/weed/filer2" "github.com/chrislusf/seaweedfs/weed/glog" "github.com/chrislusf/seaweedfs/weed/pb/filer_pb" "strconv" "time" "fmt" ) func (fs *FilerServer) registerHandler(w http.ResponseWriter, r *http.Request) { path := r.FormValue("path") fileId := r.FormValue("fileId") fileSize, err := strconv.ParseUint(r.FormValue("fileSize"), 10, 64) if err != nil { glog.V(0).Infof("register %s to %s parse fileSize %s: %v", fileId, path, r.FormValue("fileSize"), err) writeJsonError(w, r, http.StatusInternalServerError, fmt.Errorf("parsing fileSize: %v", err)) return } uid, err := strconv.ParseUint(r.FormValue("uid"), 10, 64) if err != nil && r.FormValue("uid") != "" { glog.V(0).Infof("register %s to %s parse uid %s: %v", fileId, path, r.FormValue("uid"), err) writeJsonError(w, r, http.StatusInternalServerError, fmt.Errorf("parsing uid: %v", err)) return } gid, err := strconv.ParseUint(r.FormValue("gid"), 10, 64) if err != nil && r.FormValue("gid") != "" { glog.V(0).Infof("register %s to %s parse gid %s: %v", fileId, path, r.FormValue("gid"), err) writeJsonError(w, r, http.StatusInternalServerError, fmt.Errorf("parsing gid: %v", err)) return } entry := &filer2.Entry{ FullPath: filer2.FullPath(path), Attr: filer2.Attr{ Mode: 0660, Crtime: time.Now(), Mtime: time.Now(), Uid: uint32(uid), Gid: uint32(gid), }, Chunks: []*filer_pb.FileChunk{{ FileId: fileId, Size: fileSize, Mtime: time.Now().UnixNano(), }}, } glog.V(2).Infof("register %s to %s parse fileSize %s", fileId, path, r.FormValue("fileSize")) err = fs.filer.CreateEntry(entry) if err != nil { glog.V(0).Infof("register %s to %s error: %v", fileId, path, err) writeJsonError(w, r, http.StatusInternalServerError, fmt.Errorf("create %s: %v", path, err)) } else { w.WriteHeader(http.StatusOK) } }