2014-04-14 15:13:18 +08:00
|
|
|
package weed_server
|
|
|
|
|
|
|
|
import (
|
2014-10-27 02:34:55 +08:00
|
|
|
"net/http"
|
|
|
|
"path/filepath"
|
|
|
|
|
2014-09-25 16:57:22 +08:00
|
|
|
"github.com/chrislusf/weed-fs/go/glog"
|
|
|
|
"github.com/chrislusf/weed-fs/go/stats"
|
|
|
|
"github.com/chrislusf/weed-fs/go/util"
|
2014-04-14 15:13:18 +08: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 16:19:32 +08:00
|
|
|
writeJsonQuiet(w, r, http.StatusOK, m)
|
2014-04-14 15:13:18 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func (vs *VolumeServer) assignVolumeHandler(w http.ResponseWriter, r *http.Request) {
|
2014-09-21 03:38:59 +08:00
|
|
|
err := vs.store.AddVolume(r.FormValue("volume"), r.FormValue("collection"), r.FormValue("replication"), r.FormValue("ttl"))
|
2014-04-14 15:13:18 +08:00
|
|
|
if err == nil {
|
2015-01-08 16:19:32 +08:00
|
|
|
writeJsonQuiet(w, r, http.StatusAccepted, map[string]string{"error": ""})
|
2014-04-14 15:13:18 +08:00
|
|
|
} else {
|
2015-01-08 16:19:32 +08:00
|
|
|
writeJsonError(w, r, http.StatusNotAcceptable, err)
|
2014-04-14 15:13:18 +08:00
|
|
|
}
|
|
|
|
glog.V(2).Infoln("assign volume =", r.FormValue("volume"), ", collection =", r.FormValue("collection"), ", replication =", r.FormValue("replication"), ", error =", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (vs *VolumeServer) deleteCollectionHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
if "benchmark" != r.FormValue("collection") {
|
|
|
|
glog.V(0).Infoln("deleting collection =", r.FormValue("collection"), "!!!")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
err := vs.store.DeleteCollection(r.FormValue("collection"))
|
|
|
|
if err == nil {
|
2015-01-08 16:19:32 +08:00
|
|
|
writeJsonQuiet(w, r, http.StatusOK, map[string]string{"error": ""})
|
2014-04-14 15:13:18 +08:00
|
|
|
} else {
|
2015-01-08 16:19:32 +08:00
|
|
|
writeJsonError(w, r, http.StatusInternalServerError, err)
|
2014-04-14 15:13:18 +08:00
|
|
|
}
|
|
|
|
glog.V(2).Infoln("deleting collection =", r.FormValue("collection"), ", error =", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (vs *VolumeServer) freezeVolumeHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
//TODO: notify master that this volume will be read-only
|
|
|
|
err := vs.store.FreezeVolume(r.FormValue("volume"))
|
|
|
|
if err == nil {
|
2015-01-08 16:19:32 +08:00
|
|
|
writeJsonQuiet(w, r, http.StatusOK, map[string]string{"error": ""})
|
2014-04-14 15:13:18 +08:00
|
|
|
} else {
|
2015-01-08 16:19:32 +08:00
|
|
|
writeJsonError(w, r, http.StatusInternalServerError, err)
|
2014-04-14 15:13:18 +08:00
|
|
|
}
|
|
|
|
glog.V(2).Infoln("freeze volume =", r.FormValue("volume"), ", error =", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (vs *VolumeServer) statsDiskHandler(w http.ResponseWriter, r *http.Request) {
|
|
|
|
m := make(map[string]interface{})
|
|
|
|
m["Version"] = util.VERSION
|
2015-03-10 15:20:31 +08:00
|
|
|
var ds []*stats.DiskStatus
|
2014-04-14 15:13:18 +08:00
|
|
|
for _, loc := range vs.store.Locations {
|
|
|
|
if dir, e := filepath.Abs(loc.Directory); e == nil {
|
|
|
|
ds = append(ds, stats.NewDiskStatus(dir))
|
|
|
|
}
|
|
|
|
}
|
2015-03-20 01:39:22 +08:00
|
|
|
m["DiskStatuses"] = ds
|
2015-01-08 16:19:32 +08:00
|
|
|
writeJsonQuiet(w, r, http.StatusOK, m)
|
2014-04-14 15:13:18 +08:00
|
|
|
}
|