Skip to content
Snippets Groups Projects
Commit 3bdd9f54 authored by Lluis Gifre Renom's avatar Lluis Gifre Renom
Browse files

Common tools - Context Queries:

- Added get_connection_by_id and get_connection_by_uuid methods
- Updated old get_service method to get_service_by_id and get_service_by_uuid
- Updated get_service method to use new SelectService context method and filter options
- Updated old get_slice method to get_slice_by_id and get_slice_by_uuid
- Updated get_slice method to use new SelectSlice context method and filter options
- Updated get_device method to use new SelectDevice context method and filter options
parent fb3b9f74
No related branches found
No related tags found
2 merge requests!142Release TeraFlowSDN 2.1,!87Context & Device Performance Enhancements
# Copyright 2022-2023 ETSI TeraFlowSDN - TFS OSG (https://tfs.etsi.org/)
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import grpc, logging
from typing import Optional
from common.proto.context_pb2 import Connection, ConnectionId
from context.client.ContextClient import ContextClient
LOGGER = logging.getLogger(__name__)
def get_connection_by_id(
context_client : ContextClient, connection_id : ConnectionId, rw_copy : bool = False
) -> Optional[Connection]:
try:
ro_connection : Connection = context_client.GetConnection(connection_id)
if not rw_copy: return ro_connection
rw_connection = Connection()
rw_connection.CopyFrom(ro_connection)
return rw_connection
except grpc.RpcError as e:
if e.code() != grpc.StatusCode.NOT_FOUND: raise # pylint: disable=no-member
#connection_uuid = connection_id.connection_uuid.uuid
#LOGGER.exception('Unable to get connection({:s})'.format(str(connection_uuid)))
return None
def get_connection_by_uuid(
context_client : ContextClient, connection_uuid : str, rw_copy : bool = False
) -> Optional[Connection]:
# pylint: disable=no-member
connection_id = ConnectionId()
connection_id.connection_uuid.uuid = connection_uuid
return get_connection_by_id(context_client, connection_id, rw_copy=rw_copy)
...@@ -14,23 +14,34 @@ ...@@ -14,23 +14,34 @@
import grpc, logging import grpc, logging
from typing import List, Optional, Set from typing import List, Optional, Set
from common.proto.context_pb2 import ContextId, Device, DeviceId, Empty, Topology, TopologyId from common.proto.context_pb2 import ContextId, Device, DeviceFilter, Empty, Topology, TopologyId
from common.tools.object_factory.Topology import json_topology_id from common.tools.object_factory.Topology import json_topology_id
from context.client.ContextClient import ContextClient from context.client.ContextClient import ContextClient
LOGGER = logging.getLogger(__name__) LOGGER = logging.getLogger(__name__)
def get_device(context_client : ContextClient, device_uuid : str, rw_copy : bool = False) -> Optional[Device]: def get_device(
context_client : ContextClient, device_uuid : str, rw_copy : bool = False,
include_endpoints : bool = True, include_config_rules : bool = True, include_components : bool = True
) -> Optional[Device]:
device_filter = DeviceFilter()
device_id = device_filter.device_ids.device_ids.add() # pylint: disable=no-member
device_id.device_uuid.uuid = device_uuid
device_filter.include_endpoints = include_endpoints
device_filter.include_config_rules = include_config_rules
device_filter.include_components = include_components
try: try:
# pylint: disable=no-member ro_devices = context_client.SelectDevice(device_filter)
device_id = DeviceId() if len(ro_devices.devices) == 0: return None
device_id.device_uuid.uuid = device_uuid assert len(ro_devices.devices) == 1
ro_device = context_client.GetDevice(device_id) ro_device = ro_devices.devices[0]
if not rw_copy: return ro_device if not rw_copy: return ro_device
rw_device = Device() rw_device = Device()
rw_device.CopyFrom(ro_device) rw_device.CopyFrom(ro_device)
return rw_device return rw_device
except grpc.RpcError: except grpc.RpcError as e:
if e.code() != grpc.StatusCode.NOT_FOUND: raise # pylint: disable=no-member
#LOGGER.exception('Unable to get Device({:s})'.format(str(device_uuid))) #LOGGER.exception('Unable to get Device({:s})'.format(str(device_uuid)))
return None return None
......
...@@ -15,25 +15,43 @@ ...@@ -15,25 +15,43 @@
import grpc, logging import grpc, logging
from typing import Optional from typing import Optional
from common.Constants import DEFAULT_CONTEXT_NAME from common.Constants import DEFAULT_CONTEXT_NAME
from common.proto.context_pb2 import Service, ServiceId from common.proto.context_pb2 import Service, ServiceFilter, ServiceId
from context.client.ContextClient import ContextClient from context.client.ContextClient import ContextClient
LOGGER = logging.getLogger(__name__) LOGGER = logging.getLogger(__name__)
def get_service( def get_service_by_id(
context_client : ContextClient, service_uuid : str, context_uuid : str = DEFAULT_CONTEXT_NAME, context_client : ContextClient, service_id : ServiceId, rw_copy : bool = False,
rw_copy : bool = False include_endpoint_ids : bool = True, include_constraints : bool = True, include_config_rules : bool = True
) -> Optional[Service]: ) -> Optional[Service]:
service_filter = ServiceFilter()
service_filter.service_ids.service_ids.append(service_id) # pylint: disable=no-member
service_filter.include_endpoint_ids = include_endpoint_ids
service_filter.include_constraints = include_constraints
service_filter.include_config_rules = include_config_rules
try: try:
# pylint: disable=no-member ro_services = context_client.SelectService(service_filter)
service_id = ServiceId() if len(ro_services.services) == 0: return None
service_id.context_id.context_uuid.uuid = context_uuid assert len(ro_services.services) == 1
service_id.service_uuid.uuid = service_uuid ro_service = ro_services.services[0]
ro_service = context_client.GetService(service_id)
if not rw_copy: return ro_service if not rw_copy: return ro_service
rw_service = Service() rw_service = Service()
rw_service.CopyFrom(ro_service) rw_service.CopyFrom(ro_service)
return rw_service return rw_service
except grpc.RpcError: except grpc.RpcError as e:
if e.code() != grpc.StatusCode.NOT_FOUND: raise # pylint: disable=no-member
#LOGGER.exception('Unable to get service({:s} / {:s})'.format(str(context_uuid), str(service_uuid))) #LOGGER.exception('Unable to get service({:s} / {:s})'.format(str(context_uuid), str(service_uuid)))
return None return None
def get_service_by_uuid(
context_client : ContextClient, service_uuid : str, context_uuid : str = DEFAULT_CONTEXT_NAME,
rw_copy : bool = False, include_endpoint_ids : bool = True, include_constraints : bool = True,
include_config_rules : bool = True
) -> Optional[Service]:
service_id = ServiceId()
service_id.context_id.context_uuid.uuid = context_uuid # pylint: disable=no-member
service_id.service_uuid.uuid = service_uuid # pylint: disable=no-member
return get_service_by_id(
context_client, service_id, rw_copy=rw_copy, include_endpoint_ids=include_endpoint_ids,
include_constraints=include_constraints, include_config_rules=include_config_rules)
...@@ -15,25 +15,47 @@ ...@@ -15,25 +15,47 @@
import grpc, logging import grpc, logging
from typing import Optional from typing import Optional
from common.Constants import DEFAULT_CONTEXT_NAME from common.Constants import DEFAULT_CONTEXT_NAME
from common.proto.context_pb2 import Slice, SliceId from common.proto.context_pb2 import Slice, SliceFilter, SliceId
from context.client.ContextClient import ContextClient from context.client.ContextClient import ContextClient
LOGGER = logging.getLogger(__name__) LOGGER = logging.getLogger(__name__)
def get_slice( def get_slice_by_id(
context_client : ContextClient, slice_uuid : str, context_uuid : str = DEFAULT_CONTEXT_NAME, context_client : ContextClient, slice_id : SliceId, rw_copy : bool = False, include_endpoint_ids : bool = True,
rw_copy : bool = False include_constraints : bool = True, include_service_ids : bool = True, include_subslice_ids : bool = True,
) -> Optional[Slice]: include_config_rules : bool = True
) -> Optional[Slice]:
slice_filter = SliceFilter()
slice_id = slice_filter.slice_ids.slice_ids.append(slice_id) # pylint: disable=no-member
slice_filter.include_endpoint_ids = include_endpoint_ids
slice_filter.include_constraints = include_constraints
slice_filter.include_service_ids = include_service_ids
slice_filter.include_subslice_ids = include_subslice_ids
slice_filter.include_config_rules = include_config_rules
try: try:
# pylint: disable=no-member ro_slices = context_client.SelectSlice(slice_filter)
slice_id = SliceId() if len(ro_slices.slices) == 0: return None
slice_id.context_id.context_uuid.uuid = context_uuid assert len(ro_slices.slices) == 1
slice_id.slice_uuid.uuid = slice_uuid ro_slice = ro_slices.slices[0]
ro_slice = context_client.GetSlice(slice_id)
if not rw_copy: return ro_slice if not rw_copy: return ro_slice
rw_slice = Slice() rw_slice = Slice()
rw_slice.CopyFrom(ro_slice) rw_slice.CopyFrom(ro_slice)
return rw_slice return rw_slice
except grpc.RpcError: except grpc.RpcError as e:
if e.code() != grpc.StatusCode.NOT_FOUND: raise # pylint: disable=no-member
#LOGGER.exception('Unable to get slice({:s} / {:s})'.format(str(context_uuid), str(slice_uuid))) #LOGGER.exception('Unable to get slice({:s} / {:s})'.format(str(context_uuid), str(slice_uuid)))
return None return None
def get_slice_by_uuid(
context_client : ContextClient, slice_uuid : str, context_uuid : str = DEFAULT_CONTEXT_NAME,
rw_copy : bool = False, include_endpoint_ids : bool = True, include_constraints : bool = True,
include_service_ids : bool = True, include_subslice_ids : bool = True, include_config_rules : bool = True
) -> Optional[Slice]:
slice_id = SliceId()
slice_id.context_id.context_uuid.uuid = context_uuid # pylint: disable=no-member
slice_id.slice_uuid.uuid = slice_uuid # pylint: disable=no-member
return get_slice_by_id(
context_client, slice_id, rw_copy=rw_copy, include_endpoint_ids=include_endpoint_ids,
include_constraints=include_constraints, include_service_ids=include_service_ids,
include_subslice_ids=include_subslice_ids, include_config_rules=include_config_rules)
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment