2022-04-25 05:03:05 +00:00
|
|
|
package proxy
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/url"
|
2022-06-07 07:35:54 +08:00
|
|
|
"os"
|
2022-04-25 05:03:05 +00:00
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
type config struct {
|
|
|
|
proxyPort int
|
|
|
|
proxyHost string
|
|
|
|
destinationUrl *url.URL
|
|
|
|
logger *logrus.Logger
|
2022-06-07 07:35:54 +08:00
|
|
|
secret string
|
2022-04-25 05:03:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
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
|
|
|
|
}
|
|
|
|
}
|
2022-06-07 07:35:54 +08:00
|
|
|
|
|
|
|
// 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
|
|
|
|
}
|
|
|
|
}
|