mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2024-12-24 12:27:18 +00:00
6c39301f33
* add it in * support jwt secret * fix it * fix Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
80 lines
1.6 KiB
Go
80 lines
1.6 KiB
Go
package proxy
|
|
|
|
import (
|
|
"net/url"
|
|
"os"
|
|
|
|
"github.com/pkg/errors"
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
type config struct {
|
|
proxyPort int
|
|
proxyHost string
|
|
destinationUrl *url.URL
|
|
logger *logrus.Logger
|
|
secret string
|
|
}
|
|
|
|
type Option func(p *Proxy) error
|
|
|
|
// WithHost sets the proxy server host.
|
|
func WithHost(host string) Option {
|
|
return func(p *Proxy) error {
|
|
p.cfg.proxyHost = host
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithPort sets the proxy server port.
|
|
func WithPort(port int) Option {
|
|
return func(p *Proxy) error {
|
|
p.cfg.proxyPort = port
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithDestinationAddress sets the forwarding address requests will be proxied to.
|
|
func WithDestinationAddress(addr string) Option {
|
|
return func(p *Proxy) error {
|
|
if addr == "" {
|
|
return errors.New("must provide a destination address for proxy")
|
|
}
|
|
u, err := url.Parse(addr)
|
|
if err != nil {
|
|
return errors.Wrapf(err, "could not parse URL for destination address: %s", addr)
|
|
}
|
|
p.cfg.destinationUrl = u
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithLogger sets a custom logger for the proxy.
|
|
func WithLogger(l *logrus.Logger) Option {
|
|
return func(p *Proxy) error {
|
|
p.cfg.logger = l
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithLogFile specifies a log file to write
|
|
// the proxies output to.
|
|
func WithLogFile(f *os.File) Option {
|
|
return func(p *Proxy) error {
|
|
if p.cfg.logger == nil {
|
|
return errors.New("nil logger provided")
|
|
}
|
|
p.cfg.logger.SetOutput(f)
|
|
return nil
|
|
}
|
|
}
|
|
|
|
// WithJwtSecret adds in support for jwt authenticated
|
|
// connections for our proxy.
|
|
func WithJwtSecret(secret string) Option {
|
|
return func(p *Proxy) error {
|
|
p.cfg.secret = secret
|
|
return nil
|
|
}
|
|
}
|