-
-
Notifications
You must be signed in to change notification settings - Fork 208
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
refactor: add
service
package to prepare for split HTTP handling
Package service exposes types to abstract services from the networking. The idea is that we build a set of services and a set of network endpoints (Listener). The services are then assigned to endpoints based on the address(es) they were configured for. Actual service to endpoint binding is not handled by the abstractions in this package as it is protocol specific. The general pattern is to make a "server" that wraps a service, and can then be started on an endpoint using a `Serve` method, similar to `http.Server`. To support exposing multiple compatible services on a single endpoint (example: DoH + metrics on a single port), services can implement `Merger`.
- Loading branch information
1 parent
9da89c3
commit ea921a6
Showing
17 changed files
with
1,075 additions
and
71 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
package helpertest | ||
|
||
import ( | ||
"crypto/tls" | ||
"crypto/x509" | ||
"sync" | ||
|
||
"github.com/0xERR0R/blocky/util" | ||
. "github.com/onsi/gomega" | ||
) | ||
|
||
const tlsTestServerName = "test.blocky.invalid" | ||
|
||
type tlsData struct { | ||
ServerCfg *tls.Config | ||
ClientCfg *tls.Config | ||
} | ||
|
||
// Lazy init | ||
// | ||
//nolint:gochecknoglobals | ||
var ( | ||
initTLSData sync.Once | ||
tlsDataStorage tlsData | ||
) | ||
|
||
func getTLSData() tlsData { | ||
initTLSData.Do(func() { | ||
cert, err := util.TLSGenerateSelfSignedCert([]string{tlsTestServerName}) | ||
Expect(err).Should(Succeed()) | ||
|
||
tlsDataStorage.ServerCfg = &tls.Config{ | ||
Certificates: []tls.Certificate{cert}, | ||
MinVersion: tls.VersionTLS13, | ||
} | ||
|
||
certPool := x509.NewCertPool() | ||
certPool.AddCert(cert.Leaf) | ||
|
||
tlsDataStorage.ClientCfg = &tls.Config{ | ||
RootCAs: certPool, | ||
ServerName: tlsTestServerName, | ||
MinVersion: tls.VersionTLS13, | ||
} | ||
}) | ||
|
||
return tlsDataStorage | ||
} | ||
|
||
// TLSTestServerConfig returns a TLS Config for use by test servers. | ||
func TLSTestServerConfig() *tls.Config { | ||
return getTLSData().ServerCfg.Clone() | ||
} | ||
|
||
// TLSTestServerConfig returns a TLS Config for use by test clients. | ||
// | ||
// This is required to connect to a test TLS server, otherwise TLS verification fails. | ||
func TLSTestClientConfig() *tls.Config { | ||
return getTLSData().ClientCfg.Clone() | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.