-
Notifications
You must be signed in to change notification settings - Fork 168
/
cluster.go
61 lines (53 loc) · 2.08 KB
/
cluster.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*
Copyright 2014 Outbrain Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package inst
import (
"github.com/outbrain/orchestrator/go/config"
"regexp"
"strings"
)
// ClusterInfo makes for a cluster status/info summary
type ClusterInfo struct {
ClusterName string
ClusterAlias string // Human friendly alias
CountInstances uint
HeuristicLag int64
HasAutomatedMasterRecovery bool
HasAutomatedIntermediateMasterRecovery bool
}
// ReadRecoveryInfo
func (this *ClusterInfo) ReadRecoveryInfo() {
this.HasAutomatedMasterRecovery = this.filtersMatchCluster(config.Config.RecoverMasterClusterFilters)
this.HasAutomatedIntermediateMasterRecovery = this.filtersMatchCluster(config.Config.RecoverIntermediateMasterClusterFilters)
}
// filtersMatchCluster will see whether the given filters match the given cluster details
func (this *ClusterInfo) filtersMatchCluster(filters []string) bool {
for _, filter := range filters {
if strings.HasPrefix(filter, "alias=") {
// Match by exact cluster alias name
alias := strings.SplitN(filter, "=", 2)[1]
if alias == this.ClusterAlias {
return true
}
} else if strings.HasPrefix(filter, "alias~=") {
// Match by cluster alias regex
aliasPattern := strings.SplitN(filter, "~=", 2)[1]
if matched, _ := regexp.MatchString(aliasPattern, this.ClusterAlias); matched {
return true
}
} else if matched, _ := regexp.MatchString(filter, this.ClusterName); matched && filter != "" {
return true
}
}
return false
}