mv registry interface to core library

This commit is contained in:
ginuerzh 2022-11-29 09:43:15 +08:00
parent dbae70232c
commit 745196d805
10 changed files with 44 additions and 85 deletions

View File

@ -20,10 +20,7 @@ func (r *admissionRegistry) Get(name string) admission.Admission {
} }
func (r *admissionRegistry) get(name string) admission.Admission { func (r *admissionRegistry) get(name string) admission.Admission {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(admission.Admission)
}
return nil
} }
type admissionWrapper struct { type admissionWrapper struct {

View File

@ -20,10 +20,7 @@ func (r *autherRegistry) Get(name string) auth.Authenticator {
} }
func (r *autherRegistry) get(name string) auth.Authenticator { func (r *autherRegistry) get(name string) auth.Authenticator {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(auth.Authenticator)
}
return nil
} }
type autherWrapper struct { type autherWrapper struct {

View File

@ -20,10 +20,7 @@ func (r *bypassRegistry) Get(name string) bypass.Bypass {
} }
func (r *bypassRegistry) get(name string) bypass.Bypass { func (r *bypassRegistry) get(name string) bypass.Bypass {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(bypass.Bypass)
}
return nil
} }
type bypassWrapper struct { type bypassWrapper struct {

View File

@ -24,10 +24,7 @@ func (r *chainRegistry) Get(name string) chain.Chainer {
} }
func (r *chainRegistry) get(name string) chain.Chainer { func (r *chainRegistry) get(name string) chain.Chainer {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(chain.Chainer)
}
return nil
} }
type chainWrapper struct { type chainWrapper struct {

View File

@ -22,10 +22,7 @@ func (r *hopRegistry) Get(name string) chain.Hop {
} }
func (r *hopRegistry) get(name string) chain.Hop { func (r *hopRegistry) get(name string) chain.Hop {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(chain.Hop)
}
return nil
} }
type hopWrapper struct { type hopWrapper struct {

View File

@ -22,10 +22,7 @@ func (r *hostsRegistry) Get(name string) hosts.HostMapper {
} }
func (r *hostsRegistry) get(name string) hosts.HostMapper { func (r *hostsRegistry) get(name string) hosts.HostMapper {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(hosts.HostMapper)
}
return nil
} }
type hostsWrapper struct { type hostsWrapper struct {

View File

@ -22,10 +22,7 @@ func (r *trafficLimiterRegistry) Get(name string) traffic.TrafficLimiter {
} }
func (r *trafficLimiterRegistry) get(name string) traffic.TrafficLimiter { func (r *trafficLimiterRegistry) get(name string) traffic.TrafficLimiter {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(traffic.TrafficLimiter)
}
return nil
} }
type trafficLimiterWrapper struct { type trafficLimiterWrapper struct {
@ -65,10 +62,7 @@ func (r *connLimiterRegistry) Get(name string) conn.ConnLimiter {
} }
func (r *connLimiterRegistry) get(name string) conn.ConnLimiter { func (r *connLimiterRegistry) get(name string) conn.ConnLimiter {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(conn.ConnLimiter)
}
return nil
} }
type connLimiterWrapper struct { type connLimiterWrapper struct {
@ -100,10 +94,7 @@ func (r *rateLimiterRegistry) Get(name string) rate.RateLimiter {
} }
func (r *rateLimiterRegistry) get(name string) rate.RateLimiter { func (r *rateLimiterRegistry) get(name string) rate.RateLimiter {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(rate.RateLimiter)
}
return nil
} }
type rateLimiterWrapper struct { type rateLimiterWrapper struct {

View File

@ -22,10 +22,7 @@ func (r *recorderRegistry) Get(name string) recorder.Recorder {
} }
func (r *recorderRegistry) get(name string) recorder.Recorder { func (r *recorderRegistry) get(name string) recorder.Recorder {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(recorder.Recorder)
}
return nil
} }
type recorderWrapper struct { type recorderWrapper struct {

View File

@ -14,6 +14,7 @@ import (
"github.com/go-gost/core/limiter/rate" "github.com/go-gost/core/limiter/rate"
"github.com/go-gost/core/limiter/traffic" "github.com/go-gost/core/limiter/traffic"
"github.com/go-gost/core/recorder" "github.com/go-gost/core/recorder"
reg "github.com/go-gost/core/registry"
"github.com/go-gost/core/resolver" "github.com/go-gost/core/resolver"
"github.com/go-gost/core/service" "github.com/go-gost/core/service"
) )
@ -23,34 +24,25 @@ var (
) )
var ( var (
listenerReg Registry[NewListener] = new(listenerRegistry) listenerReg reg.Registry[NewListener] = new(listenerRegistry)
handlerReg Registry[NewHandler] = new(handlerRegistry) handlerReg reg.Registry[NewHandler] = new(handlerRegistry)
dialerReg Registry[NewDialer] = new(dialerRegistry) dialerReg reg.Registry[NewDialer] = new(dialerRegistry)
connectorReg Registry[NewConnector] = new(connectorRegistry) connectorReg reg.Registry[NewConnector] = new(connectorRegistry)
serviceReg reg.Registry[service.Service] = new(serviceRegistry)
chainReg reg.Registry[chain.Chainer] = new(chainRegistry)
hopReg reg.Registry[chain.Hop] = new(hopRegistry)
autherReg reg.Registry[auth.Authenticator] = new(autherRegistry)
admissionReg reg.Registry[admission.Admission] = new(admissionRegistry)
bypassReg reg.Registry[bypass.Bypass] = new(bypassRegistry)
resolverReg reg.Registry[resolver.Resolver] = new(resolverRegistry)
hostsReg reg.Registry[hosts.HostMapper] = new(hostsRegistry)
recorderReg reg.Registry[recorder.Recorder] = new(recorderRegistry)
serviceReg Registry[service.Service] = new(serviceRegistry) trafficLimiterReg reg.Registry[traffic.TrafficLimiter] = new(trafficLimiterRegistry)
chainReg Registry[chain.Chainer] = new(chainRegistry) connLimiterReg reg.Registry[conn.ConnLimiter] = new(connLimiterRegistry)
hopReg Registry[chain.Hop] = new(hopRegistry) rateLimiterReg reg.Registry[rate.RateLimiter] = new(rateLimiterRegistry)
autherReg Registry[auth.Authenticator] = new(autherRegistry)
admissionReg Registry[admission.Admission] = new(admissionRegistry)
bypassReg Registry[bypass.Bypass] = new(bypassRegistry)
resolverReg Registry[resolver.Resolver] = new(resolverRegistry)
hostsReg Registry[hosts.HostMapper] = new(hostsRegistry)
recorderReg Registry[recorder.Recorder] = new(recorderRegistry)
trafficLimiterReg Registry[traffic.TrafficLimiter] = new(trafficLimiterRegistry)
connLimiterReg Registry[conn.ConnLimiter] = new(connLimiterRegistry)
rateLimiterReg Registry[rate.RateLimiter] = new(rateLimiterRegistry)
) )
type Registry[T any] interface {
Register(name string, v T) error
Unregister(name string)
IsRegistered(name string) bool
Get(name string) T
GetAll() map[string]T
}
type registry[T any] struct { type registry[T any] struct {
m sync.Map m sync.Map
} }
@ -100,66 +92,66 @@ func (r *registry[T]) GetAll() (m map[string]T) {
return return
} }
func ListenerRegistry() Registry[NewListener] { func ListenerRegistry() reg.Registry[NewListener] {
return listenerReg return listenerReg
} }
func HandlerRegistry() Registry[NewHandler] { func HandlerRegistry() reg.Registry[NewHandler] {
return handlerReg return handlerReg
} }
func DialerRegistry() Registry[NewDialer] { func DialerRegistry() reg.Registry[NewDialer] {
return dialerReg return dialerReg
} }
func ConnectorRegistry() Registry[NewConnector] { func ConnectorRegistry() reg.Registry[NewConnector] {
return connectorReg return connectorReg
} }
func ServiceRegistry() Registry[service.Service] { func ServiceRegistry() reg.Registry[service.Service] {
return serviceReg return serviceReg
} }
func ChainRegistry() Registry[chain.Chainer] { func ChainRegistry() reg.Registry[chain.Chainer] {
return chainReg return chainReg
} }
func HopRegistry() Registry[chain.Hop] { func HopRegistry() reg.Registry[chain.Hop] {
return hopReg return hopReg
} }
func AutherRegistry() Registry[auth.Authenticator] { func AutherRegistry() reg.Registry[auth.Authenticator] {
return autherReg return autherReg
} }
func AdmissionRegistry() Registry[admission.Admission] { func AdmissionRegistry() reg.Registry[admission.Admission] {
return admissionReg return admissionReg
} }
func BypassRegistry() Registry[bypass.Bypass] { func BypassRegistry() reg.Registry[bypass.Bypass] {
return bypassReg return bypassReg
} }
func ResolverRegistry() Registry[resolver.Resolver] { func ResolverRegistry() reg.Registry[resolver.Resolver] {
return resolverReg return resolverReg
} }
func HostsRegistry() Registry[hosts.HostMapper] { func HostsRegistry() reg.Registry[hosts.HostMapper] {
return hostsReg return hostsReg
} }
func RecorderRegistry() Registry[recorder.Recorder] { func RecorderRegistry() reg.Registry[recorder.Recorder] {
return recorderReg return recorderReg
} }
func TrafficLimiterRegistry() Registry[traffic.TrafficLimiter] { func TrafficLimiterRegistry() reg.Registry[traffic.TrafficLimiter] {
return trafficLimiterReg return trafficLimiterReg
} }
func ConnLimiterRegistry() Registry[conn.ConnLimiter] { func ConnLimiterRegistry() reg.Registry[conn.ConnLimiter] {
return connLimiterReg return connLimiterReg
} }
func RateLimiterRegistry() Registry[rate.RateLimiter] { func RateLimiterRegistry() reg.Registry[rate.RateLimiter] {
return rateLimiterReg return rateLimiterReg
} }

View File

@ -23,10 +23,7 @@ func (r *resolverRegistry) Get(name string) resolver.Resolver {
} }
func (r *resolverRegistry) get(name string) resolver.Resolver { func (r *resolverRegistry) get(name string) resolver.Resolver {
if v := r.registry.Get(name); v != nil { return r.registry.Get(name)
return v.(resolver.Resolver)
}
return nil
} }
type resolverWrapper struct { type resolverWrapper struct {