2014-07-21 06:12:49 +00:00
|
|
|
package weed_server
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
2014-10-26 18:34:55 +00:00
|
|
|
|
2018-05-14 06:56:16 +00:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/filer2"
|
2018-05-27 18:52:26 +00:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog"
|
2018-05-16 07:08:44 +00:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb"
|
2018-05-27 18:52:26 +00:00
|
|
|
"strconv"
|
2018-05-16 07:54:44 +00:00
|
|
|
"time"
|
2018-05-30 06:46:17 +00:00
|
|
|
"fmt"
|
2014-07-21 06:12:49 +00:00
|
|
|
)
|
|
|
|
|
2016-07-21 06:45:55 +00:00
|
|
|
func (fs *FilerServer) registerHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
path := r.FormValue("path")
|
|
|
|
fileId := r.FormValue("fileId")
|
2018-05-14 06:56:16 +00:00
|
|
|
fileSize, err := strconv.ParseUint(r.FormValue("fileSize"), 10, 64)
|
|
|
|
if err != nil {
|
2018-05-19 19:07:15 +00:00
|
|
|
glog.V(0).Infof("register %s to %s parse fileSize %s: %v", fileId, path, r.FormValue("fileSize"), err)
|
2018-05-30 06:46:17 +00:00
|
|
|
writeJsonError(w, r, http.StatusInternalServerError, fmt.Errorf("parsing fileSize: %v", err))
|
2018-05-14 06:56:16 +00:00
|
|
|
return
|
|
|
|
}
|
2018-05-21 08:25:30 +00:00
|
|
|
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)
|
2018-05-30 06:46:17 +00:00
|
|
|
writeJsonError(w, r, http.StatusInternalServerError, fmt.Errorf("parsing uid: %v", err))
|
2018-05-21 08:25:30 +00:00
|
|
|
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)
|
2018-05-30 06:46:17 +00:00
|
|
|
writeJsonError(w, r, http.StatusInternalServerError, fmt.Errorf("parsing gid: %v", err))
|
2018-05-21 08:25:30 +00:00
|
|
|
return
|
|
|
|
}
|
2018-05-31 03:24:57 +00:00
|
|
|
mime := r.FormValue("mime")
|
2018-05-14 06:56:16 +00:00
|
|
|
entry := &filer2.Entry{
|
|
|
|
FullPath: filer2.FullPath(path),
|
|
|
|
Attr: filer2.Attr{
|
2018-05-25 06:42:13 +00:00
|
|
|
Mode: 0660,
|
|
|
|
Crtime: time.Now(),
|
|
|
|
Mtime: time.Now(),
|
|
|
|
Uid: uint32(uid),
|
|
|
|
Gid: uint32(gid),
|
2018-05-31 03:24:57 +00:00
|
|
|
Mime: mime,
|
2018-05-14 06:56:16 +00:00
|
|
|
},
|
2018-05-16 07:08:44 +00:00
|
|
|
Chunks: []*filer_pb.FileChunk{{
|
|
|
|
FileId: fileId,
|
|
|
|
Size: fileSize,
|
2018-05-16 07:54:44 +00:00
|
|
|
Mtime: time.Now().UnixNano(),
|
2018-05-14 06:56:16 +00:00
|
|
|
}},
|
|
|
|
}
|
2018-05-19 19:07:15 +00:00
|
|
|
glog.V(2).Infof("register %s to %s parse fileSize %s", fileId, path, r.FormValue("fileSize"))
|
2018-05-14 06:56:16 +00:00
|
|
|
err = fs.filer.CreateEntry(entry)
|
2016-07-21 06:45:55 +00:00
|
|
|
if err != nil {
|
2018-05-26 10:49:46 +00:00
|
|
|
glog.V(0).Infof("register %s to %s error: %v", fileId, path, err)
|
2018-05-30 06:46:17 +00:00
|
|
|
writeJsonError(w, r, http.StatusInternalServerError, fmt.Errorf("create %s: %v", path, err))
|
2016-07-21 06:45:55 +00:00
|
|
|
} else {
|
|
|
|
w.WriteHeader(http.StatusOK)
|
|
|
|
}
|
|
|
|
}
|