@ -2,6 +2,7 @@ package main
import (
import (
"encoding/json"
"encoding/json"
"errors"
"log"
"log"
"net/http"
"net/http"
"pkg/directory"
"pkg/directory"
@ -70,7 +71,7 @@ func dirAssignHandler(w http.ResponseWriter, r *http.Request) {
func dirAssign2Handler ( w http . ResponseWriter , r * http . Request ) {
func dirAssign2Handler ( w http . ResponseWriter , r * http . Request ) {
c , _ := strconv . Atoi ( r . FormValue ( "count" ) )
c , _ := strconv . Atoi ( r . FormValue ( "count" ) )
rt , err := storage . NewReplicationType ( r . FormValue ( "replication" ) )
rt , err := storage . NewReplicationType ( r . FormValue ( "replication" ) )
if err != nil {
if err != nil {
writeJson ( w , r , map [ string ] string { "error" : err . Error ( ) } )
writeJson ( w , r , map [ string ] string { "error" : err . Error ( ) } )
return
return
}
}
@ -111,22 +112,21 @@ func dirNewStatusHandler(w http.ResponseWriter, r *http.Request) {
writeJson ( w , r , topo . ToMap ( ) )
writeJson ( w , r , topo . ToMap ( ) )
}
}
func volumeGrowHandler ( w http . ResponseWriter , r * http . Request ) {
func volumeGrowHandler ( w http . ResponseWriter , r * http . Request ) {
count := 0
rt , err := storage . NewReplicationType ( r . FormValue ( "replication" ) )
rt , err := storage . NewReplicationType ( r . FormValue ( "replication" ) )
if err != nil {
writeJson ( w , r , map [ string ] string { "error" : err . Error ( ) } )
return
if err == nil {
if count , err = strconv . Atoi ( r . FormValue ( "count" ) ) ; err == nil {
if topo . FreeSpace ( ) < count * rt . GetCopyCount ( ) {
err = errors . New ( "Only " + strconv . Itoa ( topo . FreeSpace ( ) ) + " volumes left! Not enough for " + strconv . Itoa ( count * rt . GetCopyCount ( ) ) )
} else {
count , err = vg . GrowByCountAndType ( count , rt , topo )
}
}
}
count , err := strconv . Atoi ( r . FormValue ( "count" ) )
if topo . FreeSpace ( ) < count * rt . GetCopyCount ( ) {
writeJson ( w , r , map [ string ] string { "error" : "Only " + strconv . Itoa ( topo . FreeSpace ( ) ) + " volumes left! Not enough for " + strconv . Itoa ( count * rt . GetCopyCount ( ) ) } )
return
}
}
if err != nil {
if err != nil {
count , err := vg . GrowByType ( rt , topo )
writeJson ( w , r , map [ string ] interface { } { "count" : count , "error" : err } )
writeJson ( w , r , map [ string ] string { "error" : err . Error ( ) } )
} else {
} else {
count , err := vg . GrowByCountAndType ( count , rt , topo )
writeJson ( w , r , map [ string ] interface { } { "count" : count , "error" : err } )
writeJson ( w , r , map [ string ] interface { } { "count" : count } )
}
}
}
}
@ -144,6 +144,7 @@ func runMaster(cmd *Command, args []string) bool {
http . HandleFunc ( "/vol/grow" , volumeGrowHandler )
http . HandleFunc ( "/vol/grow" , volumeGrowHandler )
mapper . StartRefreshWritableVolumes ( )
mapper . StartRefreshWritableVolumes ( )
topo . StartRefreshWritableVolumes ( )
log . Println ( "Start directory service at http://127.0.0.1:" + strconv . Itoa ( * mport ) )
log . Println ( "Start directory service at http://127.0.0.1:" + strconv . Itoa ( * mport ) )
e := http . ListenAndServe ( ":" + strconv . Itoa ( * mport ) , nil )
e := http . ListenAndServe ( ":" + strconv . Itoa ( * mport ) , nil )