|
@@ -10,50 +10,51 @@ import (
|
|
|
E "github.com/sagernet/sing/common/exceptions"
|
|
|
)
|
|
|
|
|
|
-func New(ctx context.Context, router adapter.Router, logger log.ContextLogger, options option.Outbound) (adapter.Outbound, error) {
|
|
|
+func New(ctx context.Context, router adapter.Router, logger log.ContextLogger, tag string, options option.Outbound) (adapter.Outbound, error) {
|
|
|
var metadata *adapter.InboundContext
|
|
|
- if options.Tag != "" {
|
|
|
+ if tag != "" {
|
|
|
ctx, metadata = adapter.AppendContext(ctx)
|
|
|
- metadata.Outbound = options.Tag
|
|
|
+ metadata.Outbound = tag
|
|
|
}
|
|
|
if options.Type == "" {
|
|
|
return nil, E.New("missing outbound type")
|
|
|
}
|
|
|
+ ctx = ContextWithTag(ctx, tag)
|
|
|
switch options.Type {
|
|
|
case C.TypeDirect:
|
|
|
- return NewDirect(router, logger, options.Tag, options.DirectOptions)
|
|
|
+ return NewDirect(router, logger, tag, options.DirectOptions)
|
|
|
case C.TypeBlock:
|
|
|
- return NewBlock(logger, options.Tag), nil
|
|
|
+ return NewBlock(logger, tag), nil
|
|
|
case C.TypeDNS:
|
|
|
- return NewDNS(router, options.Tag), nil
|
|
|
+ return NewDNS(router, tag), nil
|
|
|
case C.TypeSocks:
|
|
|
- return NewSocks(router, logger, options.Tag, options.SocksOptions)
|
|
|
+ return NewSocks(router, logger, tag, options.SocksOptions)
|
|
|
case C.TypeHTTP:
|
|
|
- return NewHTTP(router, logger, options.Tag, options.HTTPOptions)
|
|
|
+ return NewHTTP(router, logger, tag, options.HTTPOptions)
|
|
|
case C.TypeShadowsocks:
|
|
|
- return NewShadowsocks(ctx, router, logger, options.Tag, options.ShadowsocksOptions)
|
|
|
+ return NewShadowsocks(ctx, router, logger, tag, options.ShadowsocksOptions)
|
|
|
case C.TypeVMess:
|
|
|
- return NewVMess(ctx, router, logger, options.Tag, options.VMessOptions)
|
|
|
+ return NewVMess(ctx, router, logger, tag, options.VMessOptions)
|
|
|
case C.TypeTrojan:
|
|
|
- return NewTrojan(ctx, router, logger, options.Tag, options.TrojanOptions)
|
|
|
+ return NewTrojan(ctx, router, logger, tag, options.TrojanOptions)
|
|
|
case C.TypeWireGuard:
|
|
|
- return NewWireGuard(ctx, router, logger, options.Tag, options.WireGuardOptions)
|
|
|
+ return NewWireGuard(ctx, router, logger, tag, options.WireGuardOptions)
|
|
|
case C.TypeHysteria:
|
|
|
- return NewHysteria(ctx, router, logger, options.Tag, options.HysteriaOptions)
|
|
|
+ return NewHysteria(ctx, router, logger, tag, options.HysteriaOptions)
|
|
|
case C.TypeTor:
|
|
|
- return NewTor(ctx, router, logger, options.Tag, options.TorOptions)
|
|
|
+ return NewTor(ctx, router, logger, tag, options.TorOptions)
|
|
|
case C.TypeSSH:
|
|
|
- return NewSSH(ctx, router, logger, options.Tag, options.SSHOptions)
|
|
|
+ return NewSSH(ctx, router, logger, tag, options.SSHOptions)
|
|
|
case C.TypeShadowTLS:
|
|
|
- return NewShadowTLS(ctx, router, logger, options.Tag, options.ShadowTLSOptions)
|
|
|
+ return NewShadowTLS(ctx, router, logger, tag, options.ShadowTLSOptions)
|
|
|
case C.TypeShadowsocksR:
|
|
|
- return NewShadowsocksR(ctx, router, logger, options.Tag, options.ShadowsocksROptions)
|
|
|
+ return NewShadowsocksR(ctx, router, logger, tag, options.ShadowsocksROptions)
|
|
|
case C.TypeVLESS:
|
|
|
- return NewVLESS(ctx, router, logger, options.Tag, options.VLESSOptions)
|
|
|
+ return NewVLESS(ctx, router, logger, tag, options.VLESSOptions)
|
|
|
case C.TypeSelector:
|
|
|
- return NewSelector(router, logger, options.Tag, options.SelectorOptions)
|
|
|
+ return NewSelector(router, logger, tag, options.SelectorOptions)
|
|
|
case C.TypeURLTest:
|
|
|
- return NewURLTest(router, logger, options.Tag, options.URLTestOptions)
|
|
|
+ return NewURLTest(router, logger, tag, options.URLTestOptions)
|
|
|
default:
|
|
|
return nil, E.New("unknown outbound type: ", options.Type)
|
|
|
}
|