blob: 374b2aa75830eaca1c8e6d6c71cdbb110a9b8671 [file] [log] [blame]
Stephane Barbariea75791c2019-01-24 10:58:06 -05001/*
2 * Copyright 2018-present Open Networking Foundation
3
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 */
npujar03b018e2019-11-13 15:29:36 +053016
Stephane Barbariea75791c2019-01-24 10:58:06 -050017package core
18
19import (
20 "context"
npujar03b018e2019-11-13 15:29:36 +053021 "sync"
22
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -050023 "github.com/gogo/protobuf/proto"
sbarbari17d7e222019-11-05 10:02:29 -050024 "github.com/opencord/voltha-go/db/model"
serkant.uluderya2ae470f2020-01-21 11:13:09 -080025 "github.com/opencord/voltha-lib-go/v3/pkg/log"
26 "github.com/opencord/voltha-protos/v3/go/voltha"
Stephane Barbariea75791c2019-01-24 10:58:06 -050027 "google.golang.org/grpc/codes"
28 "google.golang.org/grpc/status"
Stephane Barbariea75791c2019-01-24 10:58:06 -050029)
30
npujar03b018e2019-11-13 15:29:36 +053031// LogicalDeviceAgent represents logical device agent related information
Stephane Barbariea75791c2019-01-24 10:58:06 -050032type LogicalDeviceAgent struct {
npujar03b018e2019-11-13 15:29:36 +053033 logicalDeviceID string
Stephane Barbariea75791c2019-01-24 10:58:06 -050034 lastData *voltha.LogicalDevice
npujar03b018e2019-11-13 15:29:36 +053035 rootDeviceID string
Stephane Barbariea75791c2019-01-24 10:58:06 -050036 deviceMgr *DeviceManager
37 ldeviceMgr *LogicalDeviceManager
38 clusterDataProxy *model.Proxy
39 exitChannel chan int
40 lockLogicalDevice sync.RWMutex
41}
42
npujar03b018e2019-11-13 15:29:36 +053043func newLogicalDeviceAgent(id string, deviceID string, ldeviceMgr *LogicalDeviceManager, deviceMgr *DeviceManager, cdProxy *model.Proxy) *LogicalDeviceAgent {
Stephane Barbariea75791c2019-01-24 10:58:06 -050044 var agent LogicalDeviceAgent
45 agent.exitChannel = make(chan int, 1)
npujar03b018e2019-11-13 15:29:36 +053046 agent.logicalDeviceID = id
47 agent.rootDeviceID = deviceID
Stephane Barbariea75791c2019-01-24 10:58:06 -050048 agent.deviceMgr = deviceMgr
49 agent.clusterDataProxy = cdProxy
50 agent.ldeviceMgr = ldeviceMgr
51 agent.lockLogicalDevice = sync.RWMutex{}
52 return &agent
53}
54
55// start creates the logical device and add it to the data model
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -050056func (agent *LogicalDeviceAgent) start(ctx context.Context, loadFromDb bool) error {
npujar03b018e2019-11-13 15:29:36 +053057 log.Infow("starting-logical_device-agent", log.Fields{"logicaldeviceID": agent.logicalDeviceID, "loadFromdB": loadFromDb})
Stephane Barbariea75791c2019-01-24 10:58:06 -050058 agent.lockLogicalDevice.Lock()
59 defer agent.lockLogicalDevice.Unlock()
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -050060 if loadFromDb {
61 // load from dB - the logical may not exist at this time. On error, just return and the calling function
62 // will destroy this agent.
Thomas Lee Se5a44012019-11-07 20:32:24 +053063 if logicalDevice, err := agent.clusterDataProxy.Get(ctx, "/logical_devices/"+agent.logicalDeviceID, 0, false, ""); err != nil {
64 log.Errorw("failed-to-get-logical-device", log.Fields{"error": err})
65 return err
66 } else if logicalDevice != nil {
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -050067 if lDevice, ok := logicalDevice.(*voltha.LogicalDevice); ok {
68 agent.lastData = proto.Clone(lDevice).(*voltha.LogicalDevice)
69 }
70 } else {
npujar03b018e2019-11-13 15:29:36 +053071 log.Errorw("failed-to-load-device", log.Fields{"logicaldeviceID": agent.logicalDeviceID})
72 return status.Errorf(codes.NotFound, "logicaldeviceID-%s", agent.logicalDeviceID)
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -050073 }
74 }
Stephane Barbariea75791c2019-01-24 10:58:06 -050075 log.Info("logical_device-agent-started")
76 return nil
77}
78
79// stop terminates the logical device agent.
80func (agent *LogicalDeviceAgent) stop(ctx context.Context) {
81 log.Info("stopping-logical_device-agent")
82 agent.lockLogicalDevice.Lock()
83 defer agent.lockLogicalDevice.Unlock()
84 //Remove the logical device from the model
85 agent.exitChannel <- 1
86 log.Info("logical_device-agent-stopped")
87}
88
89// GetLogicalDevice locks the logical device model and then retrieves the latest logical device information
90func (agent *LogicalDeviceAgent) GetLogicalDevice() (*voltha.LogicalDevice, error) {
91 log.Debug("GetLogicalDevice")
92 agent.lockLogicalDevice.Lock()
93 defer agent.lockLogicalDevice.Unlock()
Thomas Lee Se5a44012019-11-07 20:32:24 +053094 if logicalDevice, err := agent.clusterDataProxy.Get(context.Background(), "/logical_devices/"+agent.logicalDeviceID, 0, false, ""); err != nil {
95 log.Errorw("failed-to-get-logical-device", log.Fields{"error": err})
96 return nil, err
97 } else if logicalDevice != nil {
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -050098 if lDevice, ok := logicalDevice.(*voltha.LogicalDevice); ok {
99 return lDevice, nil
100 }
Stephane Barbariea75791c2019-01-24 10:58:06 -0500101 }
npujar03b018e2019-11-13 15:29:36 +0530102 return nil, status.Errorf(codes.NotFound, "logical_device-%s", agent.logicalDeviceID)
Stephane Barbariea75791c2019-01-24 10:58:06 -0500103}
104
npujar03b018e2019-11-13 15:29:36 +0530105// ListLogicalDevicePorts returns all logical device ports details
Stephane Barbariea75791c2019-01-24 10:58:06 -0500106func (agent *LogicalDeviceAgent) ListLogicalDevicePorts() (*voltha.LogicalPorts, error) {
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -0500107 log.Debug("ListLogicalDevicePorts")
npujar03b018e2019-11-13 15:29:36 +0530108 if logicalDevice, _ := agent.ldeviceMgr.getLogicalDevice(agent.logicalDeviceID); logicalDevice != nil {
Stephane Barbariea75791c2019-01-24 10:58:06 -0500109 lPorts := make([]*voltha.LogicalPort, 0)
npujar03b018e2019-11-13 15:29:36 +0530110 lPorts = append(lPorts, logicalDevice.Ports...)
Stephane Barbariea75791c2019-01-24 10:58:06 -0500111 return &voltha.LogicalPorts{Items: lPorts}, nil
112 }
npujar03b018e2019-11-13 15:29:36 +0530113 return nil, status.Errorf(codes.NotFound, "logical_device-%s", agent.logicalDeviceID)
Stephane Barbariea75791c2019-01-24 10:58:06 -0500114}
115
npujar03b018e2019-11-13 15:29:36 +0530116// ListLogicalDeviceFlows - listFlows locks the logical device model and then retrieves the latest flow information
Stephane Barbariea75791c2019-01-24 10:58:06 -0500117func (agent *LogicalDeviceAgent) ListLogicalDeviceFlows() (*voltha.Flows, error) {
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -0500118 log.Debug("ListLogicalDeviceFlows")
npujar03b018e2019-11-13 15:29:36 +0530119 if logicalDevice, _ := agent.ldeviceMgr.getLogicalDevice(agent.logicalDeviceID); logicalDevice != nil {
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -0500120 return logicalDevice.GetFlows(), nil
Stephane Barbariea75791c2019-01-24 10:58:06 -0500121 }
npujar03b018e2019-11-13 15:29:36 +0530122 return nil, status.Errorf(codes.NotFound, "logical_device-%s", agent.logicalDeviceID)
Stephane Barbariea75791c2019-01-24 10:58:06 -0500123}
124
npujar03b018e2019-11-13 15:29:36 +0530125// ListLogicalDeviceFlowGroups - listFlowGroups locks the logical device model and then retrieves the latest flow groups information
Stephane Barbariea75791c2019-01-24 10:58:06 -0500126func (agent *LogicalDeviceAgent) ListLogicalDeviceFlowGroups() (*voltha.FlowGroups, error) {
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -0500127 log.Debug("ListLogicalDeviceFlowGroups")
npujar03b018e2019-11-13 15:29:36 +0530128 if logicalDevice, _ := agent.ldeviceMgr.getLogicalDevice(agent.logicalDeviceID); logicalDevice != nil {
Stephane Barbarie1e28f3e2019-02-08 15:45:20 -0500129 return logicalDevice.GetFlowGroups(), nil
Stephane Barbariea75791c2019-01-24 10:58:06 -0500130 }
npujar03b018e2019-11-13 15:29:36 +0530131 return nil, status.Errorf(codes.NotFound, "logical_device-%s", agent.logicalDeviceID)
Stephane Barbariea75791c2019-01-24 10:58:06 -0500132}