You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
117 lines
2.6 KiB
117 lines
2.6 KiB
package main
|
|
|
|
import (
|
|
b64 "encoding/base64"
|
|
"encoding/json"
|
|
"encoding/pem"
|
|
"fmt"
|
|
"io/ioutil"
|
|
"net"
|
|
"os"
|
|
|
|
"github.com/Baozisoftware/qrcode-terminal-go"
|
|
"github.com/glendc/go-external-ip"
|
|
"github.com/skip2/go-qrcode"
|
|
)
|
|
|
|
type certificates struct {
|
|
Cert string `json:"c"`
|
|
Macaroon string `json:"m"`
|
|
Ip string `json:"ip,omitempty"`
|
|
}
|
|
|
|
func getLocalIP() string {
|
|
addrs, err := net.InterfaceAddrs()
|
|
if err != nil {
|
|
return ""
|
|
}
|
|
for _, address := range addrs {
|
|
if ipnet, ok := address.(*net.IPNet); ok && !ipnet.IP.IsLoopback() {
|
|
if ipnet.IP.To4() != nil {
|
|
return ipnet.IP.String()
|
|
}
|
|
}
|
|
}
|
|
return ""
|
|
}
|
|
|
|
func getPublicIP() string {
|
|
consensus := externalip.DefaultConsensus(nil, nil)
|
|
ip, err := consensus.ExternalIP()
|
|
if err != nil {
|
|
fmt.Println(err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
return ip.String()
|
|
}
|
|
|
|
func main() {
|
|
loadedConfig, err := loadConfig()
|
|
if err != nil {
|
|
fmt.Println()
|
|
return
|
|
}
|
|
|
|
certBytes, err := ioutil.ReadFile(loadedConfig.TLSCertPath)
|
|
if err != nil {
|
|
fmt.Println(err)
|
|
return
|
|
}
|
|
|
|
block, _ := pem.Decode(certBytes)
|
|
if block == nil || block.Type != "CERTIFICATE" {
|
|
fmt.Println("failed to decode PEM block containing certificate")
|
|
}
|
|
|
|
certificate := b64.StdEncoding.EncodeToString([]byte(block.Bytes))
|
|
|
|
var macBytes []byte
|
|
if loadedConfig.ZapConnect.Invoice {
|
|
macBytes, err = ioutil.ReadFile(loadedConfig.InvoiceMacPath)
|
|
} else if loadedConfig.ZapConnect.Readonly {
|
|
macBytes, err = ioutil.ReadFile(loadedConfig.ReadMacPath)
|
|
} else {
|
|
macBytes, err = ioutil.ReadFile(loadedConfig.AdminMacPath)
|
|
}
|
|
|
|
if err != nil {
|
|
fmt.Println(err)
|
|
return
|
|
}
|
|
|
|
macaroonB64 := b64.StdEncoding.EncodeToString([]byte(macBytes))
|
|
|
|
ipString := ""
|
|
if loadedConfig.ZapConnect.Host != "" {
|
|
ipString = loadedConfig.ZapConnect.Host
|
|
} else if loadedConfig.ZapConnect.LocalIp {
|
|
ipString = getLocalIP()
|
|
} else if loadedConfig.ZapConnect.Localhost {
|
|
ipString = "127.0.0.1"
|
|
} else {
|
|
ipString = getPublicIP()
|
|
}
|
|
|
|
ipString = net.JoinHostPort(
|
|
ipString, fmt.Sprint(loadedConfig.ZapConnect.Port),
|
|
)
|
|
|
|
cert := &certificates{
|
|
Cert: certificate,
|
|
Macaroon: macaroonB64,
|
|
Ip: ipString,
|
|
}
|
|
certB, _ := json.Marshal(cert)
|
|
|
|
if loadedConfig.ZapConnect.Json {
|
|
fmt.Println(string(certB))
|
|
} else if loadedConfig.ZapConnect.Image {
|
|
qrcode.WriteFile(string(certB), qrcode.Medium, 512, "zapconnect-qr.png")
|
|
fmt.Println("Wrote QR Code to file \"zapconnect-qr.png\"")
|
|
} else {
|
|
obj := qrcodeTerminal.New()
|
|
obj.Get(string(certB)).Print()
|
|
fmt.Println("\n⚠️ Press \"cmd + -\" a few times to see the full QR Code!\nIf that doesn't work run \"zapconnect -j\" to get a code you can copy paste into the app.")
|
|
}
|
|
}
|
|
|