mirror of
https://github.com/SagerNet/sing-box.git
synced 2024-12-01 10:56:38 +00:00
d1c3dd0ee1
* Add hysteria client/server * Add acme TLS certificate issuer
46 lines
1.7 KiB
Go
46 lines
1.7 KiB
Go
package inbound
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/sagernet/sing-box/adapter"
|
|
C "github.com/sagernet/sing-box/constant"
|
|
"github.com/sagernet/sing-box/log"
|
|
"github.com/sagernet/sing-box/option"
|
|
E "github.com/sagernet/sing/common/exceptions"
|
|
)
|
|
|
|
func New(ctx context.Context, router adapter.Router, logger log.ContextLogger, options option.Inbound) (adapter.Inbound, error) {
|
|
if options.Type == "" {
|
|
return nil, E.New("missing inbound type")
|
|
}
|
|
switch options.Type {
|
|
case C.TypeTun:
|
|
return NewTun(ctx, router, logger, options.Tag, options.TunOptions)
|
|
case C.TypeRedirect:
|
|
return NewRedirect(ctx, router, logger, options.Tag, options.RedirectOptions), nil
|
|
case C.TypeTProxy:
|
|
return NewTProxy(ctx, router, logger, options.Tag, options.TProxyOptions), nil
|
|
case C.TypeDirect:
|
|
return NewDirect(ctx, router, logger, options.Tag, options.DirectOptions), nil
|
|
case C.TypeSocks:
|
|
return NewSocks(ctx, router, logger, options.Tag, options.SocksOptions), nil
|
|
case C.TypeHTTP:
|
|
return NewHTTP(ctx, router, logger, options.Tag, options.HTTPOptions)
|
|
case C.TypeMixed:
|
|
return NewMixed(ctx, router, logger, options.Tag, options.MixedOptions), nil
|
|
case C.TypeShadowsocks:
|
|
return NewShadowsocks(ctx, router, logger, options.Tag, options.ShadowsocksOptions)
|
|
case C.TypeVMess:
|
|
return NewVMess(ctx, router, logger, options.Tag, options.VMessOptions)
|
|
case C.TypeTrojan:
|
|
return NewTrojan(ctx, router, logger, options.Tag, options.TrojanOptions)
|
|
case C.TypeNaive:
|
|
return NewNaive(ctx, router, logger, options.Tag, options.NaiveOptions)
|
|
case C.TypeHysteria:
|
|
return NewHysteria(ctx, router, logger, options.Tag, options.HysteriaOptions)
|
|
default:
|
|
return nil, E.New("unknown inbound type: ", options.Type)
|
|
}
|
|
}
|