github.com/cloudwan/edgelq-sdk@v1.15.4/logging/resources/v1/log_descriptor/log_descriptor.pb.fieldmask.go (about) 1 // Code generated by protoc-gen-goten-object 2 // File: edgelq/logging/proto/v1/log_descriptor.proto 3 // DO NOT EDIT!!! 4 5 package log_descriptor 6 7 import ( 8 "encoding/json" 9 "strings" 10 11 "google.golang.org/grpc/codes" 12 "google.golang.org/grpc/status" 13 "google.golang.org/protobuf/proto" 14 preflect "google.golang.org/protobuf/reflect/protoreflect" 15 googlefieldmaskpb "google.golang.org/protobuf/types/known/fieldmaskpb" 16 17 gotenobject "github.com/cloudwan/goten-sdk/runtime/object" 18 ) 19 20 // proto imports 21 import ( 22 iam_organization "github.com/cloudwan/edgelq-sdk/iam/resources/v1/organization" 23 iam_project "github.com/cloudwan/edgelq-sdk/iam/resources/v1/project" 24 common "github.com/cloudwan/edgelq-sdk/logging/resources/v1/common" 25 meta_service "github.com/cloudwan/goten-sdk/meta-service/resources/v1/service" 26 meta "github.com/cloudwan/goten-sdk/types/meta" 27 ) 28 29 // ensure the imports are used 30 var ( 31 _ = new(json.Marshaler) 32 _ = strings.Builder{} 33 34 _ = codes.NotFound 35 _ = status.Status{} 36 _ = new(proto.Message) 37 _ = new(preflect.Message) 38 _ = googlefieldmaskpb.FieldMask{} 39 40 _ = new(gotenobject.FieldMask) 41 ) 42 43 // make sure we're using proto imports 44 var ( 45 _ = &iam_organization.Organization{} 46 _ = &iam_project.Project{} 47 _ = &common.LabelDescriptor{} 48 _ = &meta_service.Service{} 49 _ = &meta.Meta{} 50 ) 51 52 type LogDescriptor_FieldMask struct { 53 Paths []LogDescriptor_FieldPath 54 } 55 56 func FullLogDescriptor_FieldMask() *LogDescriptor_FieldMask { 57 res := &LogDescriptor_FieldMask{} 58 res.Paths = append(res.Paths, &LogDescriptor_FieldTerminalPath{selector: LogDescriptor_FieldPathSelectorName}) 59 res.Paths = append(res.Paths, &LogDescriptor_FieldTerminalPath{selector: LogDescriptor_FieldPathSelectorMetadata}) 60 res.Paths = append(res.Paths, &LogDescriptor_FieldTerminalPath{selector: LogDescriptor_FieldPathSelectorDisplayName}) 61 res.Paths = append(res.Paths, &LogDescriptor_FieldTerminalPath{selector: LogDescriptor_FieldPathSelectorDescription}) 62 res.Paths = append(res.Paths, &LogDescriptor_FieldTerminalPath{selector: LogDescriptor_FieldPathSelectorLabels}) 63 res.Paths = append(res.Paths, &LogDescriptor_FieldTerminalPath{selector: LogDescriptor_FieldPathSelectorPromotedLabelKeySets}) 64 return res 65 } 66 67 func (fieldMask *LogDescriptor_FieldMask) String() string { 68 if fieldMask == nil { 69 return "<nil>" 70 } 71 pathsStr := make([]string, 0, len(fieldMask.Paths)) 72 for _, path := range fieldMask.Paths { 73 pathsStr = append(pathsStr, path.String()) 74 } 75 return strings.Join(pathsStr, ", ") 76 } 77 78 func (fieldMask *LogDescriptor_FieldMask) IsFull() bool { 79 if fieldMask == nil { 80 return false 81 } 82 presentSelectors := make([]bool, 6) 83 for _, path := range fieldMask.Paths { 84 if asFinal, ok := path.(*LogDescriptor_FieldTerminalPath); ok { 85 presentSelectors[int(asFinal.selector)] = true 86 } 87 } 88 for _, flag := range presentSelectors { 89 if !flag { 90 return false 91 } 92 } 93 return true 94 } 95 96 func (fieldMask *LogDescriptor_FieldMask) ProtoReflect() preflect.Message { 97 return gotenobject.MakeFieldMaskReflection(fieldMask, func(raw string) (gotenobject.FieldPath, error) { 98 return ParseLogDescriptor_FieldPath(raw) 99 }) 100 } 101 102 func (fieldMask *LogDescriptor_FieldMask) ProtoMessage() {} 103 104 func (fieldMask *LogDescriptor_FieldMask) Reset() { 105 if fieldMask != nil { 106 fieldMask.Paths = nil 107 } 108 } 109 110 func (fieldMask *LogDescriptor_FieldMask) Subtract(other *LogDescriptor_FieldMask) *LogDescriptor_FieldMask { 111 result := &LogDescriptor_FieldMask{} 112 removedSelectors := make([]bool, 6) 113 otherSubMasks := map[LogDescriptor_FieldPathSelector]gotenobject.FieldMask{ 114 LogDescriptor_FieldPathSelectorMetadata: &meta.Meta_FieldMask{}, 115 LogDescriptor_FieldPathSelectorLabels: &common.LabelDescriptor_FieldMask{}, 116 LogDescriptor_FieldPathSelectorPromotedLabelKeySets: &common.LabelKeySet_FieldMask{}, 117 } 118 mySubMasks := map[LogDescriptor_FieldPathSelector]gotenobject.FieldMask{ 119 LogDescriptor_FieldPathSelectorMetadata: &meta.Meta_FieldMask{}, 120 LogDescriptor_FieldPathSelectorLabels: &common.LabelDescriptor_FieldMask{}, 121 LogDescriptor_FieldPathSelectorPromotedLabelKeySets: &common.LabelKeySet_FieldMask{}, 122 } 123 124 for _, path := range other.GetPaths() { 125 switch tp := path.(type) { 126 case *LogDescriptor_FieldTerminalPath: 127 removedSelectors[int(tp.selector)] = true 128 case *LogDescriptor_FieldSubPath: 129 otherSubMasks[tp.selector].AppendRawPath(tp.subPath) 130 } 131 } 132 for _, path := range fieldMask.GetPaths() { 133 if !removedSelectors[int(path.Selector())] { 134 if otherSubMask := otherSubMasks[path.Selector()]; otherSubMask != nil && otherSubMask.PathsCount() > 0 { 135 if tp, ok := path.(*LogDescriptor_FieldTerminalPath); ok { 136 switch tp.selector { 137 case LogDescriptor_FieldPathSelectorMetadata: 138 mySubMasks[LogDescriptor_FieldPathSelectorMetadata] = meta.FullMeta_FieldMask() 139 case LogDescriptor_FieldPathSelectorLabels: 140 mySubMasks[LogDescriptor_FieldPathSelectorLabels] = common.FullLabelDescriptor_FieldMask() 141 case LogDescriptor_FieldPathSelectorPromotedLabelKeySets: 142 mySubMasks[LogDescriptor_FieldPathSelectorPromotedLabelKeySets] = common.FullLabelKeySet_FieldMask() 143 } 144 } else if tp, ok := path.(*LogDescriptor_FieldSubPath); ok { 145 mySubMasks[tp.selector].AppendRawPath(tp.subPath) 146 } 147 } else { 148 result.Paths = append(result.Paths, path) 149 } 150 } 151 } 152 for selector, mySubMask := range mySubMasks { 153 if mySubMask.PathsCount() > 0 { 154 for _, allowedPath := range mySubMask.SubtractRaw(otherSubMasks[selector]).GetRawPaths() { 155 result.Paths = append(result.Paths, &LogDescriptor_FieldSubPath{selector: selector, subPath: allowedPath}) 156 } 157 } 158 } 159 160 if len(result.Paths) == 0 { 161 return nil 162 } 163 return result 164 } 165 166 func (fieldMask *LogDescriptor_FieldMask) SubtractRaw(other gotenobject.FieldMask) gotenobject.FieldMask { 167 return fieldMask.Subtract(other.(*LogDescriptor_FieldMask)) 168 } 169 170 // FilterInputFields generates copy of field paths with output_only field paths removed 171 func (fieldMask *LogDescriptor_FieldMask) FilterInputFields() *LogDescriptor_FieldMask { 172 result := &LogDescriptor_FieldMask{} 173 for _, path := range fieldMask.Paths { 174 switch path.Selector() { 175 case LogDescriptor_FieldPathSelectorMetadata: 176 if _, ok := path.(*LogDescriptor_FieldTerminalPath); ok { 177 for _, subpath := range meta.FullMeta_FieldMask().FilterInputFields().Paths { 178 result.Paths = append(result.Paths, &LogDescriptor_FieldSubPath{selector: path.Selector(), subPath: subpath}) 179 } 180 } else if sub, ok := path.(*LogDescriptor_FieldSubPath); ok { 181 selectedMask := &meta.Meta_FieldMask{ 182 Paths: []meta.Meta_FieldPath{sub.subPath.(meta.Meta_FieldPath)}, 183 } 184 for _, allowedPath := range selectedMask.FilterInputFields().Paths { 185 result.Paths = append(result.Paths, &LogDescriptor_FieldSubPath{selector: LogDescriptor_FieldPathSelectorMetadata, subPath: allowedPath}) 186 } 187 } 188 default: 189 result.Paths = append(result.Paths, path) 190 } 191 } 192 return result 193 } 194 195 // ToFieldMask is used for proto conversions 196 func (fieldMask *LogDescriptor_FieldMask) ToProtoFieldMask() *googlefieldmaskpb.FieldMask { 197 protoFieldMask := &googlefieldmaskpb.FieldMask{} 198 for _, path := range fieldMask.Paths { 199 protoFieldMask.Paths = append(protoFieldMask.Paths, path.String()) 200 } 201 return protoFieldMask 202 } 203 204 func (fieldMask *LogDescriptor_FieldMask) FromProtoFieldMask(protoFieldMask *googlefieldmaskpb.FieldMask) error { 205 if fieldMask == nil { 206 return status.Error(codes.Internal, "target field mask is nil") 207 } 208 fieldMask.Paths = make([]LogDescriptor_FieldPath, 0, len(protoFieldMask.Paths)) 209 for _, strPath := range protoFieldMask.Paths { 210 path, err := ParseLogDescriptor_FieldPath(strPath) 211 if err != nil { 212 return err 213 } 214 fieldMask.Paths = append(fieldMask.Paths, path) 215 } 216 return nil 217 } 218 219 // implement methods required by customType 220 func (fieldMask LogDescriptor_FieldMask) Marshal() ([]byte, error) { 221 protoFieldMask := fieldMask.ToProtoFieldMask() 222 return proto.Marshal(protoFieldMask) 223 } 224 225 func (fieldMask *LogDescriptor_FieldMask) Unmarshal(data []byte) error { 226 protoFieldMask := &googlefieldmaskpb.FieldMask{} 227 if err := proto.Unmarshal(data, protoFieldMask); err != nil { 228 return err 229 } 230 if err := fieldMask.FromProtoFieldMask(protoFieldMask); err != nil { 231 return err 232 } 233 return nil 234 } 235 236 func (fieldMask *LogDescriptor_FieldMask) Size() int { 237 return proto.Size(fieldMask.ToProtoFieldMask()) 238 } 239 240 func (fieldMask LogDescriptor_FieldMask) MarshalJSON() ([]byte, error) { 241 return json.Marshal(fieldMask.ToProtoFieldMask()) 242 } 243 244 func (fieldMask *LogDescriptor_FieldMask) UnmarshalJSON(data []byte) error { 245 protoFieldMask := &googlefieldmaskpb.FieldMask{} 246 if err := json.Unmarshal(data, protoFieldMask); err != nil { 247 return err 248 } 249 if err := fieldMask.FromProtoFieldMask(protoFieldMask); err != nil { 250 return err 251 } 252 return nil 253 } 254 255 func (fieldMask *LogDescriptor_FieldMask) AppendPath(path LogDescriptor_FieldPath) { 256 fieldMask.Paths = append(fieldMask.Paths, path) 257 } 258 259 func (fieldMask *LogDescriptor_FieldMask) AppendRawPath(path gotenobject.FieldPath) { 260 fieldMask.Paths = append(fieldMask.Paths, path.(LogDescriptor_FieldPath)) 261 } 262 263 func (fieldMask *LogDescriptor_FieldMask) GetPaths() []LogDescriptor_FieldPath { 264 if fieldMask == nil { 265 return nil 266 } 267 return fieldMask.Paths 268 } 269 270 func (fieldMask *LogDescriptor_FieldMask) GetRawPaths() []gotenobject.FieldPath { 271 if fieldMask == nil { 272 return nil 273 } 274 rawPaths := make([]gotenobject.FieldPath, 0, len(fieldMask.Paths)) 275 for _, path := range fieldMask.Paths { 276 rawPaths = append(rawPaths, path) 277 } 278 return rawPaths 279 } 280 281 func (fieldMask *LogDescriptor_FieldMask) SetFromCliFlag(raw string) error { 282 path, err := ParseLogDescriptor_FieldPath(raw) 283 if err != nil { 284 return err 285 } 286 fieldMask.Paths = append(fieldMask.Paths, path) 287 return nil 288 } 289 290 func (fieldMask *LogDescriptor_FieldMask) Set(target, source *LogDescriptor) { 291 for _, path := range fieldMask.Paths { 292 val, _ := path.GetSingle(source) 293 // if val is nil, then field does not exist in source, skip 294 // otherwise, process (can still reflect.ValueOf(val).IsNil!) 295 if val != nil { 296 path.WithIValue(val).SetTo(&target) 297 } 298 } 299 } 300 301 func (fieldMask *LogDescriptor_FieldMask) SetRaw(target, source gotenobject.GotenObjectExt) { 302 fieldMask.Set(target.(*LogDescriptor), source.(*LogDescriptor)) 303 } 304 305 func (fieldMask *LogDescriptor_FieldMask) Project(source *LogDescriptor) *LogDescriptor { 306 if source == nil { 307 return nil 308 } 309 if fieldMask == nil { 310 return source 311 } 312 result := &LogDescriptor{} 313 metadataMask := &meta.Meta_FieldMask{} 314 wholeMetadataAccepted := false 315 labelsMask := &common.LabelDescriptor_FieldMask{} 316 wholeLabelsAccepted := false 317 promotedLabelKeySetsMask := &common.LabelKeySet_FieldMask{} 318 wholePromotedLabelKeySetsAccepted := false 319 320 for _, p := range fieldMask.Paths { 321 switch tp := p.(type) { 322 case *LogDescriptor_FieldTerminalPath: 323 switch tp.selector { 324 case LogDescriptor_FieldPathSelectorName: 325 result.Name = source.Name 326 case LogDescriptor_FieldPathSelectorMetadata: 327 result.Metadata = source.Metadata 328 wholeMetadataAccepted = true 329 case LogDescriptor_FieldPathSelectorDisplayName: 330 result.DisplayName = source.DisplayName 331 case LogDescriptor_FieldPathSelectorDescription: 332 result.Description = source.Description 333 case LogDescriptor_FieldPathSelectorLabels: 334 result.Labels = source.Labels 335 wholeLabelsAccepted = true 336 case LogDescriptor_FieldPathSelectorPromotedLabelKeySets: 337 result.PromotedLabelKeySets = source.PromotedLabelKeySets 338 wholePromotedLabelKeySetsAccepted = true 339 } 340 case *LogDescriptor_FieldSubPath: 341 switch tp.selector { 342 case LogDescriptor_FieldPathSelectorMetadata: 343 metadataMask.AppendPath(tp.subPath.(meta.Meta_FieldPath)) 344 case LogDescriptor_FieldPathSelectorLabels: 345 labelsMask.AppendPath(tp.subPath.(common.LabelDescriptor_FieldPath)) 346 case LogDescriptor_FieldPathSelectorPromotedLabelKeySets: 347 promotedLabelKeySetsMask.AppendPath(tp.subPath.(common.LabelKeySet_FieldPath)) 348 } 349 } 350 } 351 if wholeMetadataAccepted == false && len(metadataMask.Paths) > 0 { 352 result.Metadata = metadataMask.Project(source.GetMetadata()) 353 } 354 if wholeLabelsAccepted == false && len(labelsMask.Paths) > 0 { 355 for _, sourceItem := range source.GetLabels() { 356 result.Labels = append(result.Labels, labelsMask.Project(sourceItem)) 357 } 358 } 359 if wholePromotedLabelKeySetsAccepted == false && len(promotedLabelKeySetsMask.Paths) > 0 { 360 for _, sourceItem := range source.GetPromotedLabelKeySets() { 361 result.PromotedLabelKeySets = append(result.PromotedLabelKeySets, promotedLabelKeySetsMask.Project(sourceItem)) 362 } 363 } 364 return result 365 } 366 367 func (fieldMask *LogDescriptor_FieldMask) ProjectRaw(source gotenobject.GotenObjectExt) gotenobject.GotenObjectExt { 368 return fieldMask.Project(source.(*LogDescriptor)) 369 } 370 371 func (fieldMask *LogDescriptor_FieldMask) PathsCount() int { 372 if fieldMask == nil { 373 return 0 374 } 375 return len(fieldMask.Paths) 376 }