aboutsummaryrefslogtreecommitdiffhomepage
path: root/modules/caddytls/matchers.go
blob: 712472f81306dcd8b574403b16ea24229335ae63 (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
package caddytls

import (
	"crypto/tls"

	"github.com/caddyserver/caddy2"
)

// MatchServerName matches based on SNI.
type MatchServerName []string

func init() {
	caddy2.RegisterModule(caddy2.Module{
		Name: "tls.handshake_match.sni",
		New:  func() interface{} { return MatchServerName{} },
	})
}

// Match matches hello based on SNI.
func (m MatchServerName) Match(hello *tls.ClientHelloInfo) bool {
	for _, name := range m {
		// TODO: support wildcards (and regex?)
		if hello.ServerName == name {
			return true
		}
	}
	return false
}

// Interface guard
var _ ConnectionMatcher = MatchServerName{}