2022-08-15 08:23:25 +00:00
|
|
|
//
|
|
|
|
// DISCLAIMER
|
|
|
|
//
|
2024-02-16 09:04:43 +00:00
|
|
|
// Copyright 2016-2024 ArangoDB GmbH, Cologne, Germany
|
2022-08-15 08:23:25 +00:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
//
|
|
|
|
// Copyright holder is ArangoDB GmbH, Cologne, Germany
|
|
|
|
//
|
|
|
|
|
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2022-09-05 08:09:26 +00:00
|
|
|
"fmt"
|
2022-08-15 08:23:25 +00:00
|
|
|
|
2024-02-16 09:04:43 +00:00
|
|
|
pbSharedV1 "github.com/arangodb/kube-arangodb/integrations/shared/v1/definition"
|
2022-08-15 08:23:25 +00:00
|
|
|
pb "github.com/arangodb/kube-arangodb/pkg/api/server"
|
2022-09-05 08:09:26 +00:00
|
|
|
"github.com/arangodb/kube-arangodb/pkg/logging"
|
2022-08-15 08:23:25 +00:00
|
|
|
"github.com/arangodb/kube-arangodb/pkg/version"
|
|
|
|
)
|
|
|
|
|
2024-02-16 09:04:43 +00:00
|
|
|
func (s *Server) GetVersion(ctx context.Context, _ *pbSharedV1.Empty) (*pb.Version, error) {
|
2022-08-15 08:23:25 +00:00
|
|
|
v := version.GetVersionV1()
|
|
|
|
return &pb.Version{
|
|
|
|
Version: string(v.Version),
|
|
|
|
Build: v.Build,
|
|
|
|
Edition: string(v.Edition),
|
|
|
|
GoVersion: v.GoVersion,
|
|
|
|
BuildDate: v.BuildDate,
|
|
|
|
}, nil
|
|
|
|
}
|
2022-09-05 08:09:26 +00:00
|
|
|
|
|
|
|
var loglevelMap = map[pb.LogLevel]logging.Level{
|
2024-02-16 09:04:43 +00:00
|
|
|
pb.LogLevel_LOG_LEVEL_TRACE_UNSPECIFIED: logging.Trace,
|
|
|
|
pb.LogLevel_LOG_LEVEL_DEBUG: logging.Debug,
|
|
|
|
pb.LogLevel_LOG_LEVEL_INFO: logging.Info,
|
|
|
|
pb.LogLevel_LOG_LEVEL_WARN: logging.Warn,
|
|
|
|
pb.LogLevel_LOG_LEVEL_ERROR: logging.Error,
|
|
|
|
pb.LogLevel_LOG_LEVEL_FATAL: logging.Fatal,
|
2022-09-05 08:09:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func logLevelToGRPC(l logging.Level) pb.LogLevel {
|
|
|
|
for grpcVal, localVal := range loglevelMap {
|
|
|
|
if l == localVal {
|
|
|
|
return grpcVal
|
|
|
|
}
|
|
|
|
}
|
2024-02-16 09:04:43 +00:00
|
|
|
return pb.LogLevel_LOG_LEVEL_DEBUG
|
2022-09-05 08:09:26 +00:00
|
|
|
}
|
|
|
|
|
2024-02-16 09:04:43 +00:00
|
|
|
func (s *Server) GetLogLevel(ctx context.Context, _ *pbSharedV1.Empty) (*pb.LogLevelConfig, error) {
|
2022-09-05 08:09:26 +00:00
|
|
|
l := s.getLogLevelsByTopics()
|
|
|
|
|
|
|
|
topics := make(map[string]pb.LogLevel, len(l))
|
|
|
|
for topic, level := range l {
|
|
|
|
topics[topic] = logLevelToGRPC(level)
|
|
|
|
}
|
|
|
|
return &pb.LogLevelConfig{
|
|
|
|
Topics: topics,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2024-02-16 09:04:43 +00:00
|
|
|
func (s *Server) SetLogLevel(ctx context.Context, cfg *pb.LogLevelConfig) (*pbSharedV1.Empty, error) {
|
2022-09-05 08:09:26 +00:00
|
|
|
l := make(map[string]logging.Level, len(cfg.Topics))
|
|
|
|
for topic, grpcLevel := range cfg.Topics {
|
|
|
|
level, ok := loglevelMap[grpcLevel]
|
|
|
|
if !ok {
|
2024-02-16 09:04:43 +00:00
|
|
|
return &pbSharedV1.Empty{}, fmt.Errorf("unknown log level %s for topic %s", grpcLevel, topic)
|
2022-09-05 08:09:26 +00:00
|
|
|
}
|
|
|
|
l[topic] = level
|
|
|
|
}
|
|
|
|
s.setLogLevelsByTopics(l)
|
2024-02-16 09:04:43 +00:00
|
|
|
return &pbSharedV1.Empty{}, nil
|
2022-09-05 08:09:26 +00:00
|
|
|
}
|