|
@ -1,60 +0,0 @@ |
|
|
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 |
|
|
|
|
|
} |
|
|
|
|
|
mime := r.FormValue("mime") |
|
|
|
|
|
entry := &filer2.Entry{ |
|
|
|
|
|
FullPath: filer2.FullPath(path), |
|
|
|
|
|
Attr: filer2.Attr{ |
|
|
|
|
|
Mode: 0660, |
|
|
|
|
|
Crtime: time.Now(), |
|
|
|
|
|
Mtime: time.Now(), |
|
|
|
|
|
Uid: uint32(uid), |
|
|
|
|
|
Gid: uint32(gid), |
|
|
|
|
|
Mime: mime, |
|
|
|
|
|
}, |
|
|
|
|
|
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) |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|