mv registry interface to core library
This commit is contained in:
parent
dbae70232c
commit
745196d805
@ -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 {
|
||||||
|
@ -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 {
|
||||||
|
@ -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 {
|
||||||
|
@ -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 {
|
||||||
|
@ -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 {
|
||||||
|
@ -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 {
|
||||||
|
@ -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 {
|
||||||
|
@ -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 {
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
Loading…
Reference in New Issue
Block a user