forked from acm1/list_instances
-
Notifications
You must be signed in to change notification settings - Fork 0
/
instance.go
82 lines (71 loc) · 1.42 KB
/
instance.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
82
package main
import (
"net"
"os"
"sort"
"github.com/aws/aws-sdk-go/service/ec2"
"github.com/olekukonko/tablewriter"
)
type instance struct {
*ec2.Instance
name string
privateIP net.IP
}
func newInstance(i *ec2.Instance) (ret instance) {
ret.Instance = i
ret.privateIP = net.ParseIP(*i.PrivateIpAddress)
for _, t := range i.Tags {
if *t.Key == "Name" {
ret.name = *t.Value
}
}
return ret
}
func (i *instance) toRow() []string {
return []string{
i.name,
*i.InstanceId,
stringify(i.PublicIpAddress),
*i.PrivateIpAddress,
stringify(i.KeyName),
}
}
func stringify(s *string) string {
if s == nil {
return ""
}
return *s
}
type instances []*instance
func (s instances) printTable() {
table := tablewriter.NewWriter(os.Stdout)
table.SetHeader([]string{"Name", "Id", "PublicIP", "PrivateIP", "Key"})
for _, i := range s {
table.Append(i.toRow())
}
table.Render()
}
func (s instances) sort() {
sort.Sort(s)
}
// implement sort.Interface
func (s instances) Len() int { return len(s) }
func (s instances) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
// Less sorts instances by name and then by private IP address
func (s instances) Less(i, j int) bool {
if s[i].name < s[j].name {
return true
}
if s[i].name > s[j].name {
return false
}
for n, v := range s[i].privateIP {
if v < s[j].privateIP[n] {
return true
}
if v > s[j].privateIP[n] {
return false
}
}
return false
}