-
Notifications
You must be signed in to change notification settings - Fork 77
/
Copy pathfirewallRule.go
36 lines (29 loc) · 992 Bytes
/
firewallRule.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
package printer
import (
"fmt"
"github.com/vultr/govultr/v2"
)
func FirewallRules(fwr []govultr.FirewallRule, meta *govultr.Meta) {
col := columns{"RULE NUMBER", "ACTION", "TYPE", "PROTOCOL", "PORT", "NETWORK", "SOURCE", "NOTES"}
display(col)
for _, f := range fwr {
display(columns{f.ID, f.Action, f.Type, f.Protocol, f.Port, getFirewallNetwork(f.Subnet, f.SubnetSize), getFirewallSource(f.Source), f.Notes})
}
Meta(meta)
flush()
}
func FirewallRule(fwr *govultr.FirewallRule) {
col := columns{"RULE NUMBER", "ACTION", "TYPE", "PROTOCOL", "PORT", "NETWORK", "SOURCE", "NOTES"}
display(col)
display(columns{fwr.ID, fwr.Action, fwr.Type, fwr.Protocol, fwr.Port, getFirewallNetwork(fwr.Subnet, fwr.SubnetSize), getFirewallSource(fwr.Source), fwr.Notes})
flush()
}
func getFirewallSource(source string) string {
if source == "" {
return "anywhere"
}
return source
}
func getFirewallNetwork(subnet string, size int) string {
return fmt.Sprintf("%s/%d", subnet, size)
}