woodpecker/vendor/github.com/jackspirou/syscerts
6543 75513575be
Use go's vendoring (#284)
* store dependency's in git

* since we vendor ... rm tech-depts

* aad make target 'vendor' to update vendor folder (manual task)
2021-08-30 19:14:04 +02:00
..
.gitignore Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
LICENSE Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
README.md Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root_bsd.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root_cgo_darwin.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root_darwin.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root_darwin_armx.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root_linux.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root_nacl.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root_plan9.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root_solaris.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root_unix.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00
root_windows.go Use go's vendoring (#284) 2021-08-30 19:14:04 +02:00

syscerts

Gather local system certificates in Go via a public SystemRootsPool method.

What does this do?

Provide a way to gather local system certificates on different OS platforms.

How does it do it?

It uses the crypto/x509 package and provides a single public method called SystemRootsPool() to return a *x509.CertPool object.

How do you use it?

// gather CA certs
certpool := syscerts.SystemRootsPool()

// place them in an HTTP client for trusted SSL/TLS connections
tlsConfig := &tls.Config{RootCAs: certpool}
transport := &http.Transport{TLSClientConfig: tlsConfig}
client := &http.Client{Transport: transport}

// make a request
resp, err := client.Do(req)

Why even do it?

The crypto/x509 package already has a systemRootsPool method. The crypto/x509.systemRootsPool method is almost the same as github.com/jackspirou/syscerts.SystemRootsPool. The difference? The crypto/x509.systemRootsPool method is private so you cannot access it. :(

There are plans for the crypto/x509.systemRootsPool method to become public in Go 1.7. When this happens you might no longer need github.com/jackspirou/syscerts.SystemRootsPool.

The only reason you may still use this package after the Go 1.7 release might be for the Mac OSX System Keychain certs which are not included in the crypto/x509 package. Relevant lines below:

Find more about this Go issue here: https://github.com/golang/go/issues/13335