/
brokers_add.go
59 lines (49 loc) · 1.35 KB
/
brokers_add.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
package brokers
import (
"fmt"
"os"
"github.com/eddyzags/kafkactl/api/client"
"github.com/eddyzags/kafkactl/types"
"github.com/olekukonko/tablewriter"
)
func Add(api client.APIClient, params *types.BrokerAdd) error {
in := map[string]string{
"bindAddress": params.BindAddress,
"constraints": params.Constraints,
"cpus": params.Cpus,
"broker": params.Expr,
"failoverDelay": params.FailoverDelay,
"failoverMaxTries": params.FailoverMaxTries,
"heap": params.Heap,
"jvmOptions": params.JvmOptions,
"log4jOptions": params.Log4jOptions,
"mem": params.Mem,
"options": params.Options,
"port": params.Port,
"stickinessPeriod": params.StickinessPeriod,
"volume": params.Volume,
}
brokers, err := api.BrokerAdd(in)
if err != nil {
return err
}
table := tablewriter.NewWriter(os.Stdout)
table.SetAutoFormatHeaders(false)
table.SetAutoWrapText(false)
table.SetHeader([]string{"ID", "ACTIVE", "CPUS", "MEM", "HEAP", "PORT"})
for _, broker := range brokers {
if broker.Port == "" {
broker.Port = "auto"
}
table.Append([]string{
broker.ID,
fmt.Sprintf("%t", broker.Active),
fmt.Sprintf("%g", broker.Cpus),
fmt.Sprintf("%g", broker.Mem),
fmt.Sprintf("%g", broker.Heap),
broker.Port,
})
}
table.Render()
return nil
}