+ mutex sync.Mutex
+ register map[uint16]*Subscription
+ subIds []uint16
+ rtmgrClient *RtmgrClient
+}
+
+// This method should run as a constructor
+func (r *Registry) Initialize() {
+ r.register = make(map[uint16]*Subscription)
+ var i uint16
+ for i = 0; i < 65535; i++ {
+ r.subIds = append(r.subIds, i+1)
+ }
+}
+
+// Reserves and returns the next free sequence number
+func (r *Registry) AssignToSubscription(trans *Transaction, subReqMsg *e2ap.E2APSubscriptionRequest) (*Subscription, error) {
+ r.mutex.Lock()
+ defer r.mutex.Unlock()
+ if len(r.subIds) > 0 {
+ sequenceNumber := r.subIds[0]
+ r.subIds = r.subIds[1:]
+ if _, ok := r.register[sequenceNumber]; ok == false {
+ subs := &Subscription{
+ registry: r,
+ Seq: sequenceNumber,
+ Meid: trans.Meid,
+ }
+ err := subs.AddEndpoint(trans.GetEndpoint())
+ if err != nil {
+ return nil, err
+ }
+ subs.SubReqMsg = subReqMsg
+
+ r.register[sequenceNumber] = subs
+ xapp.Logger.Debug("Registry: Create %s", subs.String())
+ xapp.Logger.Debug("Registry: substable=%v", r.register)
+ return subs, nil
+ }
+ }
+ return nil, fmt.Errorf("Registry: Failed to reserves subscription")
+}
+
+func (r *Registry) GetSubscription(sn uint16) *Subscription {
+ r.mutex.Lock()
+ defer r.mutex.Unlock()
+ if _, ok := r.register[sn]; ok {
+ return r.register[sn]
+ }
+ return nil