-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcgroup_lister.go
81 lines (67 loc) · 2.03 KB
/
cgroup_lister.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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package kadmin
import tea "github.com/charmbracelet/bubbletea"
type CGroupLister interface {
ListCGroups() tea.Msg
}
type ConsumerGroup struct {
Name string
Members []GroupMember
}
type ConsumerGroupListingStartedMsg struct {
Err chan error
ConsumerGroups chan []*ConsumerGroup
}
func (msg *ConsumerGroupListingStartedMsg) AwaitCompletion() tea.Msg {
select {
case groups := <-msg.ConsumerGroups:
return ConsumerGroupsListedMsg{groups}
case err := <-msg.Err:
return ConsumerGroupListingErrorMsg{err}
}
}
type ConsumerGroupsListedMsg struct {
ConsumerGroups []*ConsumerGroup
}
type ConsumerGroupListingErrorMsg struct {
Err error
}
func (ka *SaramaKafkaAdmin) ListCGroups() tea.Msg {
errChan := make(chan error)
groupsChan := make(chan []*ConsumerGroup)
go ka.doListConsumerGroups(groupsChan, errChan)
return ConsumerGroupListingStartedMsg{errChan, groupsChan}
}
func (ka *SaramaKafkaAdmin) doListConsumerGroups(groupsChan chan []*ConsumerGroup, errorChan chan error) {
maybeIntroduceLatency()
if listGroupResponse, err := ka.admin.ListConsumerGroups(); err != nil {
errorChan <- err
} else {
var consumerGroups []*ConsumerGroup
var groupNames []string
var groupByName = make(map[string]*ConsumerGroup)
for name, _ := range listGroupResponse {
consumerGroup := ConsumerGroup{Name: name}
consumerGroups = append(consumerGroups, &consumerGroup)
groupByName[name] = &consumerGroup
groupNames = append(groupNames, name)
}
describeConsumerGroupResponse, err := ka.admin.DescribeConsumerGroups(groupNames)
if err != nil {
errorChan <- err
return
}
for _, groupDescription := range describeConsumerGroupResponse {
group := groupByName[groupDescription.GroupId]
var groupMembers []GroupMember
for _, m := range groupDescription.Members {
member := GroupMember{}
member.MemberId = m.MemberId
member.ClientId = m.ClientId
member.ClientHost = m.ClientHost
groupMembers = append(groupMembers, member)
}
group.Members = groupMembers
}
groupsChan <- consumerGroups
}
}