/
list.go
61 lines (54 loc) · 1.5 KB
/
list.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
package domains
import (
"fmt"
"os"
"github.com/Scalingo/cli/config"
scalingo "github.com/Scalingo/go-scalingo"
"github.com/olekukonko/tablewriter"
"gopkg.in/errgo.v1"
)
var letsencryptStatusString = map[string]string{
string(scalingo.LetsEncryptStatusPendingDNS): "Pending DNS",
string(scalingo.LetsEncryptStatusNew): "Creating",
string(scalingo.LetsEncryptStatusCreated): "In use",
string(scalingo.LetsEncryptStatusDNSRequired): "DNS required",
string(scalingo.LetsEncryptStatusError): "Error",
}
func List(app string) error {
c, err := config.ScalingoClient()
if err != nil {
return errgo.Notef(err, "fail to get Scalingo client")
}
domains, err := c.DomainsList(app)
if err != nil {
return errgo.Mask(err)
}
t := tablewriter.NewWriter(os.Stdout)
t.SetHeader([]string{"Domain", "TLS/SSL"})
hasCanonical := false
for _, domain := range domains {
domainName := domain.Name
if domain.Canonical {
hasCanonical = true
domainName += " (*)"
}
row := []string{domainName}
if !domain.SSL {
row = append(row, "-")
} else if domain.LetsEncrypt {
letsencryptStatus, ok := letsencryptStatusString[string(domain.LetsEncryptStatus)]
if !ok {
letsencryptStatus = string(domain.LetsEncryptStatus)
}
row = append(row, fmt.Sprintf("Let's Encrypt: %s", letsencryptStatus))
} else {
row = append(row, fmt.Sprintf("Valid until %v", domain.Validity))
}
t.Append(row)
}
t.Render()
if hasCanonical {
fmt.Println(" (*) canonical domain")
}
return nil
}