blob: f8e99cb002b193bb6f41fa6002c7bbfdc2a6cd43 [file] [log] [blame]
Holger Hildebrandt24d51952020-05-04 14:03:42 +00001/*
Joey Armstrong89c812c2024-01-12 19:00:20 -05002 * Copyright 2020-2024 Open Networking Foundation (ONF) and the ONF Contributors
Holger Hildebrandt24d51952020-05-04 14:03:42 +00003 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
praneeth kumar nalmas3947c582023-12-13 15:38:50 +053017// Package devdb provides access to internal device ME DB
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +000018package devdb
Holger Hildebrandt24d51952020-05-04 14:03:42 +000019
20import (
21 "context"
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +000022 "encoding/hex"
Holger Hildebrandt2ff21f12020-08-13 14:38:02 +000023 "fmt"
24 "reflect"
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +000025 "sort"
Mahir Gunyel7f4483a2021-05-06 12:53:43 -070026 "sync"
Holger Hildebrandt24d51952020-05-04 14:03:42 +000027
mpagenko836a1fd2021-11-01 16:12:42 +000028 me "github.com/opencord/omci-lib-go/v2/generated"
khenaidoo7d3c5582021-08-11 18:09:44 -040029 "github.com/opencord/voltha-lib-go/v7/pkg/log"
Holger Hildebrandt24d51952020-05-04 14:03:42 +000030)
31
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +053032// MeDbMap type holds MEs that are known to the ONT.
33type MeDbMap map[me.ClassID]map[uint16]me.AttributeValueMap
34
35// UnknownMeAndAttribDbMap type holds MEs that are Unknown to the ONT.
36type UnknownMeAndAttribDbMap map[UnknownMeOrAttribName]map[me.ClassID]map[uint16]unknownAttribs
37
38// OnuMCmnMEDBMap type holds MEs that are classified as Unknown to the ONT.
39type OnuMCmnMEDBMap map[string]*OnuCmnMEDB
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +000040
Holger Hildebrandt39080022022-03-16 10:03:17 +000041// UnknownMeOrAttribName type to be used for unknown ME and attribute names
42type UnknownMeOrAttribName string
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +000043
Holger Hildebrandt39080022022-03-16 10:03:17 +000044// names for unknown ME and attribute identifiers
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +000045const (
46 CUnknownItuG988ManagedEntity = "UnknownItuG988ManagedEntity"
47 CUnknownVendorSpecificManagedEntity = "UnknownVendorSpecificManagedEntity"
Holger Hildebrandt39080022022-03-16 10:03:17 +000048 CUnknownAttributesManagedEntity = "UnknownAttributesManagedEntity"
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +000049)
50
Holger Hildebrandt39080022022-03-16 10:03:17 +000051// CStartUnknownMeAttribsInBaseLayerPayload defines start of unknown ME attribs after ClassID, InstanceID and AttribMask
52const CStartUnknownMeAttribsInBaseLayerPayload = 6
53
54type unknownAttribs struct {
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +000055 AttribMask string `json:"AttributeMask"`
56 AttribBytes string `json:"AttributeBytes"`
57}
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +000058
praneeth kumar nalmas3947c582023-12-13 15:38:50 +053059// OnuDeviceDB structure holds information about ME's
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +000060type OnuDeviceDB struct {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +053061 ctx context.Context
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +053062 CommonMeDb *OnuCmnMEDB // Reference to OnuCmnMEDB
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +053063 OnuSpecificMeDb MeDbMap
Akash Reddy Kankanala92dfdf82025-03-23 22:07:09 +053064 deviceID string
65 OnuSpecificMeDbLock sync.RWMutex
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +053066}
67
68// MIBUploadStatus represents the status of MIBUpload for a particular ONT.
69type MIBUploadStatus int
70
71// Values for Status of the ONT MIB Upload.
72const (
73 NotStarted MIBUploadStatus = iota // MIB upload has not started
74 InProgress // MIB upload is in progress
75 Failed // MIB upload has failed
76 Completed // MIB upload is completed
77)
78
79// OnuCmnMEDB structure holds information about ME's common to ONT possessing same MIB Template.
80type OnuCmnMEDB struct {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +053081 MeDb MeDbMap
82 UnknownMeAndAttribDb UnknownMeAndAttribDbMap
83 MIBUploadStatus MIBUploadStatus
Akash Reddy Kankanala92dfdf82025-03-23 22:07:09 +053084 MeDbLock sync.RWMutex
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +053085}
86
87// NewOnuCmnMEDB returns a new instance of OnuCmnMEDB
88func NewOnuCmnMEDB(ctx context.Context) *OnuCmnMEDB {
89
90 return &OnuCmnMEDB{
91 MeDbLock: sync.RWMutex{},
92 MeDb: make(MeDbMap),
93 UnknownMeAndAttribDb: make(UnknownMeAndAttribDbMap),
94 MIBUploadStatus: NotStarted,
95 }
Holger Hildebrandt24d51952020-05-04 14:03:42 +000096}
97
praneeth kumar nalmas3947c582023-12-13 15:38:50 +053098// NewOnuDeviceDB returns a new instance for a specific ONU_Device_Entry
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +000099func NewOnuDeviceDB(ctx context.Context, aDeviceID string) *OnuDeviceDB {
100 logger.Debugw(ctx, "Init OnuDeviceDB for:", log.Fields{"device-id": aDeviceID})
Akash Reddy Kankanala92dfdf82025-03-23 22:07:09 +0530101 //nolint:govet
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +0000102 var OnuDeviceDB OnuDeviceDB
103 OnuDeviceDB.ctx = ctx
104 OnuDeviceDB.deviceID = aDeviceID
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530105 OnuDeviceDB.CommonMeDb = nil
106 OnuDeviceDB.OnuSpecificMeDb = make(MeDbMap)
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000107
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +0000108 return &OnuDeviceDB
Holger Hildebrandt24d51952020-05-04 14:03:42 +0000109}
110
praneeth kumar nalmas3947c582023-12-13 15:38:50 +0530111// PutMe puts an ME instance into internal ONU DB
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +0000112func (OnuDeviceDB *OnuDeviceDB) PutMe(ctx context.Context, meClassID me.ClassID, meEntityID uint16, meAttributes me.AttributeValueMap) {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530113
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000114 //filter out the OnuData
Himani Chawla4d908332020-08-31 12:30:20 +0530115 if me.OnuDataClassID == meClassID {
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000116 return
Holger Hildebrandt24d51952020-05-04 14:03:42 +0000117 }
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530118
119 // Dereference the MeDb pointer
120 if OnuDeviceDB.CommonMeDb == nil || OnuDeviceDB.CommonMeDb.MeDb == nil {
121 logger.Errorw(ctx, "MeDb is nil", log.Fields{"device-id": OnuDeviceDB.deviceID})
122 return
123 }
124 meDb := OnuDeviceDB.CommonMeDb.MeDb
125 _, ok := meDb[meClassID]
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000126 if !ok {
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +0000127 logger.Debugw(ctx, "meClassID not found - add to db :", log.Fields{"device-id": OnuDeviceDB.deviceID})
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530128 meDb[meClassID] = make(map[uint16]me.AttributeValueMap)
129 meDb[meClassID][meEntityID] = make(me.AttributeValueMap)
130 meDb[meClassID][meEntityID] = meAttributes
Holger Hildebrandt24d51952020-05-04 14:03:42 +0000131 } else {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530132 meAttribs, ok := meDb[meClassID][meEntityID]
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000133 if !ok {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530134 meDb[meClassID][meEntityID] = make(me.AttributeValueMap)
135 meDb[meClassID][meEntityID] = meAttributes
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000136 } else {
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000137 for k, v := range meAttributes {
138 meAttribs[k] = v
139 }
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530140 meDb[meClassID][meEntityID] = meAttribs
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000141 }
Holger Hildebrandt24d51952020-05-04 14:03:42 +0000142 }
Holger Hildebrandt24d51952020-05-04 14:03:42 +0000143}
144
praneeth kumar nalmas3947c582023-12-13 15:38:50 +0530145// GetMe returns an ME instance from internal ONU DB
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +0000146func (OnuDeviceDB *OnuDeviceDB) GetMe(meClassID me.ClassID, meEntityID uint16) me.AttributeValueMap {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530147 OnuDeviceDB.CommonMeDb.MeDbLock.RLock()
148 defer OnuDeviceDB.CommonMeDb.MeDbLock.RUnlock()
149
150 // Check in the common MeDb
151 if meAttributes, present := OnuDeviceDB.CommonMeDb.MeDb[meClassID][meEntityID]; present {
152 return meAttributes
153 }
154
155 OnuDeviceDB.OnuSpecificMeDbLock.RLock()
156 defer OnuDeviceDB.OnuSpecificMeDbLock.RUnlock()
157
158 // Check in the ONU-specific MeDb
159 if meAttributes, present := OnuDeviceDB.OnuSpecificMeDb[meClassID][meEntityID]; present {
Holger Hildebrandt9ca8b132020-08-07 14:45:03 +0000160 return meAttributes
Holger Hildebrandt9ca8b132020-08-07 14:45:03 +0000161 }
Himani Chawla4d908332020-08-31 12:30:20 +0530162 return nil
Holger Hildebrandt9ca8b132020-08-07 14:45:03 +0000163}
164
praneeth kumar nalmas3947c582023-12-13 15:38:50 +0530165// GetUint32Attrib converts JSON numbers to uint32
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +0000166func (OnuDeviceDB *OnuDeviceDB) GetUint32Attrib(meAttribute interface{}) (uint32, error) {
Holger Hildebrandt2ff21f12020-08-13 14:38:02 +0000167
168 switch reflect.TypeOf(meAttribute).Kind() {
169 case reflect.Float64:
170 //JSON numbers by default are unmarshaled into values of float64 type if type information is not present
171 return uint32(meAttribute.(float64)), nil
172 case reflect.Uint32:
Girish Gowdra09e5f212021-09-30 16:28:36 -0700173 return meAttribute.(uint32), nil
Holger Hildebrandt2ff21f12020-08-13 14:38:02 +0000174 default:
Akash Reddy Kankanala92dfdf82025-03-23 22:07:09 +0530175 return uint32(0), fmt.Errorf("wrong-interface-type-%v-received-for-device-%s", reflect.TypeOf(meAttribute).Kind(), OnuDeviceDB.deviceID)
Holger Hildebrandt2ff21f12020-08-13 14:38:02 +0000176 }
177}
178
praneeth kumar nalmas3947c582023-12-13 15:38:50 +0530179// GetUint16Attrib converts JSON numbers to uint16
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +0000180func (OnuDeviceDB *OnuDeviceDB) GetUint16Attrib(meAttribute interface{}) (uint16, error) {
Girish Gowdra041dcb32020-11-16 16:54:30 -0800181
182 switch reflect.TypeOf(meAttribute).Kind() {
Girish Gowdra09e5f212021-09-30 16:28:36 -0700183 case reflect.Float64:
184 //JSON numbers by default are unmarshaled into values of float64 type if type information is not present
185 return uint16(meAttribute.(float64)), nil
Girish Gowdra041dcb32020-11-16 16:54:30 -0800186 case reflect.Uint16:
187 return meAttribute.(uint16), nil
188 default:
Akash Reddy Kankanala92dfdf82025-03-23 22:07:09 +0530189 return uint16(0), fmt.Errorf("wrong-interface-type-%v-received-for-device-%s", reflect.TypeOf(meAttribute).Kind(), OnuDeviceDB.deviceID)
Girish Gowdra041dcb32020-11-16 16:54:30 -0800190 }
191}
Girish Gowdra041dcb32020-11-16 16:54:30 -0800192
praneeth kumar nalmas3947c582023-12-13 15:38:50 +0530193// GetSortedInstKeys returns a sorted list of all instances of an ME
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +0000194func (OnuDeviceDB *OnuDeviceDB) GetSortedInstKeys(ctx context.Context, meClassID me.ClassID) []uint16 {
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000195
196 var meInstKeys []uint16
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530197 OnuDeviceDB.CommonMeDb.MeDbLock.RLock()
198 defer OnuDeviceDB.CommonMeDb.MeDbLock.RUnlock()
199 meDb := OnuDeviceDB.CommonMeDb.MeDb
Holger Hildebrandt9ca8b132020-08-07 14:45:03 +0000200
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530201 // Check if the class ID exists in the MeDb map
202 if meInstMap, found := meDb[meClassID]; found {
203 for k := range meInstMap {
204 meInstKeys = append(meInstKeys, k)
205 }
206 logger.Debugw(ctx, "meInstKeys - input order :", log.Fields{"meInstKeys": meInstKeys}) //TODO: delete the line after test phase!
Holger Hildebrandt24d51952020-05-04 14:03:42 +0000207 }
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000208 sort.Slice(meInstKeys, func(i, j int) bool { return meInstKeys[i] < meInstKeys[j] })
dbainbri4d3a0dc2020-12-02 00:33:42 +0000209 logger.Debugw(ctx, "meInstKeys - output order :", log.Fields{"meInstKeys": meInstKeys}) //TODO: delete the line after test phase!
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530210
211 // Return the sorted instance keys
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000212 return meInstKeys
Holger Hildebrandt24d51952020-05-04 14:03:42 +0000213}
214
praneeth kumar nalmas3947c582023-12-13 15:38:50 +0530215// GetNumberOfInst returns the number of instances of an ME
Holger Hildebrandt5ba6c132022-10-06 13:53:14 +0000216func (OnuDeviceDB *OnuDeviceDB) GetNumberOfInst(meClassID me.ClassID) int {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530217 var count int
218
219 OnuDeviceDB.CommonMeDb.MeDbLock.RLock()
220 defer OnuDeviceDB.CommonMeDb.MeDbLock.RUnlock()
221
222 if meClassMap, found := OnuDeviceDB.CommonMeDb.MeDb[meClassID]; found {
223 count = len(meClassMap)
224 }
225
226 OnuDeviceDB.OnuSpecificMeDbLock.RLock()
227 defer OnuDeviceDB.OnuSpecificMeDbLock.RUnlock()
228
229 if onuSpecificMap, found := OnuDeviceDB.OnuSpecificMeDb[meClassID]; found {
230 count += len(onuSpecificMap)
231 }
232
233 return count
Holger Hildebrandt5ba6c132022-10-06 13:53:14 +0000234}
235
praneeth kumar nalmas3947c582023-12-13 15:38:50 +0530236// LogMeDb logs content of internal ONU DB
Holger Hildebrandt4b5e73f2021-08-19 06:51:21 +0000237func (OnuDeviceDB *OnuDeviceDB) LogMeDb(ctx context.Context) {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530238 logger.Debugw(ctx, "Logging ME instances for device:", log.Fields{"device-id": OnuDeviceDB.deviceID})
239
240 if OnuDeviceDB.CommonMeDb != nil && OnuDeviceDB.CommonMeDb.MeDb != nil {
241 meDb := OnuDeviceDB.CommonMeDb.MeDb
242
243 for meClassID, meInstMap := range meDb {
244 for meEntityID, meAttribs := range meInstMap {
245 logger.Debugw(ctx, "Common ME instance: ", log.Fields{"meClassID": meClassID, "meEntityID": meEntityID, "meAttribs": meAttribs,
246 "device-id": OnuDeviceDB.deviceID})
247 }
248 }
249 } else {
250 logger.Warnw(ctx, "Common MeDb is nil", log.Fields{"device-id": OnuDeviceDB.deviceID})
251 }
252
253 // Log ONU-specific ME instances
254 OnuDeviceDB.OnuSpecificMeDbLock.RLock()
255 defer OnuDeviceDB.OnuSpecificMeDbLock.RUnlock()
256
257 for meClassID, meInstMap := range OnuDeviceDB.OnuSpecificMeDb {
Himani Chawla4d908332020-08-31 12:30:20 +0530258 for meEntityID, meAttribs := range meInstMap {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530259 logger.Debugw(ctx, "ONU Specific ME instance:", log.Fields{
260 "meClassID": meClassID,
261 "meEntityID": meEntityID,
262 "meAttribs": meAttribs,
263 "device-id": OnuDeviceDB.deviceID,
264 })
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +0000265 }
266 }
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530267
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +0000268}
269
praneeth kumar nalmas3947c582023-12-13 15:38:50 +0530270// PutUnknownMeOrAttrib puts an instance with unknown ME or attributes into internal ONU DB
Holger Hildebrandt39080022022-03-16 10:03:17 +0000271func (OnuDeviceDB *OnuDeviceDB) PutUnknownMeOrAttrib(ctx context.Context, aMeName UnknownMeOrAttribName, aMeClassID me.ClassID, aMeEntityID uint16,
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +0000272 aMeAttributeMask uint16, aMePayload []byte) {
273
Holger Hildebrandt39080022022-03-16 10:03:17 +0000274 meAttribMaskStr := fmt.Sprintf("0x%04x", aMeAttributeMask)
275 attribs := unknownAttribs{meAttribMaskStr, hex.EncodeToString(aMePayload)}
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +0000276
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530277 unknownMeDb := OnuDeviceDB.CommonMeDb.UnknownMeAndAttribDb
278
279 _, ok := unknownMeDb[aMeName]
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +0000280 if !ok {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530281 unknownMeDb[aMeName] = make(map[me.ClassID]map[uint16]unknownAttribs)
282 unknownMeDb[aMeName][aMeClassID] = make(map[uint16]unknownAttribs)
283 unknownMeDb[aMeName][aMeClassID][aMeEntityID] = attribs
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +0000284 } else {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530285 _, ok := unknownMeDb[aMeName][aMeClassID]
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +0000286 if !ok {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530287 unknownMeDb[aMeName][aMeClassID] = make(map[uint16]unknownAttribs)
288 unknownMeDb[aMeName][aMeClassID][aMeEntityID] = attribs
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +0000289 } else {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530290 _, ok := unknownMeDb[aMeName][aMeClassID][aMeEntityID]
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +0000291 if !ok {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530292 unknownMeDb[aMeName][aMeClassID][aMeEntityID] = attribs
Holger Hildebrandtf3c7a182021-11-17 13:42:08 +0000293 }
Holger Hildebrandt9ac0d0f2020-05-13 11:22:02 +0000294 }
Holger Hildebrandt24d51952020-05-04 14:03:42 +0000295 }
Holger Hildebrandt24d51952020-05-04 14:03:42 +0000296}
praneeth kumar nalmas3947c582023-12-13 15:38:50 +0530297
298// DeleteMe deletes an ME instance from internal ONU DB
299func (OnuDeviceDB *OnuDeviceDB) DeleteMe(meClassID me.ClassID, meEntityID uint16) {
Praneeth Kumar Nalmas8f8f0c02024-10-22 19:29:09 +0530300 OnuDeviceDB.CommonMeDb.MeDbLock.Lock()
301 defer OnuDeviceDB.CommonMeDb.MeDbLock.Unlock()
302 meDb := OnuDeviceDB.CommonMeDb.MeDb
303 delete(meDb[meClassID], meEntityID)
304
305 OnuDeviceDB.OnuSpecificMeDbLock.Lock()
306 defer OnuDeviceDB.OnuSpecificMeDbLock.Unlock()
307 delete(OnuDeviceDB.OnuSpecificMeDb[meClassID], meEntityID)
308}
309
310// PutOnuSpeficMe puts an ME instance into specifically to the ONU DB maintained per ONU.
311func (OnuDeviceDB *OnuDeviceDB) PutOnuSpeficMe(ctx context.Context, meClassID me.ClassID, meEntityID uint16, meAttributes me.AttributeValueMap) {
312 OnuDeviceDB.OnuSpecificMeDbLock.Lock()
313 defer OnuDeviceDB.OnuSpecificMeDbLock.Unlock()
314 //filter out the OnuData
315 if me.OnuDataClassID == meClassID {
316 return
317 }
318 _, ok := OnuDeviceDB.OnuSpecificMeDb[meClassID]
319 if !ok {
320 logger.Debugw(ctx, "meClassID not found - add to db :", log.Fields{"device-id": OnuDeviceDB.deviceID})
321 OnuDeviceDB.OnuSpecificMeDb[meClassID] = make(map[uint16]me.AttributeValueMap)
322 OnuDeviceDB.OnuSpecificMeDb[meClassID][meEntityID] = make(me.AttributeValueMap)
323 OnuDeviceDB.OnuSpecificMeDb[meClassID][meEntityID] = meAttributes
324 } else {
325 meAttribs, ok := OnuDeviceDB.OnuSpecificMeDb[meClassID][meEntityID]
326 if !ok {
327 OnuDeviceDB.OnuSpecificMeDb[meClassID][meEntityID] = make(me.AttributeValueMap)
328 OnuDeviceDB.OnuSpecificMeDb[meClassID][meEntityID] = meAttributes
329 } else {
330 for k, v := range meAttributes {
331 meAttribs[k] = v
332 }
333 OnuDeviceDB.OnuSpecificMeDb[meClassID][meEntityID] = meAttribs
334 }
335 }
praneeth kumar nalmas3947c582023-12-13 15:38:50 +0530336}