package donut import ( "errors" "strconv" "strings" ) type bucketDriver struct { nodes []string } func (b bucketDriver) GetNodes() ([]string, error) { var nodes []string for _, node := range b.nodes { nodes = append(nodes, node) } return nodes, nil } func (b bucketDriver) AddNode(nodeID, bucketID string) error { 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 }