2015-03-22 00:39:39 -07:00
|
|
|
package donut
|
|
|
|
|
2015-03-24 19:58:03 -07:00
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
2015-03-23 20:40:21 -07:00
|
|
|
type donutBucket struct {
|
2015-03-22 00:39:39 -07:00
|
|
|
nodes []string
|
|
|
|
objects map[string][]byte
|
|
|
|
}
|
|
|
|
|
2015-03-23 20:40:21 -07:00
|
|
|
// GetNodes - get list of associated nodes for a given bucket
|
|
|
|
func (b donutBucket) GetNodes() ([]string, error) {
|
2015-03-22 00:39:39 -07:00
|
|
|
var nodes []string
|
2015-03-22 02:53:21 -07:00
|
|
|
for _, node := range b.nodes {
|
2015-03-22 00:39:39 -07:00
|
|
|
nodes = append(nodes, node)
|
|
|
|
}
|
|
|
|
return nodes, nil
|
|
|
|
}
|
2015-03-24 19:58:03 -07:00
|
|
|
|
2015-03-24 21:04:08 -07:00
|
|
|
func (b donutBucket) AddNode(nodeID, bucketID string) error {
|
2015-03-24 19:58:03 -07:00
|
|
|
tokens := strings.Split(bucketID, ":")
|
|
|
|
if len(tokens) != 3 {
|
|
|
|
return errors.New("Bucket ID malformed: " + bucketID)
|
|
|
|
}
|
|
|
|
// bucketName := tokens[0]
|
|
|
|
// aggregate := tokens[1]
|
|
|
|
// aggregate := "0"
|
|
|
|
part, err := strconv.Atoi(tokens[2])
|
|
|
|
if err != nil {
|
|
|
|
return errors.New("Part malformed: " + tokens[2])
|
|
|
|
}
|
|
|
|
b.nodes[part] = nodeID
|
|
|
|
return nil
|
|
|
|
}
|