Files
matchbox/api/groups.go
Dalton Hubble d9b5f10eb7 config: Require a -config file to run the api server
* Exit if no config file is supplied and the default doesn't exist
2016-01-14 16:16:37 -08:00

71 lines
1.7 KiB
Go

package api
import (
"fmt"
"sort"
)
// Group associates matcher conditions with a Specification identifier. The
// Matcher conditions may be satisfied by zero or more machines.
type Group struct {
// Human readable name (optional)
Name string `yaml:"name"`
// Spec identifier
Spec string `yaml:"spec"`
// matcher conditions
Matcher RequirementSet `yaml:"require"`
}
// byMatcher defines a collection of Group structs which have a deterministic
// order in increasing number of Matchers, then by sorted key/value pair strings.
// For example, Matcher {a:b, c:d} is ordered before {a:d, c:d} and {a:b, d:e}.
type byMatcher []Group
func (g byMatcher) Len() int {
return len(g)
}
func (g byMatcher) Swap(i, j int) {
g[i], g[j] = g[j], g[i]
}
func (g byMatcher) Less(i, j int) bool {
if len(g[i].Matcher) == len(g[j].Matcher) {
return g[i].Matcher.String() < g[j].Matcher.String()
}
return len(g[i].Matcher) < len(g[j].Matcher)
}
type groupsResource struct {
store Store
}
func newGroupsResource(store Store) *groupsResource {
res := &groupsResource{
store: store,
}
return res
}
// listGroups lists all Group resources.
func (r *groupsResource) listGroups() ([]Group, error) {
return r.store.ListGroups()
}
// findMatch returns the first Group whose Matcher is satisfied by the given
// labels. Groups are attempted in sorted order, preferring those with
// more matcher conditions, alphabetically.
func (r *groupsResource) findMatch(labels Labels) (*Group, error) {
groups, err := r.store.ListGroups()
if err != nil {
return nil, err
}
sort.Sort(sort.Reverse(byMatcher(groups)))
for _, group := range groups {
if group.Matcher.Matches(labels) {
return &group, nil
}
}
return nil, fmt.Errorf("no Group matching %v", labels)
}