Skip to content

Commit

Permalink
sloglint fixes (#1584)
Browse files Browse the repository at this point in the history
  • Loading branch information
RebeccaMahany authored Feb 7, 2024
1 parent 6e83279 commit 0147ee0
Show file tree
Hide file tree
Showing 14 changed files with 32 additions and 22 deletions.
2 changes: 1 addition & 1 deletion cmd/launcher/extension.go
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ func createExtensionRuntime(ctx context.Context, k types.Knapsack, launcherClien
if k.Transport() == "grpc" && k.LogMaxBytesPerBatch() > 3 {
slogger.Log(ctx, slog.LevelInfo,
"LogMaxBytesPerBatch is set above the grpc recommended maximum of 3. Expect errors",
"LogMaxBytesPerBatch", k.LogMaxBytesPerBatch(),
"log_max_bytes_per_batch", k.LogMaxBytesPerBatch(),
)
}
extOpts.MaxBytesPerBatch = k.LogMaxBytesPerBatch() << 20
Expand Down
3 changes: 2 additions & 1 deletion cmd/launcher/launcher.go
Original file line number Diff line number Diff line change
Expand Up @@ -332,7 +332,8 @@ func runLauncher(ctx context.Context, cancel func(), multiSlogger, systemMultiSl
runGroup.Add("osqueryExtension", extension.Execute, extension.Interrupt)

versionInfo := version.Version()
k.SystemSlogger().Info("started kolide launcher",
k.SystemSlogger().Log(ctx, slog.LevelInfo,
"started kolide launcher",
"version", versionInfo.Version,
"build", versionInfo.Revision,
)
Expand Down
4 changes: 2 additions & 2 deletions ee/desktop/runner/runner.go
Original file line number Diff line number Diff line change
Expand Up @@ -385,7 +385,7 @@ func (r *DesktopUsersProcessesRunner) FlagsChanged(flagKeys ...keys.FlagKey) {
r.processSpawningEnabled = r.knapsack.DesktopEnabled()
r.slogger.Log(context.TODO(), slog.LevelDebug,
"runner processSpawningEnabled set by control server",
"processSpawningEnabled", r.processSpawningEnabled,
"process_spawning_enabled", r.processSpawningEnabled,
)
}
}
Expand Down Expand Up @@ -811,7 +811,7 @@ func (r *DesktopUsersProcessesRunner) desktopCommand(executablePath, uid, socket
scanner := bufio.NewScanner(combined)

for scanner.Scan() {
r.slogger.Log(context.TODO(), slog.LevelDebug,
r.slogger.Log(context.TODO(), slog.LevelDebug, // nolint:sloglint // it's fine to not have a constant or literal here
scanner.Text(),
"uid", uid,
"subprocess", "desktop",
Expand Down
6 changes: 3 additions & 3 deletions ee/desktop/runner/runner_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -343,9 +343,9 @@ func (r *DesktopUsersProcessesRunner) getXauthority(ctx context.Context, uid str

r.slogger.Log(ctx, slog.LevelDebug,
"could not find xauthority in any known location",
"wayland", waylandXAuthorityLocationPattern,
"x11", x11XauthorityLocation,
"default", homeLocation,
"wayland_location", waylandXAuthorityLocationPattern,
"x11_location", x11XauthorityLocation,
"default_location", homeLocation,
)

return ""
Expand Down
2 changes: 1 addition & 1 deletion ee/log/osquerylogs/log.go
Original file line number Diff line number Diff line change
Expand Up @@ -80,7 +80,7 @@ func (l *OsqueryLogAdapter) Write(p []byte) (int, error) {

msg := strings.TrimSpace(string(p))
caller := extractOsqueryCaller(msg)
l.slogger.Log(context.TODO(), level,
l.slogger.Log(context.TODO(), level, // nolint:sloglint // it's fine to not have a constant or literal here
msg,
"caller", caller,
)
Expand Down
6 changes: 4 additions & 2 deletions pkg/log/logshipper/logshipper.go
Original file line number Diff line number Diff line change
Expand Up @@ -307,14 +307,16 @@ func (ls *LogShipper) updateLogShippingLevel() {
case "error":
ls.slogLevel.Set(slog.LevelError)
case "default":
ls.knapsack.Slogger().Error("unrecognized flag value for log shipping level",
ls.knapsack.Slogger().Log(context.TODO(), slog.LevelError,
"unrecognized flag value for log shipping level",
"flag_value", ls.knapsack.LogShippingLevel(),
"current_log_level", ls.slogLevel.String(),
)
}

if startingLevel != ls.slogLevel.Level() {
ls.knapsack.Slogger().Info("log shipping level changed",
ls.knapsack.Slogger().Log(context.TODO(), slog.LevelInfo,
"log shipping level changed",
"old_log_level", startingLevel.String(),
"new_log_level", ls.slogLevel.Level().String(),
"send_interval", sendInterval.String(),
Expand Down
8 changes: 4 additions & 4 deletions pkg/log/multislogger/multislogger_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,29 +24,29 @@ func TestMultiSlogger(t *testing.T) {
}

multislogger := New()
multislogger.Logger.Debug("dont panic")
multislogger.Logger.DebugContext(context.TODO(), "dont panic")

multislogger = New(slog.NewJSONHandler(&debugLogBuf, &slog.HandlerOptions{Level: slog.LevelDebug}))

shipperLogLevel := new(slog.LevelVar)
shipperLogLevel.Set(slog.LevelInfo)
multislogger.AddHandler(slog.NewJSONHandler(&shipperBuf, &slog.HandlerOptions{Level: shipperLogLevel}))

multislogger.Logger.Debug("debug_msg")
multislogger.Logger.DebugContext(context.TODO(), "debug_msg")

require.Contains(t, debugLogBuf.String(), "debug_msg", "should be in debug log since it's debug level")
require.Empty(t, shipperBuf.String(), "should not be in shipper log since it's debug level")
clearBufsFn()

multislogger.Logger.Info("info_msg")
multislogger.Logger.InfoContext(context.TODO(), "info_msg")

require.Contains(t, debugLogBuf.String(), "info_msg", "should be in debug log since it's info level and that's higher than debug level")
require.Contains(t, shipperBuf.String(), "info_msg", "should be in shipper log since it's info level")
clearBufsFn()

// set shipper level to debug
shipperLogLevel.Set(slog.LevelDebug)
multislogger.Logger.Debug("debug_msg")
multislogger.Logger.DebugContext(context.TODO(), "debug_msg")

require.Contains(t, debugLogBuf.String(), "debug_msg", "should be in debug log since it's debug level")
require.Contains(t, shipperBuf.String(), "debug_msg", "should now be in shipper log since it's level was set to debug")
Expand Down
3 changes: 2 additions & 1 deletion pkg/service/check_health.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"context"
"encoding/json"
"fmt"
"log/slog"
"time"

"github.com/go-kit/kit/endpoint"
Expand Down Expand Up @@ -106,7 +107,7 @@ func (s *grpcServer) CheckHealth(ctx context.Context, req *pb.AgentApiRequest) (
func (mw logmw) CheckHealth(ctx context.Context) (status int32, err error) {
defer func(begin time.Time) {
uuid, _ := uuid.FromContext(ctx)
mw.knapsack.Slogger().Debug("check health",
mw.knapsack.Slogger().Log(ctx, slog.LevelDebug, "check health",
"method", "CheckHealth",
"uuid", uuid,
"status", status,
Expand Down
4 changes: 3 additions & 1 deletion pkg/service/client_grpc.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package service
import (
"context"
"crypto/x509"
"log/slog"
"net"
"strings"
"time"
Expand Down Expand Up @@ -105,7 +106,8 @@ func DialGRPC(
opts ...grpc.DialOption, // Used for overrides in testing
) (*grpc.ClientConn, error) {

k.Slogger().Debug("dialing grpc server",
k.Slogger().Log(context.TODO(), slog.LevelDebug,
"dialing grpc server",
"server", k.KolideServerURL(),
"tls_secure", !k.InsecureTLS(),
"transport_secure", !k.InsecureTransportTLS(),
Expand Down
2 changes: 1 addition & 1 deletion pkg/service/publish_logs.go
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,7 @@ func (mw logmw) PublishLogs(ctx context.Context, nodeKey string, logType logger.
}
}

mw.knapsack.Slogger().Log(ctx, levelForError(err), message,
mw.knapsack.Slogger().Log(ctx, levelForError(err), message, // nolint:sloglint // it's fine to not have a constant or literal here
"method", "PublishLogs",
"uuid", uuid,
"logType", logType,
Expand Down
2 changes: 1 addition & 1 deletion pkg/service/publish_results.go
Original file line number Diff line number Diff line change
Expand Up @@ -194,7 +194,7 @@ func (mw logmw) PublishResults(ctx context.Context, nodeKey string, results []di
}
}

mw.knapsack.Slogger().Log(ctx, levelForError(err), message,
mw.knapsack.Slogger().Log(ctx, levelForError(err), message, // nolint:sloglint // it's fine to not have a constant or literal here
"method", "PublishResults",
"uuid", uuid,
"results", string(resJSON),
Expand Down
2 changes: 1 addition & 1 deletion pkg/service/request_config.go
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,7 @@ func (mw logmw) RequestConfig(ctx context.Context, nodeKey string) (config strin
message = "failure"
}

mw.knapsack.Slogger().Log(ctx, levelForError(err), message,
mw.knapsack.Slogger().Log(ctx, levelForError(err), message, // nolint:sloglint // it's fine to not have a constant or literal here
"method", "RequestConfig",
"uuid", uuid,
"config_size", len(config),
Expand Down
2 changes: 1 addition & 1 deletion pkg/service/request_enrollment.go
Original file line number Diff line number Diff line change
Expand Up @@ -217,7 +217,7 @@ func (mw logmw) RequestEnrollment(ctx context.Context, enrollSecret, hostIdentif
)
}

mw.knapsack.Slogger().Log(ctx, levelForError(err), message, keyvals...)
mw.knapsack.Slogger().Log(ctx, levelForError(err), message, keyvals...) // nolint:sloglint // it's fine to not have a constant or literal here
}(time.Now())

nodekey, reauth, err = mw.next.RequestEnrollment(ctx, enrollSecret, hostIdentifier, details)
Expand Down
8 changes: 6 additions & 2 deletions pkg/service/tls.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,12 @@ package service

import (
"bytes"
"context"
"crypto/sha256"
"crypto/tls"
"crypto/x509"
"errors"
"log/slog"
"net/url"

"github.com/kolide/launcher/ee/agent/types"
Expand All @@ -18,7 +20,8 @@ func makeTLSConfig(k types.Knapsack, rootPool *x509.CertPool) *tls.Config {
// gRPC doesn't use the port for TLS verification. So we strip it here.
u, err := url.Parse(k.KolideServerURL())
if err != nil {
k.Slogger().Error("failed to parse server URL",
k.Slogger().Log(context.TODO(), slog.LevelError,
"failed to parse server URL",
"err", err,
)
return nil
Expand Down Expand Up @@ -54,7 +57,8 @@ func makeTLSConfig(k types.Knapsack, rootPool *x509.CertPool) *tls.Config {
// gRPC does not seem to expose the error in a way that
// we can get at it later. At least this provides some
// feedback to the user about what is going wrong.
k.Slogger().Error("no match found with pinned certificates",
k.Slogger().Log(context.TODO(), slog.LevelError,
"no match found with pinned certificates",
"err", "certificate pin validation failed",
)
return errors.New("no match found with pinned cert")
Expand Down

0 comments on commit 0147ee0

Please sign in to comment.