Add support for setting a global default User-Agent
This commit is contained in:
parent
b8b6c74d86
commit
52a626d7b9
4 changed files with 40 additions and 2 deletions
|
@ -59,6 +59,7 @@ const (
|
||||||
defaultMetricsCollector = false
|
defaultMetricsCollector = false
|
||||||
defaultMetricsRefreshInterval = 60
|
defaultMetricsRefreshInterval = 60
|
||||||
defaultMetricsAllowedNetworks = "127.0.0.1/8"
|
defaultMetricsAllowedNetworks = "127.0.0.1/8"
|
||||||
|
defaultUserAgent = ""
|
||||||
)
|
)
|
||||||
|
|
||||||
// Options contains configuration options.
|
// Options contains configuration options.
|
||||||
|
@ -112,6 +113,7 @@ type Options struct {
|
||||||
metricsCollector bool
|
metricsCollector bool
|
||||||
metricsRefreshInterval int
|
metricsRefreshInterval int
|
||||||
metricsAllowedNetworks []string
|
metricsAllowedNetworks []string
|
||||||
|
userAgent string
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewOptions returns Options with default values.
|
// NewOptions returns Options with default values.
|
||||||
|
@ -164,6 +166,7 @@ func NewOptions() *Options {
|
||||||
metricsCollector: defaultMetricsCollector,
|
metricsCollector: defaultMetricsCollector,
|
||||||
metricsRefreshInterval: defaultMetricsRefreshInterval,
|
metricsRefreshInterval: defaultMetricsRefreshInterval,
|
||||||
metricsAllowedNetworks: []string{defaultMetricsAllowedNetworks},
|
metricsAllowedNetworks: []string{defaultMetricsAllowedNetworks},
|
||||||
|
userAgent: defaultUserAgent,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -422,6 +425,11 @@ func (o *Options) MetricsAllowedNetworks() []string {
|
||||||
return o.metricsAllowedNetworks
|
return o.metricsAllowedNetworks
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// UserAgent returns the global User-Agent header for miniflux.
|
||||||
|
func (o *Options) UserAgent() string {
|
||||||
|
return o.userAgent
|
||||||
|
}
|
||||||
|
|
||||||
func (o *Options) String() string {
|
func (o *Options) String() string {
|
||||||
var builder strings.Builder
|
var builder strings.Builder
|
||||||
builder.WriteString(fmt.Sprintf("LOG_DATE_TIME: %v\n", o.logDateTime))
|
builder.WriteString(fmt.Sprintf("LOG_DATE_TIME: %v\n", o.logDateTime))
|
||||||
|
@ -473,5 +481,6 @@ func (o *Options) String() string {
|
||||||
builder.WriteString(fmt.Sprintf("METRICS_COLLECTOR: %v\n", o.metricsCollector))
|
builder.WriteString(fmt.Sprintf("METRICS_COLLECTOR: %v\n", o.metricsCollector))
|
||||||
builder.WriteString(fmt.Sprintf("METRICS_REFRESH_INTERVAL: %v\n", o.metricsRefreshInterval))
|
builder.WriteString(fmt.Sprintf("METRICS_REFRESH_INTERVAL: %v\n", o.metricsRefreshInterval))
|
||||||
builder.WriteString(fmt.Sprintf("METRICS_ALLOWED_NETWORKS: %v\n", o.metricsAllowedNetworks))
|
builder.WriteString(fmt.Sprintf("METRICS_ALLOWED_NETWORKS: %v\n", o.metricsAllowedNetworks))
|
||||||
|
builder.WriteString(fmt.Sprintf("USER_AGENT: %v\n", o.userAgent))
|
||||||
return builder.String()
|
return builder.String()
|
||||||
}
|
}
|
||||||
|
|
|
@ -184,6 +184,8 @@ func (p *Parser) parseLines(lines []string) (err error) {
|
||||||
p.opts.metricsRefreshInterval = parseInt(value, defaultMetricsRefreshInterval)
|
p.opts.metricsRefreshInterval = parseInt(value, defaultMetricsRefreshInterval)
|
||||||
case "METRICS_ALLOWED_NETWORKS":
|
case "METRICS_ALLOWED_NETWORKS":
|
||||||
p.opts.metricsAllowedNetworks = parseStringList(value, []string{defaultMetricsAllowedNetworks})
|
p.opts.metricsAllowedNetworks = parseStringList(value, []string{defaultMetricsAllowedNetworks})
|
||||||
|
case "USER_AGENT":
|
||||||
|
p.opts.userAgent = parseString(value, defaultUserAgent)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -72,9 +72,13 @@ func New(url string) *Client {
|
||||||
|
|
||||||
// NewClientWithConfig initializes a new HTTP client with application config options.
|
// NewClientWithConfig initializes a new HTTP client with application config options.
|
||||||
func NewClientWithConfig(url string, opts *config.Options) *Client {
|
func NewClientWithConfig(url string, opts *config.Options) *Client {
|
||||||
|
userAgent := opts.UserAgent()
|
||||||
|
if userAgent == "" {
|
||||||
|
userAgent = DefaultUserAgent
|
||||||
|
}
|
||||||
return &Client{
|
return &Client{
|
||||||
inputURL: url,
|
inputURL: url,
|
||||||
requestUserAgent: DefaultUserAgent,
|
requestUserAgent: userAgent,
|
||||||
ClientTimeout: opts.HTTPClientTimeout(),
|
ClientTimeout: opts.HTTPClientTimeout(),
|
||||||
ClientMaxBodySize: opts.HTTPClientMaxBodySize(),
|
ClientMaxBodySize: opts.HTTPClientMaxBodySize(),
|
||||||
ClientProxyURL: opts.HTTPClientProxy(),
|
ClientProxyURL: opts.HTTPClientProxy(),
|
||||||
|
|
|
@ -4,7 +4,12 @@
|
||||||
|
|
||||||
package client // import "miniflux.app/http/client"
|
package client // import "miniflux.app/http/client"
|
||||||
|
|
||||||
import "testing"
|
import (
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"miniflux.app/config"
|
||||||
|
)
|
||||||
|
|
||||||
func TestClientWithDelay(t *testing.T) {
|
func TestClientWithDelay(t *testing.T) {
|
||||||
clt := New("http://httpbin.org/delay/5")
|
clt := New("http://httpbin.org/delay/5")
|
||||||
|
@ -49,3 +54,21 @@ func TestClientWithBasicAuth(t *testing.T) {
|
||||||
t.Fatalf(`The client should be authenticated successfully: %v`, err)
|
t.Fatalf(`The client should be authenticated successfully: %v`, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestClientRequestUserAgent(t *testing.T) {
|
||||||
|
clt := New("http://httpbin.org")
|
||||||
|
if clt.requestUserAgent != DefaultUserAgent {
|
||||||
|
t.Errorf(`The client had default User-Agent %q, wanted %q`, clt.requestUserAgent, DefaultUserAgent)
|
||||||
|
}
|
||||||
|
|
||||||
|
userAgent := "Custom User Agent"
|
||||||
|
os.Setenv("USER_AGENT", userAgent)
|
||||||
|
opts, err := config.NewParser().ParseEnvironmentVariables()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf(`Parsing config failed: %v`, err)
|
||||||
|
}
|
||||||
|
clt = NewClientWithConfig("http://httpbin.org", opts)
|
||||||
|
if clt.requestUserAgent != userAgent {
|
||||||
|
t.Errorf(`The client had User-Agent %q, wanted %q`, clt.requestUserAgent, userAgent)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue