-
Notifications
You must be signed in to change notification settings - Fork 2.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Perform log.fatal if TLS flags are used when tls.enabled=false #2893 #3030
Conversation
39138be
to
f156584
Compare
3e5607a
to
b3bf080
Compare
@yurishkuro let me know what you think now |
pkg/config/tlscfg/flags.go
Outdated
var p Options | ||
if c.ShowEnabled { | ||
p.Enabled = v.GetBool(c.Prefix + tlsEnabled) | ||
} else { | ||
return p, errors.New("ES_TLS_ENABLED is set to false unable to talk to server(s)") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the point of the issue was to raise an error if enabled=false but other flags are present. There's nothing wrong with enabled=false by itself. Also, this is not specific to ES, if you want to refer to the actual property it would be c.Prefix + tlsEnabled
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
noted
b3bf080
to
700af6f
Compare
@yurishkuro let me know what you think now |
700af6f
to
1f596c0
Compare
cmd/agent/app/reporter/grpc/flags.go
Outdated
b.DiscoveryMinPeers = v.GetInt(discoveryMinPeers) | ||
return b | ||
if TLS, err := tlsFlagsConfig.InitFromViper(v); err != nil { | ||
return b, err |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
- not sure if this will pass the linter, if not you can swap the condition and do a return in the
else
part. - it looks odd when local var is upper case, use
tls
orcfg
@@ -15,6 +15,7 @@ | |||
package app | |||
|
|||
import ( | |||
"github.com/stretchr/testify/require" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
did you run make lint
?
pkg/config/tlscfg/flags.go
Outdated
if c.ShowEnabled { | ||
p.Enabled = v.GetBool(c.Prefix + tlsEnabled) | ||
} else { | ||
return p, fmt.Errorf("%s has been set to False", c.Prefix+tlsEnabled) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
c.ShowEnabled == false
doesn't mean that tls was disabled, it means that the CLI option does not need to be present- even if TLS is disabled (
p.Enable == false
), doesn't mean that this is an error. The error is when it is false but any other flags are non-empty:(!p.Enabled || !c.ShowEnabled) && anyOtherFieldIsNotEmpty
7b116fb
to
24b9800
Compare
@yurishkuro ran lint and tests let me know what you think now |
plugin/metrics/prometheus/options.go
Outdated
cfg := &opt.Primary | ||
cfg.ServerURL = stripWhiteSpace(v.GetString(cfg.namespace + suffixServerURL)) | ||
cfg.ConnectTimeout = v.GetDuration(cfg.namespace + suffixConnectTimeout) | ||
cfg.TLS = cfg.getTLSFlagsConfig().InitFromViper(v) | ||
if tls, err := cfg.getTLSFlagsConfig().InitFromViper(v); err == nil { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The failing unit test job is due to linter errors, the majority of which are:
if block ends with a return statement, so drop this else and outdent its block (move short variable declaration to its own line if necessary)
Whether if the linter is right about this being a good style or not is debatable. :)
One option is:
tls, err := cfg.getTLSFlagsConfig().InitFromViper(v)
if err != nil {
return err
}
cfg.TLS = tls
return nil
To check for linter errors, run make lint
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@albertteoh don't think see this is the output of make lint and it does point to any of my changes
time staticcheck ./... \
| grep -v \
-e model/model.pb.go \
-e proto-gen \
-e _test.pb.go \
-e thrift-gen/ \
-e swagger-gen/ \
>> .lint.log || true
real 0m5.547s
user 0m5.165s
sys 0m7.180s
time gosec -quiet -exclude=G104,G107 ./...
Results:
[/Users/rkaur/github/jaeger/plugin/sampling/strategystore/adaptive/processor.go:226] - G404 (CWE-338): Use of weak random number generator (math/rand instead of crypto/rand) (Confidence: MEDIUM, Severity: HIGH)
225: func addJitter(jitterAmount time.Duration) {
> 226: delay := (jitterAmount / 2) + time.Duration(rand.Int63n(int64(jitterAmount/2)))
227: time.Sleep(delay)
[/Users/rkaur/github/jaeger/pkg/discovery/grpcresolver/grpc_resolver.go:68] - G404 (CWE-338): Use of weak random number generator (math/rand instead of crypto/rand) (Confidence: MEDIUM, Severity: HIGH)
67: seed := time.Now().UnixNano()
> 68: random := rand.New(rand.NewSource(seed))
69: r := &Resolver{
[/Users/rkaur/github/jaeger/crossdock/services/tracehandler.go:308] - G404 (CWE-338): Use of weak random number generator (math/rand instead of crypto/rand) (Confidence: MEDIUM, Severity: HIGH)
307: // A random 8-byte hex
> 308: return fmt.Sprintf("%x", rand.Int63())
309: }
[/Users/rkaur/github/jaeger/cmd/ingester/app/processor/decorator/retry.go:54] - G404 (CWE-338): Use of weak random number generator (math/rand instead of crypto/rand) (Confidence: MEDIUM, Severity: HIGH)
53: propagateError: false,
> 54: rand: rand.New(rand.NewSource(time.Now().UnixNano())),
55: }
[/Users/rkaur/github/jaeger/cmd/collector/app/sanitizer/cache/auto_refresh_cache.go:136] - G404 (CWE-338): Use of weak random number generator (math/rand instead of crypto/rand) (Confidence: MEDIUM, Severity: HIGH)
135: func getRandomSleepTime(interval time.Duration) time.Duration {
> 136: return (interval / 2) + time.Duration(rand.Int63n(int64(interval/2)))
137: }
[/Users/rkaur/github/jaeger/cmd/anonymizer/app/uiconv/reader.go:40] - G304 (CWE-22): Potential file inclusion via variable (Confidence: HIGH, Severity: MEDIUM)
39: func NewReader(capturedFile string, logger *zap.Logger) (*Reader, error) {
> 40: cf, err := os.OpenFile(capturedFile, os.O_RDONLY, os.ModePerm)
41: if err != nil {
[/Users/rkaur/github/jaeger/cmd/anonymizer/app/uiconv/extractor.go:38] - G304 (CWE-22): Potential file inclusion via variable (Confidence: HIGH, Severity: MEDIUM)
37: func NewExtractor(uiFile string, traceID string, reader *Reader, logger *zap.Logger) (*Extractor, error) {
> 38: f, err := os.OpenFile(uiFile, os.O_CREATE|os.O_WRONLY, os.ModePerm)
39: if err != nil {
[/Users/rkaur/github/jaeger/model/converter/thrift/jaeger/from_domain.go:106] - G601 (CWE-118): Implicit memory aliasing in for loop. (Confidence: MEDIUM, Severity: MEDIUM)
105: for idx, kv := range kvs {
> 106: jaegerTags[idx] = d.keyValueToTag(&kv)
107: }
[/Users/rkaur/github/jaeger/cmd/anonymizer/main.go:72] - G601 (CWE-118): Implicit memory aliasing in for loop. (Confidence: MEDIUM, Severity: MEDIUM)
71: for _, span := range spans {
> 72: writer.WriteSpan(&span)
73: }
Summary:
Gosec : dev
Files : 441
Lines : 73829
Nosec : 10
Issues : 9
164.77 real 166.34 user 224.53 sys
make: *** [lint-gosec] Error 1
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@albertteoh ooh it is make go-lint
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
make lint
should run make go-lint
, but it looks like it's gosec -quiet -exclude=G104,G107 ./...
that's failing for you before it gets to call make go-lint
. This is odd, because gosec
passes in CI (and for me as well).
Did you run make install-tools
to install gosec
? which gosec
should point to $GOPATH/bin/gosec
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
installed explicitly gosec but didn't run make install-tools
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
it should show a warning now should not show failing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ooh less than 95 got it
68279e2
to
8ba6555
Compare
Codecov Report
@@ Coverage Diff @@
## main #3030 +/- ##
==========================================
- Coverage 96.53% 96.44% -0.09%
==========================================
Files 264 264
Lines 15449 15509 +60
==========================================
+ Hits 14913 14957 +44
- Misses 451 463 +12
- Partials 85 89 +4
Continue to review full report at Codecov.
|
8ba6555
to
8c74894
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To help with identifying test coverage gaps locally, I know of a few options (folks reading this, please feel free to add other suggestions):
- your IDE should support executing tests with coverage.
- run
make cover
from the project root. This checks coverage for the entire project so it takes some time. - I personally like to use a command that I install in .zshrc that is like
make cover
but runs from a path relative to the current dir, so it's much quicker. Happy to share that if you prefer this option.
pkg/config/tlscfg/flags_test.go
Outdated
err := command.ParseFlags(append(cmdLine, test.option)) | ||
require.NoError(t, err) | ||
_, err = flagCfg.InitFromViper(v) | ||
require.Error(t, err, "prefix.tls.enabled has been disable") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Error
just checks that the error is not nil. I would use EqualError
to assert on the actual error message.
pkg/config/tlscfg/flags.go
Outdated
p.CAPath = v.GetString(c.Prefix + tlsCA) | ||
p.CertPath = v.GetString(c.Prefix + tlsCert) | ||
p.KeyPath = v.GetString(c.Prefix + tlsKey) | ||
if cAPATH := v.GetString(c.Prefix + tlsCA); len(cAPATH) > 0 { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
cAPATH
seems like an unconventional name, I would use caPath
.
pkg/config/tlscfg/flags.go
Outdated
var p Options | ||
var checkAnyFieldIsEmpty bool | ||
if c.ShowEnabled { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@yurishkuro what is the purpose of ShowEnabled
and ShowServerName
?
If I do a search for ClientFlagsConfig{
in the project, both are always set to true
, so the zero value of false
is not used, or perhaps I've missed something.
Similarly for ShowClientCA
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
They weren't always true, some settings did not apply to some use cases. This may have changed since then.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@clock21am The Show*
flags have been removed in #3106 which should simplify efforts for you in this PR. Please merge these changes in from master.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
and thanks for confirming, Yuri.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the review @albertteoh @yurishkuro i will rebase my branch and fix it
pkg/config/tlscfg/flags.go
Outdated
p.KeyPath = v.GetString(c.Prefix + tlsKey) | ||
if cAPATH := v.GetString(c.Prefix + tlsCA); len(cAPATH) > 0 { | ||
p.CAPath = cAPATH | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why isn't there an else
case here like the others?
pkg/config/tlscfg/flags.go
Outdated
if c.ShowServerName { | ||
p.ServerName = v.GetString(c.Prefix + tlsServerName) | ||
} else { | ||
checkAnyFieldIsEmpty = true |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is this line of code ever called? I can't see where c.ShowServerName == false
.
pkg/config/tlscfg/flags.go
Outdated
p.Enabled = v.GetBool(c.Prefix + tlsEnabled) | ||
} | ||
if (!p.Enabled || !c.ShowEnabled) && !checkAnyFieldIsEmpty { | ||
return p, fmt.Errorf("%s has been disable", c.Prefix+tlsEnabled) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: I would extract fmt.Errorf("%s has been disable", c.Prefix+tlsEnabled)
into a function so there's only one place where the error message is defined.
Also, consider rewording this to be clearer on what is causing the error, a suggestion:
fmt.Errorf("some tls flags were set while %s=false", c.Prefix+tlsEnabled)
pkg/config/tlscfg/flags.go
Outdated
if c.ShowClientCA { | ||
p.ClientCAPath = v.GetString(c.Prefix + tlsClientCA) | ||
} else { | ||
checkAnyFieldIsEmpty = true |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
will this ever be called? I can't see where cShowClientCA == false
.
pkg/config/tlscfg/flags.go
Outdated
p.CAPath = v.GetString(c.Prefix + tlsCA) | ||
p.CertPath = v.GetString(c.Prefix + tlsCert) | ||
p.KeyPath = v.GetString(c.Prefix + tlsKey) | ||
if cAPATH := v.GetString(c.Prefix + tlsCA); len(cAPATH) > 0 { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the if/else cases could be simplified back to what it was before but add a bool var. So something like:
p.CAPath = v.GetString(c.Prefix + tlsCA)
p.CertPath = v.GetString(c.Prefix + tlsCert)
p.KeyPath = v.GetString(c.Prefix + tlsKey)
// or alternatively could loop over a list of these options.
areTLSFlagsUsed := v.IsSet(c.Prefix+tlsCA) || v.IsSet(c.Prefix+tlsCert) || v.IsSet(c.Prefix+tlsKey)
...
if (!p.Enabled || !c.ShowEnabled) && (p.SkipHostVerify && areTLSFlagsUsed) {
return p, fmt.Errorf("%s has been disable", c.Prefix+tlsEnabled)
}
pkg/kafka/auth/config.go
Outdated
@@ -95,7 +95,7 @@ func (config *AuthenticationConfig) InitFromViper(configPrefix string, v *viper. | |||
ShowServerName: true, | |||
} | |||
|
|||
config.TLS = tlsClientConfig.InitFromViper(v) | |||
config.TLS, _ = tlsClientConfig.InitFromViper(v) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why is the error ignored? I thought we'd want to report the TLS flag usage error for Kafka storage too?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
because it has been set to true later https://github.com/jaegertracing/jaeger/blob/master/pkg/kafka/auth/config.go#L96
…tracing#2893) Signed-off-by: Rajdeep Kaur <rajdeep51994@gmail.com>
ebbd75c
to
9e51d3e
Compare
This commit adds tls flag test in collector/app/builder_flag_test.go and query/app/flag_test.go Also fixes InitFromViper check in builder_flag.go (jaegertracing#2893) Signed-off-by: Rajdeep Kaur <rajdeep51994@gmail.com>
9e51d3e
to
f8f1cdf
Compare
pkg/config/tlscfg/flags.go
Outdated
return p | ||
areTLSFlagsUsed := v.IsSet(c.Prefix+tlsCA) || v.IsSet(c.Prefix+tlsCert) || v.IsSet(c.Prefix+tlsKey) || v.IsSet(c.Prefix+tlsServerName) | ||
if (!p.Enabled) && (p.SkipHostVerify && areTLSFlagsUsed) { | ||
return p, fmt.Errorf("%s has been disable", c.Prefix+tlsEnabled) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
return p, fmt.Errorf("%s has been disable", c.Prefix+tlsEnabled) | |
return p, fmt.Errorf("TLS parameters do not apply when %s=false", c.Prefix+tlsEnabled) |
cmd/query/app/flags_test.go
Outdated
v.Set("query.http.tls.ca", "def") | ||
v.Set("query.http.tls.key", "xyz") | ||
_, err := new(QueryOptions).InitFromViper(v, zap.NewNop()) | ||
require.Error(t, err, "query.http.tls.enabled has been disable") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This does not test for the type of error, only that it is not nil (the last argument is only used when logging a failure).
If you want to test for the actual error, I would suggest this:
require.Error(t, err)
assert.Contains(t, err.Error(), "some relevant substring of the message")
What's the status of this PR? |
Hey
hey will start working on it again..somehow lost it will update it today. |
This pull request has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. You may re-open it if you need more time. |
Signed-off-by: Yuri Shkuro <github@ysh.us>
Signed-off-by: Yuri Shkuro <github@ysh.us>
Signed-off-by: Yuri Shkuro <github@ysh.us>
@clock21am thank you! |
…tracing#2893 (jaegertracing#3030) Signed-off-by: Albert Teoh <see.kwang.teoh@gmail.com>
Signed-off-by: Rajdeep Kaur rajdeep51994@gmail.com
Which problem is this PR solving?
Short description of the changes