seaweedfs/go/topology/allocate_volume.go

36 lines
881 B
Go
Raw Normal View History

package topology
2012-09-21 09:02:56 +08:00
import (
2013-02-27 14:54:22 +08:00
"encoding/json"
"errors"
"fmt"
2013-02-27 14:54:22 +08:00
"net/url"
"github.com/chrislusf/seaweedfs/go/storage"
"github.com/chrislusf/seaweedfs/go/util"
2012-09-21 09:02:56 +08:00
)
type AllocateVolumeResult struct {
2013-01-17 16:56:56 +08:00
Error string
2012-09-21 09:02:56 +08:00
}
func AllocateVolume(dn *DataNode, vid storage.VolumeId, option *VolumeGrowOption) error {
2013-01-17 16:56:56 +08:00
values := make(url.Values)
values.Add("volume", vid.String())
values.Add("collection", option.Collection)
values.Add("replication", option.ReplicaPlacement.String())
values.Add("ttl", option.Ttl.String())
jsonBlob, err := util.Post("http://"+dn.Url()+"/admin/assign_volume", values)
2013-01-17 16:56:56 +08:00
if err != nil {
return err
}
var ret AllocateVolumeResult
if err := json.Unmarshal(jsonBlob, &ret); err != nil {
return fmt.Errorf("Invalid JSON result for %s: %s", "/admin/assign_volum", string(jsonBlob))
2013-01-17 16:56:56 +08:00
}
if ret.Error != "" {
return errors.New(ret.Error)
}
return nil
2012-09-21 09:02:56 +08:00
}