summaryrefslogtreecommitdiff
path: root/tls-getcerts.go
blob: ba951c97121c76ef14b56460751282b18c27016b (plain)
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
package main

import (
	"crypto/tls"
	"crypto/x509"
	"encoding/pem"
	"fmt"
	"os"
)

func getcert(socket string) (*x509.Certificate, error){
	conn, err := tls.Dial("tcp", socket, &tls.Config{InsecureSkipVerify: true})
	if err != nil {
		return nil, err
	}
	defer conn.Close()
	return conn.ConnectionState().PeerCertificates[0], nil
}

func main() {
	for _, socket := range os.Args[1:] {
		cert, err := getcert(socket)
		if cert == nil {
			fmt.Fprintf(os.Stderr, "Could not get certificate for socket %q: %q\n", socket, err)
			os.Exit(1)
		}
		block := pem.Block{
			Type: "CERTIFICATE",
			Headers: map[string]string{"X-Socket": socket},
			Bytes: cert.Raw,
		}
		pem.Encode(os.Stdout, &block)
	}
}