Newer
Older
# Copyright 2021-2023 H2020 TeraFlow (https://www.teraflow-h2020.eu/)
#
# 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 logging, socket
from common.Constants import DEFAULT_CONTEXT_UUID
from common.Settings import get_setting
from interdomain.Config import GRPC_SERVICE_PORT
from interdomain.client.InterdomainClient import InterdomainClient
from interdomain.proto.context_pb2 import TeraFlowController
LOGGER = logging.getLogger(__name__)
class RemoteDomainClients:
def __init__(self) -> None:
self.peer_domain = {}
def add_peer(
self, domain_name : str, host : str, port : int, context_uuid : str = DEFAULT_CONTEXT_UUID
) -> None:
while True:
try:
remote_teraflow_ip = socket.gethostbyname(host)
if len(remote_teraflow_ip) > 0: break
except socket.gaierror as e:
if str(e) == '[Errno -2] Name or service not known': continue
interdomain_client = InterdomainClient(host=host, port=port)
request = TeraFlowController()
request.context_id.context_uuid.uuid = DEFAULT_CONTEXT_UUID # pylint: disable=no-member
request.ip_address = get_setting('INTERDOMAINSERVICE_SERVICE_HOST', default='0.0.0.0')
request.port = int(get_setting('INTERDOMAINSERVICE_SERVICE_PORT_GRPC', default=GRPC_SERVICE_PORT))
reply = interdomain_client.Authenticate(request)
if not reply.authenticated:
msg = 'Authentication against {:s}:{:d} rejected'
raise Exception(msg.format(str(remote_teraflow_ip), GRPC_SERVICE_PORT))
self.peer_domain[domain_name] = interdomain_client
def get_peer(self, domain_name : str) -> InterdomainClient:
LOGGER.warning('peers: {:s}'.format(str(self.peer_domain)))
return self.peer_domain.get(domain_name)
def remove_peer(self, domain_name : str) -> None:
return self.peer_domain.pop(domain_name, None)