mihomo/listener/http/server.go

95 lines
2.1 KiB
Go
Raw Normal View History

2018-06-14 01:00:58 +08:00
package http
2018-06-10 22:50:03 +08:00
import (
"net"
2023-11-03 21:01:45 +08:00
"github.com/metacubex/mihomo/adapter/inbound"
2024-08-14 13:01:06 +08:00
N "github.com/metacubex/mihomo/common/net"
"github.com/metacubex/mihomo/component/auth"
2023-11-03 21:01:45 +08:00
C "github.com/metacubex/mihomo/constant"
authStore "github.com/metacubex/mihomo/listener/auth"
2018-06-10 22:50:03 +08:00
)
2021-06-13 17:23:10 +08:00
type Listener struct {
listener net.Listener
addr string
closed bool
}
2021-08-01 00:35:37 +08:00
// RawAddress implements C.Listener
func (l *Listener) RawAddress() string {
return l.addr
}
// Address implements C.Listener
func (l *Listener) Address() string {
return l.listener.Addr().String()
}
// Close implements C.Listener
func (l *Listener) Close() error {
l.closed = true
return l.listener.Close()
}
func New(addr string, tunnel C.Tunnel, additions ...inbound.Addition) (*Listener, error) {
return NewWithAuthenticator(addr, tunnel, authStore.Authenticator, additions...)
2021-06-15 17:13:40 +08:00
}
2024-07-26 10:55:03 +08:00
// NewWithAuthenticate
2024-09-09 09:08:24 +08:00
// never change type traits because it's used in CMFA
2024-07-26 10:55:03 +08:00
func NewWithAuthenticate(addr string, tunnel C.Tunnel, authenticate bool, additions ...inbound.Addition) (*Listener, error) {
getAuth := authStore.Authenticator
2024-07-26 10:55:03 +08:00
if !authenticate {
getAuth = authStore.Nil
2024-07-26 10:55:03 +08:00
}
return NewWithAuthenticator(addr, tunnel, getAuth, additions...)
2024-07-26 10:55:03 +08:00
}
func NewWithAuthenticator(addr string, tunnel C.Tunnel, getAuth func() auth.Authenticator, additions ...inbound.Addition) (*Listener, error) {
isDefault := false
if len(additions) == 0 {
isDefault = true
additions = []inbound.Addition{
inbound.WithInName("DEFAULT-HTTP"),
inbound.WithSpecialRules(""),
}
}
2022-11-16 10:43:16 +08:00
l, err := inbound.Listen("tcp", addr)
2022-07-22 15:16:09 +08:00
2018-07-15 22:23:20 +08:00
if err != nil {
return nil, err
2018-07-15 22:23:20 +08:00
}
2021-06-15 17:13:40 +08:00
hl := &Listener{
listener: l,
addr: addr,
2021-06-15 17:13:40 +08:00
}
2018-07-15 22:23:20 +08:00
go func() {
2018-08-11 22:51:30 +08:00
for {
2021-06-15 17:13:40 +08:00
conn, err := hl.listener.Accept()
2018-08-11 22:51:30 +08:00
if err != nil {
if hl.closed {
2018-08-11 22:51:30 +08:00
break
}
continue
}
2024-08-14 13:01:06 +08:00
N.TCPKeepAlive(conn)
getAuth := getAuth
if isDefault { // only apply on default listener
if !inbound.IsRemoteAddrDisAllowed(conn.RemoteAddr()) {
_ = conn.Close()
continue
}
if inbound.SkipAuthRemoteAddr(conn.RemoteAddr()) {
getAuth = authStore.Nil
}
}
go HandleConn(conn, tunnel, getAuth, additions...)
2018-08-11 22:51:30 +08:00
}
2018-07-15 22:23:20 +08:00
}()
return hl, nil
}