Documentation ¶
Overview ¶
Package redact provides interfaces and methods to help implement redaction.
Index ¶
- Variables
- func Apply(in interface{})
- type Bypass
- type ElementRules
- func (*ElementRules) Descriptor() ([]byte, []int)deprecated
- func (x *ElementRules) GetEmpty() bool
- func (x *ElementRules) GetItem() *FieldRules
- func (x *ElementRules) GetNested() bool
- func (*ElementRules) ProtoMessage()
- func (x *ElementRules) ProtoReflect() protoreflect.Message
- func (x *ElementRules) Reset()
- func (x *ElementRules) String() string
- type FieldRules
- func (*FieldRules) Descriptor() ([]byte, []int)deprecated
- func (x *FieldRules) GetBool() bool
- func (x *FieldRules) GetBytes() []byte
- func (x *FieldRules) GetDouble() float64
- func (x *FieldRules) GetElement() *ElementRules
- func (x *FieldRules) GetEnum() int32
- func (x *FieldRules) GetFixed32() uint32
- func (x *FieldRules) GetFixed64() uint64
- func (x *FieldRules) GetFloat() float32
- func (x *FieldRules) GetInt32() int32
- func (x *FieldRules) GetInt64() int64
- func (x *FieldRules) GetMessage() *MessageRules
- func (x *FieldRules) GetSfixed32() int32
- func (x *FieldRules) GetSfixed64() int64
- func (x *FieldRules) GetSint32() int32
- func (x *FieldRules) GetSint64() int64
- func (x *FieldRules) GetString_() string
- func (x *FieldRules) GetUint32() uint32
- func (x *FieldRules) GetUint64() uint64
- func (m *FieldRules) GetValues() isFieldRules_Values
- func (*FieldRules) ProtoMessage()
- func (x *FieldRules) ProtoReflect() protoreflect.Message
- func (x *FieldRules) Reset()
- func (x *FieldRules) String() string
- type FieldRules_Bool
- type FieldRules_Bytes
- type FieldRules_Double
- type FieldRules_Element
- type FieldRules_Enum
- type FieldRules_Fixed32
- type FieldRules_Fixed64
- type FieldRules_Float
- type FieldRules_Int32
- type FieldRules_Int64
- type FieldRules_Message
- type FieldRules_Sfixed32
- type FieldRules_Sfixed64
- type FieldRules_Sint32
- type FieldRules_Sint64
- type FieldRules_String_
- type FieldRules_Uint32
- type FieldRules_Uint64
- type MessageRules
- func (*MessageRules) Descriptor() ([]byte, []int)deprecated
- func (x *MessageRules) GetApply() bool
- func (x *MessageRules) GetEmpty() bool
- func (x *MessageRules) GetNil() bool
- func (x *MessageRules) GetSkip() bool
- func (*MessageRules) ProtoMessage()
- func (x *MessageRules) ProtoReflect() protoreflect.Message
- func (x *MessageRules) Reset()
- func (x *MessageRules) String() string
- type Redactor
- type Wrapper
Constants ¶
This section is empty.
Variables ¶
var ( // ServiceSkip is used to skip the redaction in grpc service in the server // // optional bool service_skip = 54123; E_ServiceSkip = &file_redact_redact_proto_extTypes[1] // InternalService will make this service private and client will not be // able to receive any response for any of it's method, (unless skipped // explicitly) and will get PermissionDenied(7) error by default, to set // any other code set it in InternalServiceCode, it should be one of the // defined GRPC status code, and InternalServiceErrMessage for error // message, in which, one can use `%service%` or `%method%` tags to include // corresponding service name or method name, respectively. // // optional bool internal_service = 54124; E_InternalService = &file_redact_redact_proto_extTypes[2] // optional uint32 internal_service_code = 54125; E_InternalServiceCode = &file_redact_redact_proto_extTypes[3] // optional string internal_service_err_message = 54126; E_InternalServiceErrMessage = &file_redact_redact_proto_extTypes[4] )
Extension fields to descriptorpb.ServiceOptions.
var ( // MethodSkip is used to skip the redactions for this method in the grpc server // // optional bool method_skip = 54123; E_MethodSkip = &file_redact_redact_proto_extTypes[5] // InternalMethod, InternalMethodCode and InternalMethodErrMessage works same // as that of service level options: InternalService, InternalServiceCode and // InternalServiceErrMessage, but at Method level. All the validations and // functionalities are same for both. But the method level options will be used // whenever both are specified. // // optional bool internal_method = 54124; E_InternalMethod = &file_redact_redact_proto_extTypes[6] // optional uint32 internal_method_code = 54125; E_InternalMethodCode = &file_redact_redact_proto_extTypes[7] // optional string internal_method_err_message = 54126; E_InternalMethodErrMessage = &file_redact_redact_proto_extTypes[8] )
Extension fields to descriptorpb.MethodOptions.
var ( // Nil will redact message to nil (can be override by field level, `empty` option) // // optional bool nil = 54123; E_Nil = &file_redact_redact_proto_extTypes[9] // Empty will redact message to it's empty object // // optional bool empty = 54124; E_Empty = &file_redact_redact_proto_extTypes[10] // Ignored skips generation of any redaction for this message. // // optional bool ignored = 54125; E_Ignored = &file_redact_redact_proto_extTypes[11] )
Extension fields to descriptorpb.MessageOptions.
var ( // FileSkip is used to skip generation of any redaction for proto file // // optional bool file_skip = 90102; E_FileSkip = &file_redact_redact_proto_extTypes[0] )
Extension fields to descriptorpb.FileOptions.
var ( // Redact: it redact the field with predefined defaults: // - `0` for any number type // - `"REDACTED"` for string type // - `nil` for byte type // - `0th value` for enum type // - `nil` map for map type // - `nil` for repeated field type // - for message type, redaction is applied inside the message type // // bool redact = 54123; // Custom: specify the different values to be used for redaction on this field. By // default, if Custom value is not defined Redact should be true to apply redaction. // And if Custom value is to be assigned, one can skip the Redact field. // // optional redact.FieldRules value = 54123; E_Value = &file_redact_redact_proto_extTypes[12] )
Extension fields to descriptorpb.FieldOptions.
Falsy is the nil implementation for Bypass
var File_redact_redact_proto protoreflect.FileDescriptor
Functions ¶
Types ¶
type ElementRules ¶
type ElementRules struct { // Empty specifies that after redaction the list/map will be empty Empty bool `protobuf:"varint,1,opt,name=empty,proto3" json:"empty,omitempty"` // Nested specifies that default rules is to be applied `recursively` on each // item of map/list Nested bool `protobuf:"varint,2,opt,name=nested,proto3" json:"nested,omitempty"` // Item specifies that some custom redaction rules to be applied `recursively` // on each item in map/list. Item *FieldRules `protobuf:"bytes,3,opt,name=item,proto3" json:"item,omitempty"` // contains filtered or unexported fields }
ElementRules describe the constraints applied to `repeated` or `map` values
func (*ElementRules) Descriptor
deprecated
func (*ElementRules) Descriptor() ([]byte, []int)
Deprecated: Use ElementRules.ProtoReflect.Descriptor instead.
func (*ElementRules) GetEmpty ¶
func (x *ElementRules) GetEmpty() bool
func (*ElementRules) GetItem ¶
func (x *ElementRules) GetItem() *FieldRules
func (*ElementRules) GetNested ¶
func (x *ElementRules) GetNested() bool
func (*ElementRules) ProtoMessage ¶
func (*ElementRules) ProtoMessage()
func (*ElementRules) ProtoReflect ¶
func (x *ElementRules) ProtoReflect() protoreflect.Message
func (*ElementRules) Reset ¶
func (x *ElementRules) Reset()
func (*ElementRules) String ¶
func (x *ElementRules) String() string
type FieldRules ¶
type FieldRules struct { // values for redacted field // // Types that are assignable to Values: // // *FieldRules_Float // *FieldRules_Double // *FieldRules_Int32 // *FieldRules_Int64 // *FieldRules_Uint32 // *FieldRules_Uint64 // *FieldRules_Sint32 // *FieldRules_Sint64 // *FieldRules_Fixed32 // *FieldRules_Fixed64 // *FieldRules_Sfixed32 // *FieldRules_Sfixed64 // *FieldRules_Bool // *FieldRules_String_ // *FieldRules_Bytes // *FieldRules_Enum // *FieldRules_Message // *FieldRules_Element Values isFieldRules_Values `protobuf_oneof:"values"` // contains filtered or unexported fields }
FieldRules encapsulates options to change the redacted values of any type of field. Depending on the field, the correct type value should be used.
func (*FieldRules) Descriptor
deprecated
func (*FieldRules) Descriptor() ([]byte, []int)
Deprecated: Use FieldRules.ProtoReflect.Descriptor instead.
func (*FieldRules) GetBool ¶
func (x *FieldRules) GetBool() bool
func (*FieldRules) GetBytes ¶
func (x *FieldRules) GetBytes() []byte
func (*FieldRules) GetDouble ¶
func (x *FieldRules) GetDouble() float64
func (*FieldRules) GetElement ¶
func (x *FieldRules) GetElement() *ElementRules
func (*FieldRules) GetEnum ¶
func (x *FieldRules) GetEnum() int32
func (*FieldRules) GetFixed32 ¶
func (x *FieldRules) GetFixed32() uint32
func (*FieldRules) GetFixed64 ¶
func (x *FieldRules) GetFixed64() uint64
func (*FieldRules) GetFloat ¶
func (x *FieldRules) GetFloat() float32
func (*FieldRules) GetInt32 ¶
func (x *FieldRules) GetInt32() int32
func (*FieldRules) GetInt64 ¶
func (x *FieldRules) GetInt64() int64
func (*FieldRules) GetMessage ¶
func (x *FieldRules) GetMessage() *MessageRules
func (*FieldRules) GetSfixed32 ¶
func (x *FieldRules) GetSfixed32() int32
func (*FieldRules) GetSfixed64 ¶
func (x *FieldRules) GetSfixed64() int64
func (*FieldRules) GetSint32 ¶
func (x *FieldRules) GetSint32() int32
func (*FieldRules) GetSint64 ¶
func (x *FieldRules) GetSint64() int64
func (*FieldRules) GetString_ ¶
func (x *FieldRules) GetString_() string
func (*FieldRules) GetUint32 ¶
func (x *FieldRules) GetUint32() uint32
func (*FieldRules) GetUint64 ¶
func (x *FieldRules) GetUint64() uint64
func (*FieldRules) GetValues ¶
func (m *FieldRules) GetValues() isFieldRules_Values
func (*FieldRules) ProtoMessage ¶
func (*FieldRules) ProtoMessage()
func (*FieldRules) ProtoReflect ¶
func (x *FieldRules) ProtoReflect() protoreflect.Message
func (*FieldRules) Reset ¶
func (x *FieldRules) Reset()
func (*FieldRules) String ¶
func (x *FieldRules) String() string
type FieldRules_Bool ¶
type FieldRules_Bool struct {
Bool bool `protobuf:"varint,14,opt,name=bool,proto3,oneof"`
}
type FieldRules_Bytes ¶
type FieldRules_Bytes struct {
Bytes []byte `protobuf:"bytes,16,opt,name=bytes,proto3,oneof"`
}
type FieldRules_Double ¶
type FieldRules_Double struct {
Double float64 `protobuf:"fixed64,3,opt,name=double,proto3,oneof"`
}
type FieldRules_Element ¶
type FieldRules_Element struct { // Element defines rules for repeated or map type fields Element *ElementRules `protobuf:"bytes,20,opt,name=element,proto3,oneof"` }
type FieldRules_Enum ¶
type FieldRules_Enum struct {
Enum int32 `protobuf:"varint,17,opt,name=enum,proto3,oneof"`
}
type FieldRules_Fixed32 ¶
type FieldRules_Fixed32 struct {
Fixed32 uint32 `protobuf:"fixed32,10,opt,name=fixed32,proto3,oneof"`
}
type FieldRules_Fixed64 ¶
type FieldRules_Fixed64 struct {
Fixed64 uint64 `protobuf:"fixed64,11,opt,name=fixed64,proto3,oneof"`
}
type FieldRules_Float ¶
type FieldRules_Float struct { // Scalar Field Types values Float float32 `protobuf:"fixed32,2,opt,name=float,proto3,oneof"` }
type FieldRules_Int32 ¶
type FieldRules_Int32 struct {
Int32 int32 `protobuf:"varint,4,opt,name=int32,proto3,oneof"`
}
type FieldRules_Int64 ¶
type FieldRules_Int64 struct {
Int64 int64 `protobuf:"varint,5,opt,name=int64,proto3,oneof"`
}
type FieldRules_Message ¶
type FieldRules_Message struct { // Message defines rules for singular message type fields only Message *MessageRules `protobuf:"bytes,19,opt,name=message,proto3,oneof"` }
type FieldRules_Sfixed32 ¶
type FieldRules_Sfixed32 struct {
Sfixed32 int32 `protobuf:"fixed32,12,opt,name=sfixed32,proto3,oneof"`
}
type FieldRules_Sfixed64 ¶
type FieldRules_Sfixed64 struct {
Sfixed64 int64 `protobuf:"fixed64,13,opt,name=sfixed64,proto3,oneof"`
}
type FieldRules_Sint32 ¶
type FieldRules_Sint32 struct {
Sint32 int32 `protobuf:"zigzag32,8,opt,name=sint32,proto3,oneof"`
}
type FieldRules_Sint64 ¶
type FieldRules_Sint64 struct {
Sint64 int64 `protobuf:"zigzag64,9,opt,name=sint64,proto3,oneof"`
}
type FieldRules_String_ ¶
type FieldRules_String_ struct {
String_ string `protobuf:"bytes,15,opt,name=string,proto3,oneof"`
}
type FieldRules_Uint32 ¶
type FieldRules_Uint32 struct {
Uint32 uint32 `protobuf:"varint,6,opt,name=uint32,proto3,oneof"`
}
type FieldRules_Uint64 ¶
type FieldRules_Uint64 struct {
Uint64 uint64 `protobuf:"varint,7,opt,name=uint64,proto3,oneof"`
}
type MessageRules ¶
type MessageRules struct { // Skip specifies that the redaction rules of this field should not be evaluated Skip bool `protobuf:"varint,1,opt,name=skip,proto3" json:"skip,omitempty"` // Empty specifies that after redaction this field should be set to empty object Empty bool `protobuf:"varint,2,opt,name=empty,proto3" json:"empty,omitempty"` // Nil specifies that after redaction this field should be set to nil object Nil bool `protobuf:"varint,3,opt,name=nil,proto3" json:"nil,omitempty"` // Apply specifies that redaction is to be called for the message type Apply bool `protobuf:"varint,4,opt,name=apply,proto3" json:"apply,omitempty"` // contains filtered or unexported fields }
MessageRules describe the constraints applied to embedded message for redaction. For message-type fields, rules are performed recursively.
func (*MessageRules) Descriptor
deprecated
func (*MessageRules) Descriptor() ([]byte, []int)
Deprecated: Use MessageRules.ProtoReflect.Descriptor instead.
func (*MessageRules) GetApply ¶
func (x *MessageRules) GetApply() bool
func (*MessageRules) GetEmpty ¶
func (x *MessageRules) GetEmpty() bool
func (*MessageRules) GetNil ¶
func (x *MessageRules) GetNil() bool
func (*MessageRules) GetSkip ¶
func (x *MessageRules) GetSkip() bool
func (*MessageRules) ProtoMessage ¶
func (*MessageRules) ProtoMessage()
func (*MessageRules) ProtoReflect ¶
func (x *MessageRules) ProtoReflect() protoreflect.Message
func (*MessageRules) Reset ¶
func (x *MessageRules) Reset()
func (*MessageRules) String ¶
func (x *MessageRules) String() string