github.com/cloudwan/edgelq-sdk@v1.15.4/devices/access/v1/device_distribution_counter/device_distribution_counter.pb.api_access.go (about) 1 // Code generated by protoc-gen-goten-access 2 // Resource: DeviceDistributionCounter 3 // DO NOT EDIT!!! 4 5 package device_distribution_counter_access 6 7 import ( 8 "context" 9 10 "google.golang.org/grpc" 11 "google.golang.org/grpc/codes" 12 "google.golang.org/grpc/metadata" 13 "google.golang.org/grpc/status" 14 15 gotenaccess "github.com/cloudwan/goten-sdk/runtime/access" 16 gotenresource "github.com/cloudwan/goten-sdk/runtime/resource" 17 gotenfilter "github.com/cloudwan/goten-sdk/runtime/resource/filter" 18 "github.com/cloudwan/goten-sdk/types/watch_type" 19 20 device_distribution_counter_client "github.com/cloudwan/edgelq-sdk/devices/client/v1/device_distribution_counter" 21 device_distribution_counter "github.com/cloudwan/edgelq-sdk/devices/resources/v1/device_distribution_counter" 22 ) 23 24 var ( 25 _ = new(context.Context) 26 27 _ = metadata.MD{} 28 _ = new(grpc.ClientConnInterface) 29 _ = codes.NotFound 30 _ = status.Status{} 31 32 _ = new(gotenaccess.Watcher) 33 _ = watch_type.WatchType_STATEFUL 34 _ = new(gotenresource.ListQuery) 35 _ = gotenfilter.Eq 36 ) 37 38 type apiDeviceDistributionCounterAccess struct { 39 client device_distribution_counter_client.DeviceDistributionCounterServiceClient 40 } 41 42 func NewApiDeviceDistributionCounterAccess(client device_distribution_counter_client.DeviceDistributionCounterServiceClient) device_distribution_counter.DeviceDistributionCounterAccess { 43 return &apiDeviceDistributionCounterAccess{client: client} 44 } 45 46 func (a *apiDeviceDistributionCounterAccess) GetDeviceDistributionCounter(ctx context.Context, query *device_distribution_counter.GetQuery, opts ...gotenresource.GetOption) (*device_distribution_counter.DeviceDistributionCounter, error) { 47 getOpts := gotenresource.MakeGetOptions(opts) 48 callHeaders := metadata.MD{} 49 if getOpts.GetSkipCache() { 50 callHeaders["cache-control"] = []string{"no-cache"} 51 } 52 callOpts := []grpc.CallOption{} 53 if len(callHeaders) > 0 { 54 callOpts = append(callOpts, grpc.Header(&callHeaders)) 55 } 56 if !query.Reference.IsFullyQualified() { 57 return nil, status.Errorf(codes.InvalidArgument, "Reference %s is not fully specified", query.Reference) 58 } 59 request := &device_distribution_counter_client.GetDeviceDistributionCounterRequest{ 60 Name: &query.Reference.Name, 61 FieldMask: query.Mask, 62 } 63 res, err := a.client.GetDeviceDistributionCounter(ctx, request, callOpts...) 64 if err != nil { 65 return nil, err 66 } 67 query.Reference.Resolve(res) 68 return res, nil 69 } 70 71 func (a *apiDeviceDistributionCounterAccess) BatchGetDeviceDistributionCounters(ctx context.Context, refs []*device_distribution_counter.Reference, opts ...gotenresource.BatchGetOption) error { 72 batchGetOpts := gotenresource.MakeBatchGetOptions(opts) 73 callHeaders := metadata.MD{} 74 if batchGetOpts.GetSkipCache() { 75 callHeaders["cache-control"] = []string{"no-cache"} 76 } 77 callOpts := []grpc.CallOption{} 78 if len(callHeaders) > 0 { 79 callOpts = append(callOpts, grpc.Header(&callHeaders)) 80 } 81 asNames := make([]*device_distribution_counter.Name, 0, len(refs)) 82 for _, ref := range refs { 83 if !ref.IsFullyQualified() { 84 return status.Errorf(codes.InvalidArgument, "Reference %s is not fully specified", ref) 85 } 86 asNames = append(asNames, &ref.Name) 87 } 88 request := &device_distribution_counter_client.BatchGetDeviceDistributionCountersRequest{ 89 Names: asNames, 90 } 91 fieldMask := batchGetOpts.GetFieldMask(device_distribution_counter.GetDescriptor()) 92 if fieldMask != nil { 93 request.FieldMask = fieldMask.(*device_distribution_counter.DeviceDistributionCounter_FieldMask) 94 } 95 resp, err := a.client.BatchGetDeviceDistributionCounters(ctx, request, callOpts...) 96 if err != nil { 97 return err 98 } 99 resultMap := make(map[device_distribution_counter.Name]*device_distribution_counter.DeviceDistributionCounter, len(refs)) 100 for _, resolvedRes := range resp.GetDeviceDistributionCounters() { 101 resultMap[*resolvedRes.GetName()] = resolvedRes 102 } 103 for _, ref := range refs { 104 resolvedRes := resultMap[ref.Name] 105 if resolvedRes != nil { 106 ref.Resolve(resolvedRes) 107 } 108 } 109 if batchGetOpts.MustResolveAll() && len(resp.GetMissing()) > 0 { 110 return status.Errorf(codes.NotFound, "Number of references not found: %d", len(resp.GetMissing())) 111 } 112 return nil 113 } 114 115 func (a *apiDeviceDistributionCounterAccess) QueryDeviceDistributionCounters(ctx context.Context, query *device_distribution_counter.ListQuery, opts ...gotenresource.QueryOption) (*device_distribution_counter.QueryResultSnapshot, error) { 116 qOpts := gotenresource.MakeQueryOptions(opts) 117 callHeaders := metadata.MD{} 118 if qOpts.GetSkipCache() { 119 callHeaders["cache-control"] = []string{"no-cache"} 120 } 121 callOpts := []grpc.CallOption{} 122 if len(callHeaders) > 0 { 123 callOpts = append(callOpts, grpc.Header(&callHeaders)) 124 } 125 request := &device_distribution_counter_client.ListDeviceDistributionCountersRequest{ 126 Filter: query.Filter, 127 FieldMask: query.Mask, 128 IncludePagingInfo: query.WithPagingInfo, 129 } 130 if query.Pager != nil { 131 request.PageSize = int32(query.Pager.Limit) 132 request.OrderBy = query.Pager.OrderBy 133 request.PageToken = query.Pager.Cursor 134 } 135 if query.Filter != nil && query.Filter.GetCondition() != nil { 136 request.Filter, request.Parent = getParentAndFilter(query.Filter) 137 } 138 resp, err := a.client.ListDeviceDistributionCounters(ctx, request) 139 if err != nil { 140 return nil, err 141 } 142 return &device_distribution_counter.QueryResultSnapshot{ 143 DeviceDistributionCounters: resp.DeviceDistributionCounters, 144 NextPageCursor: resp.NextPageToken, 145 PrevPageCursor: resp.PrevPageToken, 146 TotalResultsCount: resp.TotalResultsCount, 147 CurrentOffset: resp.CurrentOffset, 148 }, nil 149 } 150 151 func (a *apiDeviceDistributionCounterAccess) WatchDeviceDistributionCounter(ctx context.Context, query *device_distribution_counter.GetQuery, observerCb func(*device_distribution_counter.DeviceDistributionCounterChange) error) error { 152 if !query.Reference.IsFullyQualified() { 153 return status.Errorf(codes.InvalidArgument, "Reference %s is not fully specified", query.Reference) 154 } 155 request := &device_distribution_counter_client.WatchDeviceDistributionCounterRequest{ 156 Name: &query.Reference.Name, 157 FieldMask: query.Mask, 158 } 159 ctx, cancel := context.WithCancel(ctx) 160 defer cancel() 161 162 changesStream, initErr := a.client.WatchDeviceDistributionCounter(ctx, request) 163 if initErr != nil { 164 return initErr 165 } 166 for { 167 resp, err := changesStream.Recv() 168 if err != nil { 169 return status.Errorf(status.Code(err), "watch recv error: %s", err) 170 } 171 change := resp.GetChange() 172 if err := observerCb(change); err != nil { 173 return err 174 } 175 } 176 } 177 178 func (a *apiDeviceDistributionCounterAccess) WatchDeviceDistributionCounters(ctx context.Context, query *device_distribution_counter.WatchQuery, observerCb func(*device_distribution_counter.QueryResultChange) error) error { 179 request := &device_distribution_counter_client.WatchDeviceDistributionCountersRequest{ 180 Filter: query.Filter, 181 FieldMask: query.Mask, 182 MaxChunkSize: int32(query.ChunkSize), 183 Type: query.WatchType, 184 ResumeToken: query.ResumeToken, 185 StartingTime: query.StartingTime, 186 } 187 if query.Pager != nil { 188 request.OrderBy = query.Pager.OrderBy 189 request.PageSize = int32(query.Pager.Limit) 190 request.PageToken = query.Pager.Cursor 191 } 192 if query.Filter != nil && query.Filter.GetCondition() != nil { 193 request.Filter, request.Parent = getParentAndFilter(query.Filter) 194 } 195 ctx, cancel := context.WithCancel(ctx) 196 defer cancel() 197 198 changesStream, initErr := a.client.WatchDeviceDistributionCounters(ctx, request) 199 if initErr != nil { 200 return initErr 201 } 202 for { 203 respChange, err := changesStream.Recv() 204 if err != nil { 205 return status.Errorf(status.Code(err), "watch recv error: %s", err) 206 } 207 changesWithPaging := &device_distribution_counter.QueryResultChange{ 208 Changes: respChange.DeviceDistributionCounterChanges, 209 IsCurrent: respChange.IsCurrent, 210 IsHardReset: respChange.IsHardReset, 211 IsSoftReset: respChange.IsSoftReset, 212 ResumeToken: respChange.ResumeToken, 213 SnapshotSize: respChange.SnapshotSize, 214 } 215 if respChange.PageTokenChange != nil { 216 changesWithPaging.PrevPageCursor = respChange.PageTokenChange.PrevPageToken 217 changesWithPaging.NextPageCursor = respChange.PageTokenChange.NextPageToken 218 } 219 if err := observerCb(changesWithPaging); err != nil { 220 return err 221 } 222 } 223 } 224 225 func (a *apiDeviceDistributionCounterAccess) SaveDeviceDistributionCounter(ctx context.Context, res *device_distribution_counter.DeviceDistributionCounter, opts ...gotenresource.SaveOption) error { 226 return status.Errorf(codes.Internal, "save operation on %s does not exist", res.Name.AsReference().String()) 227 } 228 229 func (a *apiDeviceDistributionCounterAccess) DeleteDeviceDistributionCounter(ctx context.Context, ref *device_distribution_counter.Reference, opts ...gotenresource.DeleteOption) error { 230 return status.Errorf(codes.Internal, "Delete operation on DeviceDistributionCounter is prohibited") 231 } 232 func getParentAndFilter(fullFilter *device_distribution_counter.Filter) (*device_distribution_counter.Filter, *device_distribution_counter.ParentName) { 233 var withParentExtraction func(cnd device_distribution_counter.FilterCondition) device_distribution_counter.FilterCondition 234 var resultParent *device_distribution_counter.ParentName 235 var resultFilter *device_distribution_counter.Filter 236 withParentExtraction = func(cnd device_distribution_counter.FilterCondition) device_distribution_counter.FilterCondition { 237 switch tCnd := cnd.(type) { 238 case *device_distribution_counter.FilterConditionComposite: 239 if tCnd.GetOperator() == gotenfilter.AND { 240 withoutParentCnds := make([]device_distribution_counter.FilterCondition, 0) 241 for _, subCnd := range tCnd.Conditions { 242 if subCndNoParent := withParentExtraction(subCnd); subCndNoParent != nil { 243 withoutParentCnds = append(withoutParentCnds, subCndNoParent) 244 } 245 } 246 if len(withoutParentCnds) == 0 { 247 return nil 248 } 249 if len(withoutParentCnds) == 1 { 250 return withoutParentCnds[0] 251 } 252 return device_distribution_counter.AndFilterConditions(withoutParentCnds...) 253 } else { 254 return tCnd 255 } 256 case *device_distribution_counter.FilterConditionCompare: 257 if tCnd.GetOperator() == gotenfilter.Eq && tCnd.GetRawFieldPath().String() == "name" { 258 nameValue := tCnd.GetRawValue().(*device_distribution_counter.Name) 259 if nameValue != nil && nameValue.ParentName.IsSpecified() { 260 resultParent = &nameValue.ParentName 261 if nameValue.IsFullyQualified() { 262 return tCnd 263 } 264 return nil 265 } 266 } 267 return tCnd 268 default: 269 return tCnd 270 } 271 } 272 cndWithoutParent := withParentExtraction(fullFilter.GetCondition()) 273 if cndWithoutParent != nil { 274 resultFilter = &device_distribution_counter.Filter{FilterCondition: cndWithoutParent} 275 } 276 return resultFilter, resultParent 277 } 278 279 func GetApiAccessBuilder() *gotenaccess.ApiAccessBuilder { 280 return gotenaccess.GetRegistry().FindApiAccessBuilder(device_distribution_counter.GetDescriptor()) 281 } 282 283 func init() { 284 gotenaccess.GetRegistry().RegisterApiAccessConstructor(device_distribution_counter.GetDescriptor(), func(cc grpc.ClientConnInterface) gotenresource.Access { 285 return device_distribution_counter.AsAnyCastAccess(NewApiDeviceDistributionCounterAccess(device_distribution_counter_client.NewDeviceDistributionCounterServiceClient(cc))) 286 }) 287 }