Redact sensitive values from config in health data (#12421)

The health api returns the server configuration details. Redact
sensitive values from the config values like URLs and credentials.
This commit is contained in:
Shireesh Anjal 2021-06-03 20:45:44 +05:30 committed by GitHub
parent 7a3b5235bf
commit fb140c146b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 73 additions and 1 deletions

View File

@ -1565,7 +1565,7 @@ func (a adminAPIHandlers) HealthInfoHandler(w http.ResponseWriter, r *http.Reque
} }
} else { } else {
healthInfo.Minio.Config = madmin.MinioConfig{ healthInfo.Minio.Config = madmin.MinioConfig{
Config: config, Config: config.RedactSensitiveInfo(),
} }
} }
partialWrite(healthInfo) partialWrite(healthInfo)

View File

@ -340,6 +340,30 @@ func (c Config) ReadConfig(r io.Reader) (dynOnly bool, err error) {
return dynOnly, nil return dynOnly, nil
} }
// RedactSensitiveInfo - removes sensitive information
// like urls and credentials from the configuration
func (c Config) RedactSensitiveInfo() Config {
nc := c.Clone()
for configName, configVals := range nc {
for _, helpKV := range HelpSubSysMap[configName] {
if helpKV.Sensitive {
for name, kvs := range configVals {
for i := range kvs {
if kvs[i].Key == helpKV.Key && len(kvs[i].Value) > 0 {
kvs[i].Value = "*redacted*"
}
}
configVals[name] = kvs
}
}
}
nc[configName] = configVals
}
return nc
}
type configWriteTo struct { type configWriteTo struct {
Config Config
filterByKey string filterByKey string

View File

@ -26,6 +26,7 @@ var (
Key: Endpoints, Key: Endpoints,
Description: `comma separated list of etcd endpoints e.g. "http://localhost:2379"`, Description: `comma separated list of etcd endpoints e.g. "http://localhost:2379"`,
Type: "csv", Type: "csv",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: PathPrefix, Key: PathPrefix,
@ -44,12 +45,14 @@ var (
Description: `client cert for mTLS authentication`, Description: `client cert for mTLS authentication`,
Optional: true, Optional: true,
Type: "path", Type: "path",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: ClientCertKey, Key: ClientCertKey,
Description: `client cert key for mTLS authentication`, Description: `client cert key for mTLS authentication`,
Optional: true, Optional: true,
Type: "path", Type: "path",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: config.Comment, Key: config.Comment,

View File

@ -25,6 +25,10 @@ type HelpKV struct {
Description string `json:"description"` Description string `json:"description"`
Optional bool `json:"optional"` Optional bool `json:"optional"`
// Indicates if the value contains sensitive info
// that shouldn't be exposed in certain apis
Sensitive bool `json:"sensitive"`
// Indicates if sub-sys supports multiple targets. // Indicates if sub-sys supports multiple targets.
MultipleTargets bool `json:"multipleTargets"` MultipleTargets bool `json:"multipleTargets"`
} }

View File

@ -26,6 +26,7 @@ var (
Key: ServerAddr, Key: ServerAddr,
Description: `AD/LDAP server address e.g. "myldapserver.com:636"`, Description: `AD/LDAP server address e.g. "myldapserver.com:636"`,
Type: "address", Type: "address",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: STSExpiry, Key: STSExpiry,
@ -38,12 +39,14 @@ var (
Description: `DN for LDAP read-only service account used to perform DN and group lookups`, Description: `DN for LDAP read-only service account used to perform DN and group lookups`,
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: LookupBindPassword, Key: LookupBindPassword,
Description: `Password for LDAP read-only service account used to perform DN and group lookups`, Description: `Password for LDAP read-only service account used to perform DN and group lookups`,
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: UserDNSearchBaseDN, Key: UserDNSearchBaseDN,
@ -62,6 +65,7 @@ var (
Description: `";" separated list of username bind DNs e.g. "uid=%s,cn=accounts,dc=myldapserver,dc=com"`, Description: `";" separated list of username bind DNs e.g. "uid=%s,cn=accounts,dc=myldapserver,dc=com"`,
Optional: true, Optional: true,
Type: "list", Type: "list",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: GroupSearchFilter, Key: GroupSearchFilter,

View File

@ -35,12 +35,14 @@ var (
Key: target.WebhookEndpoint, Key: target.WebhookEndpoint,
Description: "webhook server endpoint e.g. http://localhost:8080/minio/events", Description: "webhook server endpoint e.g. http://localhost:8080/minio/events",
Type: "url", Type: "url",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.WebhookAuthToken, Key: target.WebhookAuthToken,
Description: "opaque string or JWT authorization token", Description: "opaque string or JWT authorization token",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.WebhookQueueDir, Key: target.WebhookQueueDir,
@ -65,12 +67,14 @@ var (
Description: "client cert for Webhook mTLS auth", Description: "client cert for Webhook mTLS auth",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.WebhookClientKey, Key: target.WebhookClientKey,
Description: "client cert key for Webhook mTLS auth", Description: "client cert key for Webhook mTLS auth",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
} }
@ -79,6 +83,7 @@ var (
Key: target.AmqpURL, Key: target.AmqpURL,
Description: "AMQP server endpoint e.g. `amqp://myuser:mypassword@localhost:5672`", Description: "AMQP server endpoint e.g. `amqp://myuser:mypassword@localhost:5672`",
Type: "url", Type: "url",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.AmqpExchange, Key: target.AmqpExchange,
@ -97,6 +102,7 @@ var (
Description: "routing key for publishing", Description: "routing key for publishing",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.AmqpMandatory, Key: target.AmqpMandatory,
@ -171,12 +177,14 @@ var (
Description: "username for SASL/PLAIN or SASL/SCRAM authentication", Description: "username for SASL/PLAIN or SASL/SCRAM authentication",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.KafkaSASLPassword, Key: target.KafkaSASLPassword,
Description: "password for SASL/PLAIN or SASL/SCRAM authentication", Description: "password for SASL/PLAIN or SASL/SCRAM authentication",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.KafkaSASLMechanism, Key: target.KafkaSASLMechanism,
@ -213,12 +221,14 @@ var (
Description: "path to client certificate for mTLS auth", Description: "path to client certificate for mTLS auth",
Optional: true, Optional: true,
Type: "path", Type: "path",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.KafkaClientTLSKey, Key: target.KafkaClientTLSKey,
Description: "path to client key for mTLS auth", Description: "path to client key for mTLS auth",
Optional: true, Optional: true,
Type: "path", Type: "path",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.KafkaQueueDir, Key: target.KafkaQueueDir,
@ -251,6 +261,7 @@ var (
Key: target.MqttBroker, Key: target.MqttBroker,
Description: "MQTT server endpoint e.g. `tcp://localhost:1883`", Description: "MQTT server endpoint e.g. `tcp://localhost:1883`",
Type: "uri", Type: "uri",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.MqttTopic, Key: target.MqttTopic,
@ -262,12 +273,14 @@ var (
Description: "MQTT username", Description: "MQTT username",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.MqttPassword, Key: target.MqttPassword,
Description: "MQTT password", Description: "MQTT password",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.MqttQoS, Key: target.MqttQoS,
@ -312,6 +325,7 @@ var (
Key: target.PostgresConnectionString, Key: target.PostgresConnectionString,
Description: `Postgres server connection-string e.g. "host=localhost port=5432 dbname=minio_events user=postgres password=password sslmode=disable"`, Description: `Postgres server connection-string e.g. "host=localhost port=5432 dbname=minio_events user=postgres password=password sslmode=disable"`,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.PostgresTable, Key: target.PostgresTable,
@ -355,6 +369,7 @@ var (
Description: `MySQL data-source-name connection string e.g. "<user>:<password>@tcp(<host>:<port>)/<database>"`, Description: `MySQL data-source-name connection string e.g. "<user>:<password>@tcp(<host>:<port>)/<database>"`,
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.MySQLTable, Key: target.MySQLTable,
@ -397,6 +412,7 @@ var (
Key: target.NATSAddress, Key: target.NATSAddress,
Description: "NATS server address e.g. '0.0.0.0:4222'", Description: "NATS server address e.g. '0.0.0.0:4222'",
Type: "address", Type: "address",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.NATSSubject, Key: target.NATSSubject,
@ -408,18 +424,21 @@ var (
Description: "NATS username", Description: "NATS username",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.NATSPassword, Key: target.NATSPassword,
Description: "NATS password", Description: "NATS password",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.NATSToken, Key: target.NATSToken,
Description: "NATS token", Description: "NATS token",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.NATSTLS, Key: target.NATSTLS,
@ -468,18 +487,21 @@ var (
Description: "path to certificate chain of the target NATS server", Description: "path to certificate chain of the target NATS server",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.NATSClientCert, Key: target.NATSClientCert,
Description: "client cert for NATS mTLS auth", Description: "client cert for NATS mTLS auth",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.NATSClientKey, Key: target.NATSClientKey,
Description: "client cert key for NATS mTLS auth", Description: "client cert key for NATS mTLS auth",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.NATSQueueDir, Key: target.NATSQueueDir,
@ -506,6 +528,7 @@ var (
Key: target.NSQAddress, Key: target.NSQAddress,
Description: "NSQ server address e.g. '127.0.0.1:4150'", Description: "NSQ server address e.g. '127.0.0.1:4150'",
Type: "address", Type: "address",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.NSQTopic, Key: target.NSQTopic,
@ -549,6 +572,7 @@ var (
Key: target.ElasticURL, Key: target.ElasticURL,
Description: "Elasticsearch server's address, with optional authentication info", Description: "Elasticsearch server's address, with optional authentication info",
Type: "url", Type: "url",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.ElasticIndex, Key: target.ElasticIndex,
@ -577,12 +601,14 @@ var (
Description: "username for Elasticsearch basic-auth", Description: "username for Elasticsearch basic-auth",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.ElasticPassword, Key: target.ElasticPassword,
Description: "password for Elasticsearch basic-auth", Description: "password for Elasticsearch basic-auth",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: config.Comment, Key: config.Comment,
@ -597,11 +623,13 @@ var (
Key: target.RedisAddress, Key: target.RedisAddress,
Description: "Redis server's address. For example: `localhost:6379`", Description: "Redis server's address. For example: `localhost:6379`",
Type: "address", Type: "address",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.RedisKey, Key: target.RedisKey,
Description: "Redis key to store/update events, key is auto-created", Description: "Redis key to store/update events, key is auto-created",
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.RedisFormat, Key: target.RedisFormat,
@ -613,6 +641,7 @@ var (
Description: "Redis server password", Description: "Redis server password",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: target.RedisQueueDir, Key: target.RedisQueueDir,

View File

@ -26,12 +26,14 @@ var (
Key: URL, Key: URL,
Description: `[DEPRECATED] OPA HTTP(s) endpoint e.g. "http://localhost:8181/v1/data/httpapi/authz/allow"`, Description: `[DEPRECATED] OPA HTTP(s) endpoint e.g. "http://localhost:8181/v1/data/httpapi/authz/allow"`,
Type: "url", Type: "url",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: AuthToken, Key: AuthToken,
Description: "[DEPRECATED] authorization token for OPA endpoint", Description: "[DEPRECATED] authorization token for OPA endpoint",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: config.Comment, Key: config.Comment,

View File

@ -28,12 +28,14 @@ var (
Key: Endpoint, Key: Endpoint,
Description: `HTTP(s) endpoint e.g. "http://localhost:8080/minio/logs/server"`, Description: `HTTP(s) endpoint e.g. "http://localhost:8080/minio/logs/server"`,
Type: "url", Type: "url",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: AuthToken, Key: AuthToken,
Description: `opaque string or JWT authorization token`, Description: `opaque string or JWT authorization token`,
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: config.Comment, Key: config.Comment,
@ -48,12 +50,14 @@ var (
Key: Endpoint, Key: Endpoint,
Description: `HTTP(s) endpoint e.g. "http://localhost:8080/minio/logs/audit"`, Description: `HTTP(s) endpoint e.g. "http://localhost:8080/minio/logs/audit"`,
Type: "url", Type: "url",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: AuthToken, Key: AuthToken,
Description: `opaque string or JWT authorization token`, Description: `opaque string or JWT authorization token`,
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: config.Comment, Key: config.Comment,
@ -66,12 +70,14 @@ var (
Description: "mTLS certificate for Audit Webhook authentication", Description: "mTLS certificate for Audit Webhook authentication",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
config.HelpKV{ config.HelpKV{
Key: ClientKey, Key: ClientKey,
Description: "mTLS certificate key for Audit Webhook authentication", Description: "mTLS certificate key for Audit Webhook authentication",
Optional: true, Optional: true,
Type: "string", Type: "string",
Sensitive: true,
}, },
} }
) )