2016-06-14 20:54:08 +00:00
|
|
|
package internet
|
|
|
|
|
|
|
|
import (
|
2016-07-10 13:27:58 +00:00
|
|
|
"crypto/tls"
|
2016-06-14 20:54:08 +00:00
|
|
|
"net"
|
|
|
|
)
|
|
|
|
|
|
|
|
type ConnectionHandler func(Connection)
|
|
|
|
|
|
|
|
type Reusable interface {
|
|
|
|
Reusable() bool
|
|
|
|
SetReusable(reuse bool)
|
|
|
|
}
|
|
|
|
|
|
|
|
type StreamConnectionType int
|
|
|
|
|
2016-07-10 13:27:58 +00:00
|
|
|
const (
|
2016-06-14 20:54:08 +00:00
|
|
|
StreamConnectionTypeRawTCP StreamConnectionType = 1
|
|
|
|
StreamConnectionTypeTCP StreamConnectionType = 2
|
|
|
|
StreamConnectionTypeKCP StreamConnectionType = 4
|
|
|
|
)
|
|
|
|
|
2016-07-10 13:27:58 +00:00
|
|
|
type StreamSecurityType int
|
|
|
|
|
|
|
|
const (
|
|
|
|
StreamSecurityTypeNone StreamSecurityType = 0
|
|
|
|
StreamSecurityTypeTLS StreamSecurityType = 1
|
|
|
|
)
|
|
|
|
|
|
|
|
type TLSSettings struct {
|
2016-07-10 13:30:48 +00:00
|
|
|
AllowInsecure bool
|
|
|
|
Certs []tls.Certificate
|
2016-07-10 13:27:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (this *TLSSettings) GetTLSConfig() *tls.Config {
|
|
|
|
config := &tls.Config{
|
2016-07-10 13:30:48 +00:00
|
|
|
InsecureSkipVerify: this.AllowInsecure,
|
2016-07-10 13:27:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
config.Certificates = this.Certs
|
|
|
|
config.BuildNameToCertificate()
|
|
|
|
|
|
|
|
return config
|
|
|
|
}
|
|
|
|
|
2016-06-14 20:54:08 +00:00
|
|
|
type StreamSettings struct {
|
2016-07-10 13:27:58 +00:00
|
|
|
Type StreamConnectionType
|
|
|
|
Security StreamSecurityType
|
|
|
|
TLSSettings *TLSSettings
|
2016-06-14 20:54:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (this *StreamSettings) IsCapableOf(streamType StreamConnectionType) bool {
|
|
|
|
return (this.Type & streamType) == streamType
|
|
|
|
}
|
|
|
|
|
|
|
|
type Connection interface {
|
|
|
|
net.Conn
|
|
|
|
Reusable
|
|
|
|
}
|
2016-06-29 22:08:20 +00:00
|
|
|
|
|
|
|
type SysFd interface {
|
|
|
|
SysFd() (int, error)
|
|
|
|
}
|