2014-04-14 07:13:18 +00:00
|
|
|
package weed_server
|
|
|
|
|
|
|
|
import (
|
2017-01-20 12:02:37 +00:00
|
|
|
"fmt"
|
2014-10-26 18:34:55 +00:00
|
|
|
"net/http"
|
|
|
|
"path/filepath"
|
2017-01-08 19:01:46 +00:00
|
|
|
"strconv"
|
2014-10-26 18:34:55 +00:00
|
|
|
|
2016-06-03 01:09:14 +00:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog"
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/stats"
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/util"
|
2017-01-20 12:02:37 +00:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/storage"
|
2014-04-14 07:13:18 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func (vs *VolumeServer) statusHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
m := make(map[string]interface{})
|
|
|
|
m["Version"] = util.VERSION
|
|
|
|
m["Volumes"] = vs.store.Status()
|
2015-01-08 08:19:32 +00:00
|
|
|
writeJsonQuiet(w, r, http.StatusOK, m)
|
2014-04-14 07:13:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (vs *VolumeServer) assignVolumeHandler(w http.ResponseWriter, r *http.Request) {
|
2017-01-08 19:01:46 +00:00
|
|
|
var err error
|
|
|
|
preallocate := int64(0)
|
|
|
|
if r.FormValue("preallocate") != "" {
|
|
|
|
preallocate, err = strconv.ParseInt(r.FormValue("preallocate"), 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
glog.V(0).Infoln("ignoring invalid int64 value for preallocate = %v", r.FormValue("preallocate"))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
err = vs.store.AddVolume(
|
|
|
|
r.FormValue("volume"),
|
|
|
|
r.FormValue("collection"),
|
|
|
|
vs.needleMapKind,
|
|
|
|
r.FormValue("replication"),
|
|
|
|
r.FormValue("ttl"),
|
|
|
|
preallocate,
|
|
|
|
)
|
2014-04-14 07:13:18 +00:00
|
|
|
if err == nil {
|
2015-01-08 08:19:32 +00:00
|
|
|
writeJsonQuiet(w, r, http.StatusAccepted, map[string]string{"error": ""})
|
2014-04-14 07:13:18 +00:00
|
|
|
} else {
|
2015-01-08 08:19:32 +00:00
|
|
|
writeJsonError(w, r, http.StatusNotAcceptable, err)
|
2014-04-14 07:13:18 +00:00
|
|
|
}
|
2017-01-08 19:01:46 +00:00
|
|
|
glog.V(2).Infoln("assign volume = %s, collection = %s , replication = %s, error = %v",
|
|
|
|
r.FormValue("volume"), r.FormValue("collection"), r.FormValue("replication"), err)
|
2014-04-14 07:13:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (vs *VolumeServer) deleteCollectionHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
err := vs.store.DeleteCollection(r.FormValue("collection"))
|
|
|
|
if err == nil {
|
2015-01-08 08:19:32 +00:00
|
|
|
writeJsonQuiet(w, r, http.StatusOK, map[string]string{"error": ""})
|
2014-04-14 07:13:18 +00:00
|
|
|
} else {
|
2015-01-08 08:19:32 +00:00
|
|
|
writeJsonError(w, r, http.StatusInternalServerError, err)
|
2014-04-14 07:13:18 +00:00
|
|
|
}
|
2017-01-08 19:01:46 +00:00
|
|
|
glog.V(2).Infof("deleting collection = %s, error = %v", r.FormValue("collection"), err)
|
2014-04-14 07:13:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (vs *VolumeServer) statsDiskHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
m := make(map[string]interface{})
|
|
|
|
m["Version"] = util.VERSION
|
2015-03-10 07:20:31 +00:00
|
|
|
var ds []*stats.DiskStatus
|
2014-04-14 07:13:18 +00:00
|
|
|
for _, loc := range vs.store.Locations {
|
|
|
|
if dir, e := filepath.Abs(loc.Directory); e == nil {
|
|
|
|
ds = append(ds, stats.NewDiskStatus(dir))
|
|
|
|
}
|
|
|
|
}
|
2015-03-19 17:39:22 +00:00
|
|
|
m["DiskStatuses"] = ds
|
2015-01-08 08:19:32 +00:00
|
|
|
writeJsonQuiet(w, r, http.StatusOK, m)
|
2014-04-14 07:13:18 +00:00
|
|
|
}
|
2017-01-20 12:02:37 +00:00
|
|
|
|
|
|
|
func (vs *VolumeServer) getVolume(volumeParameterName string, r *http.Request) (*storage.Volume, error) {
|
|
|
|
vid, err := vs.getVolumeId(volumeParameterName, r)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
v := vs.store.GetVolume(vid)
|
|
|
|
if v == nil {
|
|
|
|
return nil, fmt.Errorf("Not Found Volume Id %d", vid)
|
|
|
|
}
|
|
|
|
return v, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (vs *VolumeServer) getVolumeMountHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
vid, err := vs.getVolumeId("volume", r)
|
|
|
|
if err != nil {
|
|
|
|
writeJsonError(w, r, http.StatusNotFound, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
vs.store.MountVolume(vid)
|
|
|
|
writeJsonQuiet(w, r, http.StatusOK, "Volume mounted")
|
|
|
|
}
|
|
|
|
|
|
|
|
func (vs *VolumeServer) getVolumeUnmountHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
vid, err := vs.getVolumeId("volume", r)
|
|
|
|
if err != nil {
|
|
|
|
writeJsonError(w, r, http.StatusNotFound, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
vs.store.UnmountVolume(vid)
|
|
|
|
writeJsonQuiet(w, r, http.StatusOK, "Volume unmounted")
|
|
|
|
}
|
|
|
|
|
|
|
|
func (vs *VolumeServer) getVolumeDeleteHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
vid, err := vs.getVolumeId("volume", r)
|
|
|
|
if err != nil {
|
|
|
|
writeJsonError(w, r, http.StatusNotFound, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
vs.store.DeleteVolume(vid)
|
|
|
|
writeJsonQuiet(w, r, http.StatusOK, "Volume deleted")
|
|
|
|
}
|