diff --git a/Makefile b/Makefile index 080e097..c9314aa 100644 --- a/Makefile +++ b/Makefile @@ -23,6 +23,7 @@ protos := \ proto/spire/api/types/federateswith.proto \ proto/spire/api/types/jointoken.proto \ proto/spire/api/types/jwtsvid.proto \ + proto/spire/api/types/logger.proto \ proto/spire/api/types/selector.proto \ proto/spire/api/types/spiffeid.proto \ proto/spire/api/types/status.proto \ @@ -32,11 +33,13 @@ protos := \ apiprotos := \ proto/spire/api/agent/debug/v1/debug.proto \ proto/spire/api/agent/delegatedidentity/v1/delegatedidentity.proto \ + proto/spire/api/agent/logger/v1/logger.proto \ proto/spire/api/server/agent/v1/agent.proto \ proto/spire/api/server/bundle/v1/bundle.proto \ proto/spire/api/server/debug/v1/debug.proto \ proto/spire/api/server/entry/v1/entry.proto \ proto/spire/api/server/localauthority/v1/localauthority.proto \ + proto/spire/api/server/logger/v1/logger.proto \ proto/spire/api/server/trustdomain/v1/trustdomain.proto \ proto/spire/api/server/svid/v1/svid.proto \ diff --git a/proto/spire/api/agent/logger/v1/logger.pb.go b/proto/spire/api/agent/logger/v1/logger.pb.go new file mode 100644 index 0000000..f831f4f --- /dev/null +++ b/proto/spire/api/agent/logger/v1/logger.pb.go @@ -0,0 +1,288 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// versions: +// protoc-gen-go v1.28.0 +// protoc v3.20.1 +// source: spire/api/agent/logger/v1/logger.proto + +package loggerv1 + +import ( + types "github.com/spiffe/spire-api-sdk/proto/spire/api/types" + protoreflect "google.golang.org/protobuf/reflect/protoreflect" + protoimpl "google.golang.org/protobuf/runtime/protoimpl" + reflect "reflect" + sync "sync" +) + +const ( + // Verify that this generated code is sufficiently up-to-date. + _ = protoimpl.EnforceVersion(20 - protoimpl.MinVersion) + // Verify that runtime/protoimpl is sufficiently up-to-date. + _ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20) +) + +// Empty Get Logger Request message for future extension +type GetLoggerRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields +} + +func (x *GetLoggerRequest) Reset() { + *x = GetLoggerRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_spire_api_agent_logger_v1_logger_proto_msgTypes[0] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *GetLoggerRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*GetLoggerRequest) ProtoMessage() {} + +func (x *GetLoggerRequest) ProtoReflect() protoreflect.Message { + mi := &file_spire_api_agent_logger_v1_logger_proto_msgTypes[0] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use GetLoggerRequest.ProtoReflect.Descriptor instead. +func (*GetLoggerRequest) Descriptor() ([]byte, []int) { + return file_spire_api_agent_logger_v1_logger_proto_rawDescGZIP(), []int{0} +} + +// Set Log Level Request message +type SetLogLevelRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + // The new level the logger should assume + NewLevel types.LogLevel `protobuf:"varint,1,opt,name=new_level,json=newLevel,proto3,enum=spire.api.types.LogLevel" json:"new_level,omitempty"` +} + +func (x *SetLogLevelRequest) Reset() { + *x = SetLogLevelRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_spire_api_agent_logger_v1_logger_proto_msgTypes[1] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *SetLogLevelRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*SetLogLevelRequest) ProtoMessage() {} + +func (x *SetLogLevelRequest) ProtoReflect() protoreflect.Message { + mi := &file_spire_api_agent_logger_v1_logger_proto_msgTypes[1] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use SetLogLevelRequest.ProtoReflect.Descriptor instead. +func (*SetLogLevelRequest) Descriptor() ([]byte, []int) { + return file_spire_api_agent_logger_v1_logger_proto_rawDescGZIP(), []int{1} +} + +func (x *SetLogLevelRequest) GetNewLevel() types.LogLevel { + if x != nil { + return x.NewLevel + } + return types.LogLevel(0) +} + +// Empty Reset Log Level Request message for future extension +type ResetLogLevelRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields +} + +func (x *ResetLogLevelRequest) Reset() { + *x = ResetLogLevelRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_spire_api_agent_logger_v1_logger_proto_msgTypes[2] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ResetLogLevelRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ResetLogLevelRequest) ProtoMessage() {} + +func (x *ResetLogLevelRequest) ProtoReflect() protoreflect.Message { + mi := &file_spire_api_agent_logger_v1_logger_proto_msgTypes[2] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ResetLogLevelRequest.ProtoReflect.Descriptor instead. +func (*ResetLogLevelRequest) Descriptor() ([]byte, []int) { + return file_spire_api_agent_logger_v1_logger_proto_rawDescGZIP(), []int{2} +} + +var File_spire_api_agent_logger_v1_logger_proto protoreflect.FileDescriptor + +var file_spire_api_agent_logger_v1_logger_proto_rawDesc = []byte{ + 0x0a, 0x26, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x61, 0x67, 0x65, 0x6e, + 0x74, 0x2f, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2f, 0x76, 0x31, 0x2f, 0x6c, 0x6f, 0x67, 0x67, + 0x65, 0x72, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x12, 0x19, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, + 0x61, 0x70, 0x69, 0x2e, 0x61, 0x67, 0x65, 0x6e, 0x74, 0x2e, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, + 0x2e, 0x76, 0x31, 0x1a, 0x1c, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x74, + 0x79, 0x70, 0x65, 0x73, 0x2f, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2e, 0x70, 0x72, 0x6f, 0x74, + 0x6f, 0x22, 0x12, 0x0a, 0x10, 0x47, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x52, 0x65, + 0x71, 0x75, 0x65, 0x73, 0x74, 0x22, 0x4c, 0x0a, 0x12, 0x53, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x4c, + 0x65, 0x76, 0x65, 0x6c, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x36, 0x0a, 0x09, 0x6e, + 0x65, 0x77, 0x5f, 0x6c, 0x65, 0x76, 0x65, 0x6c, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0e, 0x32, 0x19, + 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x74, 0x79, 0x70, 0x65, 0x73, + 0x2e, 0x4c, 0x6f, 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x52, 0x08, 0x6e, 0x65, 0x77, 0x4c, 0x65, + 0x76, 0x65, 0x6c, 0x22, 0x16, 0x0a, 0x14, 0x52, 0x65, 0x73, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x4c, + 0x65, 0x76, 0x65, 0x6c, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x32, 0x8d, 0x02, 0x0a, 0x06, + 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x12, 0x51, 0x0a, 0x09, 0x47, 0x65, 0x74, 0x4c, 0x6f, 0x67, + 0x67, 0x65, 0x72, 0x12, 0x2b, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, + 0x61, 0x67, 0x65, 0x6e, 0x74, 0x2e, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2e, 0x76, 0x31, 0x2e, + 0x47, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, + 0x1a, 0x17, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x74, 0x79, 0x70, + 0x65, 0x73, 0x2e, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x12, 0x55, 0x0a, 0x0b, 0x53, 0x65, 0x74, + 0x4c, 0x6f, 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x12, 0x2d, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, + 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x61, 0x67, 0x65, 0x6e, 0x74, 0x2e, 0x6c, 0x6f, 0x67, 0x67, 0x65, + 0x72, 0x2e, 0x76, 0x31, 0x2e, 0x53, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, + 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x17, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, + 0x61, 0x70, 0x69, 0x2e, 0x74, 0x79, 0x70, 0x65, 0x73, 0x2e, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, + 0x12, 0x59, 0x0a, 0x0d, 0x52, 0x65, 0x73, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x4c, 0x65, 0x76, 0x65, + 0x6c, 0x12, 0x2f, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x61, 0x67, + 0x65, 0x6e, 0x74, 0x2e, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2e, 0x76, 0x31, 0x2e, 0x52, 0x65, + 0x73, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x52, 0x65, 0x71, 0x75, 0x65, + 0x73, 0x74, 0x1a, 0x17, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x74, + 0x79, 0x70, 0x65, 0x73, 0x2e, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x42, 0x4a, 0x5a, 0x48, 0x67, + 0x69, 0x74, 0x68, 0x75, 0x62, 0x2e, 0x63, 0x6f, 0x6d, 0x2f, 0x73, 0x70, 0x69, 0x66, 0x66, 0x65, + 0x2f, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2d, 0x61, 0x70, 0x69, 0x2d, 0x73, 0x64, 0x6b, 0x2f, 0x70, + 0x72, 0x6f, 0x74, 0x6f, 0x2f, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x61, + 0x67, 0x65, 0x6e, 0x74, 0x2f, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2f, 0x76, 0x31, 0x3b, 0x6c, + 0x6f, 0x67, 0x67, 0x65, 0x72, 0x76, 0x31, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33, +} + +var ( + file_spire_api_agent_logger_v1_logger_proto_rawDescOnce sync.Once + file_spire_api_agent_logger_v1_logger_proto_rawDescData = file_spire_api_agent_logger_v1_logger_proto_rawDesc +) + +func file_spire_api_agent_logger_v1_logger_proto_rawDescGZIP() []byte { + file_spire_api_agent_logger_v1_logger_proto_rawDescOnce.Do(func() { + file_spire_api_agent_logger_v1_logger_proto_rawDescData = protoimpl.X.CompressGZIP(file_spire_api_agent_logger_v1_logger_proto_rawDescData) + }) + return file_spire_api_agent_logger_v1_logger_proto_rawDescData +} + +var file_spire_api_agent_logger_v1_logger_proto_msgTypes = make([]protoimpl.MessageInfo, 3) +var file_spire_api_agent_logger_v1_logger_proto_goTypes = []interface{}{ + (*GetLoggerRequest)(nil), // 0: spire.api.agent.logger.v1.GetLoggerRequest + (*SetLogLevelRequest)(nil), // 1: spire.api.agent.logger.v1.SetLogLevelRequest + (*ResetLogLevelRequest)(nil), // 2: spire.api.agent.logger.v1.ResetLogLevelRequest + (types.LogLevel)(0), // 3: spire.api.types.LogLevel + (*types.Logger)(nil), // 4: spire.api.types.Logger +} +var file_spire_api_agent_logger_v1_logger_proto_depIdxs = []int32{ + 3, // 0: spire.api.agent.logger.v1.SetLogLevelRequest.new_level:type_name -> spire.api.types.LogLevel + 0, // 1: spire.api.agent.logger.v1.Logger.GetLogger:input_type -> spire.api.agent.logger.v1.GetLoggerRequest + 1, // 2: spire.api.agent.logger.v1.Logger.SetLogLevel:input_type -> spire.api.agent.logger.v1.SetLogLevelRequest + 2, // 3: spire.api.agent.logger.v1.Logger.ResetLogLevel:input_type -> spire.api.agent.logger.v1.ResetLogLevelRequest + 4, // 4: spire.api.agent.logger.v1.Logger.GetLogger:output_type -> spire.api.types.Logger + 4, // 5: spire.api.agent.logger.v1.Logger.SetLogLevel:output_type -> spire.api.types.Logger + 4, // 6: spire.api.agent.logger.v1.Logger.ResetLogLevel:output_type -> spire.api.types.Logger + 4, // [4:7] is the sub-list for method output_type + 1, // [1:4] is the sub-list for method input_type + 1, // [1:1] is the sub-list for extension type_name + 1, // [1:1] is the sub-list for extension extendee + 0, // [0:1] is the sub-list for field type_name +} + +func init() { file_spire_api_agent_logger_v1_logger_proto_init() } +func file_spire_api_agent_logger_v1_logger_proto_init() { + if File_spire_api_agent_logger_v1_logger_proto != nil { + return + } + if !protoimpl.UnsafeEnabled { + file_spire_api_agent_logger_v1_logger_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*GetLoggerRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_spire_api_agent_logger_v1_logger_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*SetLogLevelRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_spire_api_agent_logger_v1_logger_proto_msgTypes[2].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ResetLogLevelRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + } + type x struct{} + out := protoimpl.TypeBuilder{ + File: protoimpl.DescBuilder{ + GoPackagePath: reflect.TypeOf(x{}).PkgPath(), + RawDescriptor: file_spire_api_agent_logger_v1_logger_proto_rawDesc, + NumEnums: 0, + NumMessages: 3, + NumExtensions: 0, + NumServices: 1, + }, + GoTypes: file_spire_api_agent_logger_v1_logger_proto_goTypes, + DependencyIndexes: file_spire_api_agent_logger_v1_logger_proto_depIdxs, + MessageInfos: file_spire_api_agent_logger_v1_logger_proto_msgTypes, + }.Build() + File_spire_api_agent_logger_v1_logger_proto = out.File + file_spire_api_agent_logger_v1_logger_proto_rawDesc = nil + file_spire_api_agent_logger_v1_logger_proto_goTypes = nil + file_spire_api_agent_logger_v1_logger_proto_depIdxs = nil +} diff --git a/proto/spire/api/agent/logger/v1/logger.proto b/proto/spire/api/agent/logger/v1/logger.proto new file mode 100644 index 0000000..795aca1 --- /dev/null +++ b/proto/spire/api/agent/logger/v1/logger.proto @@ -0,0 +1,40 @@ +syntax = "proto3"; +package spire.api.agent.logger.v1; +option go_package = "github.com/spiffe/spire-api-sdk/proto/spire/api/agent/logger/v1;loggerv1"; + +import "spire/api/types/logger.proto"; + +service Logger { + + // Gets the logger level. + // + // This message is intended for the Agent Admin Socket. + rpc GetLogger(GetLoggerRequest) returns (spire.api.types.Logger); + + // Sets the logger to a specified log level. + // + // This message is intended for the Agent Admin Socket. + rpc SetLogLevel(SetLogLevelRequest) returns (spire.api.types.Logger); + + // Resets the logger level to the level configured at launch. + // + // This message is intended for the Agent Admin Socket. + rpc ResetLogLevel(ResetLogLevelRequest) returns (spire.api.types.Logger); + +} + +// Empty Get Logger Request message for future extension +message GetLoggerRequest { +} + +// Set Log Level Request message +message SetLogLevelRequest { + + // The new level the logger should assume + spire.api.types.LogLevel new_level = 1; +} + +// Empty Reset Log Level Request message for future extension +message ResetLogLevelRequest { +} + diff --git a/proto/spire/api/agent/logger/v1/logger_grpc.pb.go b/proto/spire/api/agent/logger/v1/logger_grpc.pb.go new file mode 100644 index 0000000..5c22538 --- /dev/null +++ b/proto/spire/api/agent/logger/v1/logger_grpc.pb.go @@ -0,0 +1,188 @@ +// Code generated by protoc-gen-go-grpc. DO NOT EDIT. + +package loggerv1 + +import ( + context "context" + types "github.com/spiffe/spire-api-sdk/proto/spire/api/types" + grpc "google.golang.org/grpc" + codes "google.golang.org/grpc/codes" + status "google.golang.org/grpc/status" +) + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the grpc package it is being compiled against. +const _ = grpc.SupportPackageIsVersion7 + +// LoggerClient is the client API for Logger service. +// +// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://pkg.go.dev/google.golang.org/grpc/?tab=doc#ClientConn.NewStream. +type LoggerClient interface { + // Gets the logger level. + // + // This message is intended for the Agent Admin Socket. + GetLogger(ctx context.Context, in *GetLoggerRequest, opts ...grpc.CallOption) (*types.Logger, error) + // Sets the logger to a specified log level. + // + // This message is intended for the Agent Admin Socket. + SetLogLevel(ctx context.Context, in *SetLogLevelRequest, opts ...grpc.CallOption) (*types.Logger, error) + // Resets the logger level to the level configured at launch. + // + // This message is intended for the Agent Admin Socket. + ResetLogLevel(ctx context.Context, in *ResetLogLevelRequest, opts ...grpc.CallOption) (*types.Logger, error) +} + +type loggerClient struct { + cc grpc.ClientConnInterface +} + +func NewLoggerClient(cc grpc.ClientConnInterface) LoggerClient { + return &loggerClient{cc} +} + +func (c *loggerClient) GetLogger(ctx context.Context, in *GetLoggerRequest, opts ...grpc.CallOption) (*types.Logger, error) { + out := new(types.Logger) + err := c.cc.Invoke(ctx, "/spire.api.agent.logger.v1.Logger/GetLogger", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *loggerClient) SetLogLevel(ctx context.Context, in *SetLogLevelRequest, opts ...grpc.CallOption) (*types.Logger, error) { + out := new(types.Logger) + err := c.cc.Invoke(ctx, "/spire.api.agent.logger.v1.Logger/SetLogLevel", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *loggerClient) ResetLogLevel(ctx context.Context, in *ResetLogLevelRequest, opts ...grpc.CallOption) (*types.Logger, error) { + out := new(types.Logger) + err := c.cc.Invoke(ctx, "/spire.api.agent.logger.v1.Logger/ResetLogLevel", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +// LoggerServer is the server API for Logger service. +// All implementations must embed UnimplementedLoggerServer +// for forward compatibility +type LoggerServer interface { + // Gets the logger level. + // + // This message is intended for the Agent Admin Socket. + GetLogger(context.Context, *GetLoggerRequest) (*types.Logger, error) + // Sets the logger to a specified log level. + // + // This message is intended for the Agent Admin Socket. + SetLogLevel(context.Context, *SetLogLevelRequest) (*types.Logger, error) + // Resets the logger level to the level configured at launch. + // + // This message is intended for the Agent Admin Socket. + ResetLogLevel(context.Context, *ResetLogLevelRequest) (*types.Logger, error) + mustEmbedUnimplementedLoggerServer() +} + +// UnimplementedLoggerServer must be embedded to have forward compatible implementations. +type UnimplementedLoggerServer struct { +} + +func (UnimplementedLoggerServer) GetLogger(context.Context, *GetLoggerRequest) (*types.Logger, error) { + return nil, status.Errorf(codes.Unimplemented, "method GetLogger not implemented") +} +func (UnimplementedLoggerServer) SetLogLevel(context.Context, *SetLogLevelRequest) (*types.Logger, error) { + return nil, status.Errorf(codes.Unimplemented, "method SetLogLevel not implemented") +} +func (UnimplementedLoggerServer) ResetLogLevel(context.Context, *ResetLogLevelRequest) (*types.Logger, error) { + return nil, status.Errorf(codes.Unimplemented, "method ResetLogLevel not implemented") +} +func (UnimplementedLoggerServer) mustEmbedUnimplementedLoggerServer() {} + +// UnsafeLoggerServer may be embedded to opt out of forward compatibility for this service. +// Use of this interface is not recommended, as added methods to LoggerServer will +// result in compilation errors. +type UnsafeLoggerServer interface { + mustEmbedUnimplementedLoggerServer() +} + +func RegisterLoggerServer(s grpc.ServiceRegistrar, srv LoggerServer) { + s.RegisterService(&_Logger_serviceDesc, srv) +} + +func _Logger_GetLogger_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(GetLoggerRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(LoggerServer).GetLogger(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/spire.api.agent.logger.v1.Logger/GetLogger", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(LoggerServer).GetLogger(ctx, req.(*GetLoggerRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _Logger_SetLogLevel_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(SetLogLevelRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(LoggerServer).SetLogLevel(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/spire.api.agent.logger.v1.Logger/SetLogLevel", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(LoggerServer).SetLogLevel(ctx, req.(*SetLogLevelRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _Logger_ResetLogLevel_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(ResetLogLevelRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(LoggerServer).ResetLogLevel(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/spire.api.agent.logger.v1.Logger/ResetLogLevel", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(LoggerServer).ResetLogLevel(ctx, req.(*ResetLogLevelRequest)) + } + return interceptor(ctx, in, info, handler) +} + +var _Logger_serviceDesc = grpc.ServiceDesc{ + ServiceName: "spire.api.agent.logger.v1.Logger", + HandlerType: (*LoggerServer)(nil), + Methods: []grpc.MethodDesc{ + { + MethodName: "GetLogger", + Handler: _Logger_GetLogger_Handler, + }, + { + MethodName: "SetLogLevel", + Handler: _Logger_SetLogLevel_Handler, + }, + { + MethodName: "ResetLogLevel", + Handler: _Logger_ResetLogLevel_Handler, + }, + }, + Streams: []grpc.StreamDesc{}, + Metadata: "spire/api/agent/logger/v1/logger.proto", +} diff --git a/proto/spire/api/server/logger/v1/logger.pb.go b/proto/spire/api/server/logger/v1/logger.pb.go new file mode 100644 index 0000000..2955cce --- /dev/null +++ b/proto/spire/api/server/logger/v1/logger.pb.go @@ -0,0 +1,289 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// versions: +// protoc-gen-go v1.28.0 +// protoc v3.20.1 +// source: spire/api/server/logger/v1/logger.proto + +package loggerv1 + +import ( + types "github.com/spiffe/spire-api-sdk/proto/spire/api/types" + protoreflect "google.golang.org/protobuf/reflect/protoreflect" + protoimpl "google.golang.org/protobuf/runtime/protoimpl" + reflect "reflect" + sync "sync" +) + +const ( + // Verify that this generated code is sufficiently up-to-date. + _ = protoimpl.EnforceVersion(20 - protoimpl.MinVersion) + // Verify that runtime/protoimpl is sufficiently up-to-date. + _ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20) +) + +// Empty Get Logger Request message for future extension +type GetLoggerRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields +} + +func (x *GetLoggerRequest) Reset() { + *x = GetLoggerRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_spire_api_server_logger_v1_logger_proto_msgTypes[0] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *GetLoggerRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*GetLoggerRequest) ProtoMessage() {} + +func (x *GetLoggerRequest) ProtoReflect() protoreflect.Message { + mi := &file_spire_api_server_logger_v1_logger_proto_msgTypes[0] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use GetLoggerRequest.ProtoReflect.Descriptor instead. +func (*GetLoggerRequest) Descriptor() ([]byte, []int) { + return file_spire_api_server_logger_v1_logger_proto_rawDescGZIP(), []int{0} +} + +// Set Log Level Request message +type SetLogLevelRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + // The new level the logger should assume + NewLevel types.LogLevel `protobuf:"varint,1,opt,name=new_level,json=newLevel,proto3,enum=spire.api.types.LogLevel" json:"new_level,omitempty"` +} + +func (x *SetLogLevelRequest) Reset() { + *x = SetLogLevelRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_spire_api_server_logger_v1_logger_proto_msgTypes[1] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *SetLogLevelRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*SetLogLevelRequest) ProtoMessage() {} + +func (x *SetLogLevelRequest) ProtoReflect() protoreflect.Message { + mi := &file_spire_api_server_logger_v1_logger_proto_msgTypes[1] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use SetLogLevelRequest.ProtoReflect.Descriptor instead. +func (*SetLogLevelRequest) Descriptor() ([]byte, []int) { + return file_spire_api_server_logger_v1_logger_proto_rawDescGZIP(), []int{1} +} + +func (x *SetLogLevelRequest) GetNewLevel() types.LogLevel { + if x != nil { + return x.NewLevel + } + return types.LogLevel(0) +} + +// Empty Reset Log Level Request message for future extension +type ResetLogLevelRequest struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields +} + +func (x *ResetLogLevelRequest) Reset() { + *x = ResetLogLevelRequest{} + if protoimpl.UnsafeEnabled { + mi := &file_spire_api_server_logger_v1_logger_proto_msgTypes[2] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *ResetLogLevelRequest) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*ResetLogLevelRequest) ProtoMessage() {} + +func (x *ResetLogLevelRequest) ProtoReflect() protoreflect.Message { + mi := &file_spire_api_server_logger_v1_logger_proto_msgTypes[2] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use ResetLogLevelRequest.ProtoReflect.Descriptor instead. +func (*ResetLogLevelRequest) Descriptor() ([]byte, []int) { + return file_spire_api_server_logger_v1_logger_proto_rawDescGZIP(), []int{2} +} + +var File_spire_api_server_logger_v1_logger_proto protoreflect.FileDescriptor + +var file_spire_api_server_logger_v1_logger_proto_rawDesc = []byte{ + 0x0a, 0x27, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x73, 0x65, 0x72, 0x76, + 0x65, 0x72, 0x2f, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2f, 0x76, 0x31, 0x2f, 0x6c, 0x6f, 0x67, + 0x67, 0x65, 0x72, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x12, 0x1a, 0x73, 0x70, 0x69, 0x72, 0x65, + 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x73, 0x65, 0x72, 0x76, 0x65, 0x72, 0x2e, 0x6c, 0x6f, 0x67, 0x67, + 0x65, 0x72, 0x2e, 0x76, 0x31, 0x1a, 0x1c, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2f, 0x61, 0x70, 0x69, + 0x2f, 0x74, 0x79, 0x70, 0x65, 0x73, 0x2f, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2e, 0x70, 0x72, + 0x6f, 0x74, 0x6f, 0x22, 0x12, 0x0a, 0x10, 0x47, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, + 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x22, 0x4c, 0x0a, 0x12, 0x53, 0x65, 0x74, 0x4c, 0x6f, + 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x12, 0x36, 0x0a, + 0x09, 0x6e, 0x65, 0x77, 0x5f, 0x6c, 0x65, 0x76, 0x65, 0x6c, 0x18, 0x01, 0x20, 0x01, 0x28, 0x0e, + 0x32, 0x19, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x74, 0x79, 0x70, + 0x65, 0x73, 0x2e, 0x4c, 0x6f, 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x52, 0x08, 0x6e, 0x65, 0x77, + 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x22, 0x16, 0x0a, 0x14, 0x52, 0x65, 0x73, 0x65, 0x74, 0x4c, 0x6f, + 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x32, 0x90, 0x02, + 0x0a, 0x06, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x12, 0x52, 0x0a, 0x09, 0x47, 0x65, 0x74, 0x4c, + 0x6f, 0x67, 0x67, 0x65, 0x72, 0x12, 0x2c, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, + 0x69, 0x2e, 0x73, 0x65, 0x72, 0x76, 0x65, 0x72, 0x2e, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2e, + 0x76, 0x31, 0x2e, 0x47, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x52, 0x65, 0x71, 0x75, + 0x65, 0x73, 0x74, 0x1a, 0x17, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, + 0x74, 0x79, 0x70, 0x65, 0x73, 0x2e, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x12, 0x56, 0x0a, 0x0b, + 0x53, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x12, 0x2e, 0x2e, 0x73, 0x70, + 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x73, 0x65, 0x72, 0x76, 0x65, 0x72, 0x2e, 0x6c, + 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2e, 0x76, 0x31, 0x2e, 0x53, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x4c, + 0x65, 0x76, 0x65, 0x6c, 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x17, 0x2e, 0x73, 0x70, + 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x74, 0x79, 0x70, 0x65, 0x73, 0x2e, 0x4c, 0x6f, + 0x67, 0x67, 0x65, 0x72, 0x12, 0x5a, 0x0a, 0x0d, 0x52, 0x65, 0x73, 0x65, 0x74, 0x4c, 0x6f, 0x67, + 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x12, 0x30, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, + 0x69, 0x2e, 0x73, 0x65, 0x72, 0x76, 0x65, 0x72, 0x2e, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2e, + 0x76, 0x31, 0x2e, 0x52, 0x65, 0x73, 0x65, 0x74, 0x4c, 0x6f, 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, + 0x52, 0x65, 0x71, 0x75, 0x65, 0x73, 0x74, 0x1a, 0x17, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, + 0x61, 0x70, 0x69, 0x2e, 0x74, 0x79, 0x70, 0x65, 0x73, 0x2e, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, + 0x42, 0x4b, 0x5a, 0x49, 0x67, 0x69, 0x74, 0x68, 0x75, 0x62, 0x2e, 0x63, 0x6f, 0x6d, 0x2f, 0x73, + 0x70, 0x69, 0x66, 0x66, 0x65, 0x2f, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2d, 0x61, 0x70, 0x69, 0x2d, + 0x73, 0x64, 0x6b, 0x2f, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2f, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2f, + 0x61, 0x70, 0x69, 0x2f, 0x73, 0x65, 0x72, 0x76, 0x65, 0x72, 0x2f, 0x6c, 0x6f, 0x67, 0x67, 0x65, + 0x72, 0x2f, 0x76, 0x31, 0x3b, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x76, 0x31, 0x62, 0x06, 0x70, + 0x72, 0x6f, 0x74, 0x6f, 0x33, +} + +var ( + file_spire_api_server_logger_v1_logger_proto_rawDescOnce sync.Once + file_spire_api_server_logger_v1_logger_proto_rawDescData = file_spire_api_server_logger_v1_logger_proto_rawDesc +) + +func file_spire_api_server_logger_v1_logger_proto_rawDescGZIP() []byte { + file_spire_api_server_logger_v1_logger_proto_rawDescOnce.Do(func() { + file_spire_api_server_logger_v1_logger_proto_rawDescData = protoimpl.X.CompressGZIP(file_spire_api_server_logger_v1_logger_proto_rawDescData) + }) + return file_spire_api_server_logger_v1_logger_proto_rawDescData +} + +var file_spire_api_server_logger_v1_logger_proto_msgTypes = make([]protoimpl.MessageInfo, 3) +var file_spire_api_server_logger_v1_logger_proto_goTypes = []interface{}{ + (*GetLoggerRequest)(nil), // 0: spire.api.server.logger.v1.GetLoggerRequest + (*SetLogLevelRequest)(nil), // 1: spire.api.server.logger.v1.SetLogLevelRequest + (*ResetLogLevelRequest)(nil), // 2: spire.api.server.logger.v1.ResetLogLevelRequest + (types.LogLevel)(0), // 3: spire.api.types.LogLevel + (*types.Logger)(nil), // 4: spire.api.types.Logger +} +var file_spire_api_server_logger_v1_logger_proto_depIdxs = []int32{ + 3, // 0: spire.api.server.logger.v1.SetLogLevelRequest.new_level:type_name -> spire.api.types.LogLevel + 0, // 1: spire.api.server.logger.v1.Logger.GetLogger:input_type -> spire.api.server.logger.v1.GetLoggerRequest + 1, // 2: spire.api.server.logger.v1.Logger.SetLogLevel:input_type -> spire.api.server.logger.v1.SetLogLevelRequest + 2, // 3: spire.api.server.logger.v1.Logger.ResetLogLevel:input_type -> spire.api.server.logger.v1.ResetLogLevelRequest + 4, // 4: spire.api.server.logger.v1.Logger.GetLogger:output_type -> spire.api.types.Logger + 4, // 5: spire.api.server.logger.v1.Logger.SetLogLevel:output_type -> spire.api.types.Logger + 4, // 6: spire.api.server.logger.v1.Logger.ResetLogLevel:output_type -> spire.api.types.Logger + 4, // [4:7] is the sub-list for method output_type + 1, // [1:4] is the sub-list for method input_type + 1, // [1:1] is the sub-list for extension type_name + 1, // [1:1] is the sub-list for extension extendee + 0, // [0:1] is the sub-list for field type_name +} + +func init() { file_spire_api_server_logger_v1_logger_proto_init() } +func file_spire_api_server_logger_v1_logger_proto_init() { + if File_spire_api_server_logger_v1_logger_proto != nil { + return + } + if !protoimpl.UnsafeEnabled { + file_spire_api_server_logger_v1_logger_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*GetLoggerRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_spire_api_server_logger_v1_logger_proto_msgTypes[1].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*SetLogLevelRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + file_spire_api_server_logger_v1_logger_proto_msgTypes[2].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*ResetLogLevelRequest); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + } + type x struct{} + out := protoimpl.TypeBuilder{ + File: protoimpl.DescBuilder{ + GoPackagePath: reflect.TypeOf(x{}).PkgPath(), + RawDescriptor: file_spire_api_server_logger_v1_logger_proto_rawDesc, + NumEnums: 0, + NumMessages: 3, + NumExtensions: 0, + NumServices: 1, + }, + GoTypes: file_spire_api_server_logger_v1_logger_proto_goTypes, + DependencyIndexes: file_spire_api_server_logger_v1_logger_proto_depIdxs, + MessageInfos: file_spire_api_server_logger_v1_logger_proto_msgTypes, + }.Build() + File_spire_api_server_logger_v1_logger_proto = out.File + file_spire_api_server_logger_v1_logger_proto_rawDesc = nil + file_spire_api_server_logger_v1_logger_proto_goTypes = nil + file_spire_api_server_logger_v1_logger_proto_depIdxs = nil +} diff --git a/proto/spire/api/server/logger/v1/logger.proto b/proto/spire/api/server/logger/v1/logger.proto new file mode 100644 index 0000000..2909221 --- /dev/null +++ b/proto/spire/api/server/logger/v1/logger.proto @@ -0,0 +1,40 @@ +syntax = "proto3"; +package spire.api.server.logger.v1; +option go_package = "github.com/spiffe/spire-api-sdk/proto/spire/api/server/logger/v1;loggerv1"; + +import "spire/api/types/logger.proto"; + +service Logger { + + // Gets the logger level. + // + // The caller must be local or present an admin X509-SVID. + rpc GetLogger(GetLoggerRequest) returns (spire.api.types.Logger); + + // Sets the logger to a specified log level. + // + // The caller must be local or present an admin X509-SVID. + rpc SetLogLevel(SetLogLevelRequest) returns (spire.api.types.Logger); + + // Resets the logger level to the level configured at launch. + // + // The caller must be local or present an admin X509-SVID. + rpc ResetLogLevel(ResetLogLevelRequest) returns (spire.api.types.Logger); + +} + +// Empty Get Logger Request message for future extension +message GetLoggerRequest { +} + +// Set Log Level Request message +message SetLogLevelRequest { + + // The new level the logger should assume + spire.api.types.LogLevel new_level = 1; + +} + +// Empty Reset Log Level Request message for future extension +message ResetLogLevelRequest { +} diff --git a/proto/spire/api/server/logger/v1/logger_grpc.pb.go b/proto/spire/api/server/logger/v1/logger_grpc.pb.go new file mode 100644 index 0000000..9869e4a --- /dev/null +++ b/proto/spire/api/server/logger/v1/logger_grpc.pb.go @@ -0,0 +1,188 @@ +// Code generated by protoc-gen-go-grpc. DO NOT EDIT. + +package loggerv1 + +import ( + context "context" + types "github.com/spiffe/spire-api-sdk/proto/spire/api/types" + grpc "google.golang.org/grpc" + codes "google.golang.org/grpc/codes" + status "google.golang.org/grpc/status" +) + +// This is a compile-time assertion to ensure that this generated file +// is compatible with the grpc package it is being compiled against. +const _ = grpc.SupportPackageIsVersion7 + +// LoggerClient is the client API for Logger service. +// +// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://pkg.go.dev/google.golang.org/grpc/?tab=doc#ClientConn.NewStream. +type LoggerClient interface { + // Gets the logger level. + // + // The caller must be local or present an admin X509-SVID. + GetLogger(ctx context.Context, in *GetLoggerRequest, opts ...grpc.CallOption) (*types.Logger, error) + // Sets the logger to a specified log level. + // + // The caller must be local or present an admin X509-SVID. + SetLogLevel(ctx context.Context, in *SetLogLevelRequest, opts ...grpc.CallOption) (*types.Logger, error) + // Resets the logger level to the level configured at launch. + // + // The caller must be local or present an admin X509-SVID. + ResetLogLevel(ctx context.Context, in *ResetLogLevelRequest, opts ...grpc.CallOption) (*types.Logger, error) +} + +type loggerClient struct { + cc grpc.ClientConnInterface +} + +func NewLoggerClient(cc grpc.ClientConnInterface) LoggerClient { + return &loggerClient{cc} +} + +func (c *loggerClient) GetLogger(ctx context.Context, in *GetLoggerRequest, opts ...grpc.CallOption) (*types.Logger, error) { + out := new(types.Logger) + err := c.cc.Invoke(ctx, "/spire.api.server.logger.v1.Logger/GetLogger", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *loggerClient) SetLogLevel(ctx context.Context, in *SetLogLevelRequest, opts ...grpc.CallOption) (*types.Logger, error) { + out := new(types.Logger) + err := c.cc.Invoke(ctx, "/spire.api.server.logger.v1.Logger/SetLogLevel", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +func (c *loggerClient) ResetLogLevel(ctx context.Context, in *ResetLogLevelRequest, opts ...grpc.CallOption) (*types.Logger, error) { + out := new(types.Logger) + err := c.cc.Invoke(ctx, "/spire.api.server.logger.v1.Logger/ResetLogLevel", in, out, opts...) + if err != nil { + return nil, err + } + return out, nil +} + +// LoggerServer is the server API for Logger service. +// All implementations must embed UnimplementedLoggerServer +// for forward compatibility +type LoggerServer interface { + // Gets the logger level. + // + // The caller must be local or present an admin X509-SVID. + GetLogger(context.Context, *GetLoggerRequest) (*types.Logger, error) + // Sets the logger to a specified log level. + // + // The caller must be local or present an admin X509-SVID. + SetLogLevel(context.Context, *SetLogLevelRequest) (*types.Logger, error) + // Resets the logger level to the level configured at launch. + // + // The caller must be local or present an admin X509-SVID. + ResetLogLevel(context.Context, *ResetLogLevelRequest) (*types.Logger, error) + mustEmbedUnimplementedLoggerServer() +} + +// UnimplementedLoggerServer must be embedded to have forward compatible implementations. +type UnimplementedLoggerServer struct { +} + +func (UnimplementedLoggerServer) GetLogger(context.Context, *GetLoggerRequest) (*types.Logger, error) { + return nil, status.Errorf(codes.Unimplemented, "method GetLogger not implemented") +} +func (UnimplementedLoggerServer) SetLogLevel(context.Context, *SetLogLevelRequest) (*types.Logger, error) { + return nil, status.Errorf(codes.Unimplemented, "method SetLogLevel not implemented") +} +func (UnimplementedLoggerServer) ResetLogLevel(context.Context, *ResetLogLevelRequest) (*types.Logger, error) { + return nil, status.Errorf(codes.Unimplemented, "method ResetLogLevel not implemented") +} +func (UnimplementedLoggerServer) mustEmbedUnimplementedLoggerServer() {} + +// UnsafeLoggerServer may be embedded to opt out of forward compatibility for this service. +// Use of this interface is not recommended, as added methods to LoggerServer will +// result in compilation errors. +type UnsafeLoggerServer interface { + mustEmbedUnimplementedLoggerServer() +} + +func RegisterLoggerServer(s grpc.ServiceRegistrar, srv LoggerServer) { + s.RegisterService(&_Logger_serviceDesc, srv) +} + +func _Logger_GetLogger_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(GetLoggerRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(LoggerServer).GetLogger(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/spire.api.server.logger.v1.Logger/GetLogger", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(LoggerServer).GetLogger(ctx, req.(*GetLoggerRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _Logger_SetLogLevel_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(SetLogLevelRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(LoggerServer).SetLogLevel(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/spire.api.server.logger.v1.Logger/SetLogLevel", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(LoggerServer).SetLogLevel(ctx, req.(*SetLogLevelRequest)) + } + return interceptor(ctx, in, info, handler) +} + +func _Logger_ResetLogLevel_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) { + in := new(ResetLogLevelRequest) + if err := dec(in); err != nil { + return nil, err + } + if interceptor == nil { + return srv.(LoggerServer).ResetLogLevel(ctx, in) + } + info := &grpc.UnaryServerInfo{ + Server: srv, + FullMethod: "/spire.api.server.logger.v1.Logger/ResetLogLevel", + } + handler := func(ctx context.Context, req interface{}) (interface{}, error) { + return srv.(LoggerServer).ResetLogLevel(ctx, req.(*ResetLogLevelRequest)) + } + return interceptor(ctx, in, info, handler) +} + +var _Logger_serviceDesc = grpc.ServiceDesc{ + ServiceName: "spire.api.server.logger.v1.Logger", + HandlerType: (*LoggerServer)(nil), + Methods: []grpc.MethodDesc{ + { + MethodName: "GetLogger", + Handler: _Logger_GetLogger_Handler, + }, + { + MethodName: "SetLogLevel", + Handler: _Logger_SetLogLevel_Handler, + }, + { + MethodName: "ResetLogLevel", + Handler: _Logger_ResetLogLevel_Handler, + }, + }, + Streams: []grpc.StreamDesc{}, + Metadata: "spire/api/server/logger/v1/logger.proto", +} diff --git a/proto/spire/api/types/logger.pb.go b/proto/spire/api/types/logger.pb.go new file mode 100644 index 0000000..ed0ac95 --- /dev/null +++ b/proto/spire/api/types/logger.pb.go @@ -0,0 +1,243 @@ +// Code generated by protoc-gen-go. DO NOT EDIT. +// versions: +// protoc-gen-go v1.28.0 +// protoc v3.20.1 +// source: spire/api/types/logger.proto + +package types + +import ( + protoreflect "google.golang.org/protobuf/reflect/protoreflect" + protoimpl "google.golang.org/protobuf/runtime/protoimpl" + _ "google.golang.org/protobuf/types/known/wrapperspb" + reflect "reflect" + sync "sync" +) + +const ( + // Verify that this generated code is sufficiently up-to-date. + _ = protoimpl.EnforceVersion(20 - protoimpl.MinVersion) + // Verify that runtime/protoimpl is sufficiently up-to-date. + _ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20) +) + +// The logger log levels. +type LogLevel int32 + +const ( + LogLevel_UNSPECIFIED LogLevel = 0 + LogLevel_PANIC LogLevel = 1 + LogLevel_FATAL LogLevel = 2 + LogLevel_ERROR LogLevel = 3 + LogLevel_WARN LogLevel = 4 + LogLevel_INFO LogLevel = 5 + LogLevel_DEBUG LogLevel = 6 + LogLevel_TRACE LogLevel = 7 +) + +// Enum value maps for LogLevel. +var ( + LogLevel_name = map[int32]string{ + 0: "UNSPECIFIED", + 1: "PANIC", + 2: "FATAL", + 3: "ERROR", + 4: "WARN", + 5: "INFO", + 6: "DEBUG", + 7: "TRACE", + } + LogLevel_value = map[string]int32{ + "UNSPECIFIED": 0, + "PANIC": 1, + "FATAL": 2, + "ERROR": 3, + "WARN": 4, + "INFO": 5, + "DEBUG": 6, + "TRACE": 7, + } +) + +func (x LogLevel) Enum() *LogLevel { + p := new(LogLevel) + *p = x + return p +} + +func (x LogLevel) String() string { + return protoimpl.X.EnumStringOf(x.Descriptor(), protoreflect.EnumNumber(x)) +} + +func (LogLevel) Descriptor() protoreflect.EnumDescriptor { + return file_spire_api_types_logger_proto_enumTypes[0].Descriptor() +} + +func (LogLevel) Type() protoreflect.EnumType { + return &file_spire_api_types_logger_proto_enumTypes[0] +} + +func (x LogLevel) Number() protoreflect.EnumNumber { + return protoreflect.EnumNumber(x) +} + +// Deprecated: Use LogLevel.Descriptor instead. +func (LogLevel) EnumDescriptor() ([]byte, []int) { + return file_spire_api_types_logger_proto_rawDescGZIP(), []int{0} +} + +// Represents the current Logger settings. +type Logger struct { + state protoimpl.MessageState + sizeCache protoimpl.SizeCache + unknownFields protoimpl.UnknownFields + + // Output only. The logger's current log level. + CurrentLevel LogLevel `protobuf:"varint,1,opt,name=current_level,json=currentLevel,proto3,enum=spire.api.types.LogLevel" json:"current_level,omitempty"` + // Output only. The logger's log level at process launch. + LaunchLevel LogLevel `protobuf:"varint,2,opt,name=launch_level,json=launchLevel,proto3,enum=spire.api.types.LogLevel" json:"launch_level,omitempty"` +} + +func (x *Logger) Reset() { + *x = Logger{} + if protoimpl.UnsafeEnabled { + mi := &file_spire_api_types_logger_proto_msgTypes[0] + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + ms.StoreMessageInfo(mi) + } +} + +func (x *Logger) String() string { + return protoimpl.X.MessageStringOf(x) +} + +func (*Logger) ProtoMessage() {} + +func (x *Logger) ProtoReflect() protoreflect.Message { + mi := &file_spire_api_types_logger_proto_msgTypes[0] + if protoimpl.UnsafeEnabled && x != nil { + ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x)) + if ms.LoadMessageInfo() == nil { + ms.StoreMessageInfo(mi) + } + return ms + } + return mi.MessageOf(x) +} + +// Deprecated: Use Logger.ProtoReflect.Descriptor instead. +func (*Logger) Descriptor() ([]byte, []int) { + return file_spire_api_types_logger_proto_rawDescGZIP(), []int{0} +} + +func (x *Logger) GetCurrentLevel() LogLevel { + if x != nil { + return x.CurrentLevel + } + return LogLevel_UNSPECIFIED +} + +func (x *Logger) GetLaunchLevel() LogLevel { + if x != nil { + return x.LaunchLevel + } + return LogLevel_UNSPECIFIED +} + +var File_spire_api_types_logger_proto protoreflect.FileDescriptor + +var file_spire_api_types_logger_proto_rawDesc = []byte{ + 0x0a, 0x1c, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2f, 0x61, 0x70, 0x69, 0x2f, 0x74, 0x79, 0x70, 0x65, + 0x73, 0x2f, 0x6c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x12, 0x0f, + 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x74, 0x79, 0x70, 0x65, 0x73, 0x1a, + 0x1e, 0x67, 0x6f, 0x6f, 0x67, 0x6c, 0x65, 0x2f, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, + 0x2f, 0x77, 0x72, 0x61, 0x70, 0x70, 0x65, 0x72, 0x73, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x22, + 0x86, 0x01, 0x0a, 0x06, 0x4c, 0x6f, 0x67, 0x67, 0x65, 0x72, 0x12, 0x3e, 0x0a, 0x0d, 0x63, 0x75, + 0x72, 0x72, 0x65, 0x6e, 0x74, 0x5f, 0x6c, 0x65, 0x76, 0x65, 0x6c, 0x18, 0x01, 0x20, 0x01, 0x28, + 0x0e, 0x32, 0x19, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x74, 0x79, + 0x70, 0x65, 0x73, 0x2e, 0x4c, 0x6f, 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x52, 0x0c, 0x63, 0x75, + 0x72, 0x72, 0x65, 0x6e, 0x74, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x12, 0x3c, 0x0a, 0x0c, 0x6c, 0x61, + 0x75, 0x6e, 0x63, 0x68, 0x5f, 0x6c, 0x65, 0x76, 0x65, 0x6c, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0e, + 0x32, 0x19, 0x2e, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2e, 0x61, 0x70, 0x69, 0x2e, 0x74, 0x79, 0x70, + 0x65, 0x73, 0x2e, 0x4c, 0x6f, 0x67, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x52, 0x0b, 0x6c, 0x61, 0x75, + 0x6e, 0x63, 0x68, 0x4c, 0x65, 0x76, 0x65, 0x6c, 0x2a, 0x66, 0x0a, 0x08, 0x4c, 0x6f, 0x67, 0x4c, + 0x65, 0x76, 0x65, 0x6c, 0x12, 0x0f, 0x0a, 0x0b, 0x55, 0x4e, 0x53, 0x50, 0x45, 0x43, 0x49, 0x46, + 0x49, 0x45, 0x44, 0x10, 0x00, 0x12, 0x09, 0x0a, 0x05, 0x50, 0x41, 0x4e, 0x49, 0x43, 0x10, 0x01, + 0x12, 0x09, 0x0a, 0x05, 0x46, 0x41, 0x54, 0x41, 0x4c, 0x10, 0x02, 0x12, 0x09, 0x0a, 0x05, 0x45, + 0x52, 0x52, 0x4f, 0x52, 0x10, 0x03, 0x12, 0x08, 0x0a, 0x04, 0x57, 0x41, 0x52, 0x4e, 0x10, 0x04, + 0x12, 0x08, 0x0a, 0x04, 0x49, 0x4e, 0x46, 0x4f, 0x10, 0x05, 0x12, 0x09, 0x0a, 0x05, 0x44, 0x45, + 0x42, 0x55, 0x47, 0x10, 0x06, 0x12, 0x09, 0x0a, 0x05, 0x54, 0x52, 0x41, 0x43, 0x45, 0x10, 0x07, + 0x42, 0x37, 0x5a, 0x35, 0x67, 0x69, 0x74, 0x68, 0x75, 0x62, 0x2e, 0x63, 0x6f, 0x6d, 0x2f, 0x73, + 0x70, 0x69, 0x66, 0x66, 0x65, 0x2f, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2d, 0x61, 0x70, 0x69, 0x2d, + 0x73, 0x64, 0x6b, 0x2f, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x2f, 0x73, 0x70, 0x69, 0x72, 0x65, 0x2f, + 0x61, 0x70, 0x69, 0x2f, 0x74, 0x79, 0x70, 0x65, 0x73, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, + 0x33, +} + +var ( + file_spire_api_types_logger_proto_rawDescOnce sync.Once + file_spire_api_types_logger_proto_rawDescData = file_spire_api_types_logger_proto_rawDesc +) + +func file_spire_api_types_logger_proto_rawDescGZIP() []byte { + file_spire_api_types_logger_proto_rawDescOnce.Do(func() { + file_spire_api_types_logger_proto_rawDescData = protoimpl.X.CompressGZIP(file_spire_api_types_logger_proto_rawDescData) + }) + return file_spire_api_types_logger_proto_rawDescData +} + +var file_spire_api_types_logger_proto_enumTypes = make([]protoimpl.EnumInfo, 1) +var file_spire_api_types_logger_proto_msgTypes = make([]protoimpl.MessageInfo, 1) +var file_spire_api_types_logger_proto_goTypes = []interface{}{ + (LogLevel)(0), // 0: spire.api.types.LogLevel + (*Logger)(nil), // 1: spire.api.types.Logger +} +var file_spire_api_types_logger_proto_depIdxs = []int32{ + 0, // 0: spire.api.types.Logger.current_level:type_name -> spire.api.types.LogLevel + 0, // 1: spire.api.types.Logger.launch_level:type_name -> spire.api.types.LogLevel + 2, // [2:2] is the sub-list for method output_type + 2, // [2:2] is the sub-list for method input_type + 2, // [2:2] is the sub-list for extension type_name + 2, // [2:2] is the sub-list for extension extendee + 0, // [0:2] is the sub-list for field type_name +} + +func init() { file_spire_api_types_logger_proto_init() } +func file_spire_api_types_logger_proto_init() { + if File_spire_api_types_logger_proto != nil { + return + } + if !protoimpl.UnsafeEnabled { + file_spire_api_types_logger_proto_msgTypes[0].Exporter = func(v interface{}, i int) interface{} { + switch v := v.(*Logger); i { + case 0: + return &v.state + case 1: + return &v.sizeCache + case 2: + return &v.unknownFields + default: + return nil + } + } + } + type x struct{} + out := protoimpl.TypeBuilder{ + File: protoimpl.DescBuilder{ + GoPackagePath: reflect.TypeOf(x{}).PkgPath(), + RawDescriptor: file_spire_api_types_logger_proto_rawDesc, + NumEnums: 1, + NumMessages: 1, + NumExtensions: 0, + NumServices: 0, + }, + GoTypes: file_spire_api_types_logger_proto_goTypes, + DependencyIndexes: file_spire_api_types_logger_proto_depIdxs, + EnumInfos: file_spire_api_types_logger_proto_enumTypes, + MessageInfos: file_spire_api_types_logger_proto_msgTypes, + }.Build() + File_spire_api_types_logger_proto = out.File + file_spire_api_types_logger_proto_rawDesc = nil + file_spire_api_types_logger_proto_goTypes = nil + file_spire_api_types_logger_proto_depIdxs = nil +} diff --git a/proto/spire/api/types/logger.proto b/proto/spire/api/types/logger.proto new file mode 100644 index 0000000..442941f --- /dev/null +++ b/proto/spire/api/types/logger.proto @@ -0,0 +1,27 @@ +syntax = "proto3"; +package spire.api.types; +option go_package = "github.com/spiffe/spire-api-sdk/proto/spire/api/types"; + +import "google/protobuf/wrappers.proto"; + +// The logger log levels. +enum LogLevel { + UNSPECIFIED = 0; + PANIC = 1; + FATAL = 2; + ERROR = 3; + WARN = 4; + INFO = 5; + DEBUG = 6; + TRACE = 7; +} + +// Represents the current Logger settings. +message Logger { + // Output only. The logger's current log level. + LogLevel current_level = 1; + + // Output only. The logger's log level at process launch. + LogLevel launch_level = 2; +} +