Source code for nepi.resources.linux.gretunnel

#
#    NEPI, a framework to manage network experiments
#    Copyright (C) 2013 INRIA
#
#    This program is free software: you can redistribute it and/or modify
#    it under the terms of the GNU General Public License version 2 as
#    published by the Free Software Foundation;
#
#    This program is distributed in the hope that it will be useful,
#    but WITHOUT ANY WARRANTY; without even the implied warranty of
#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#    GNU General Public License for more details.
#
#    You should have received a copy of the GNU General Public License
#    along with this program.  If not, see <http://www.gnu.org/licenses/>.
#
# Author: Alina Quereilhac <alina.quereilhac@inria.fr>

from nepi.execution.attribute import Attribute, Flags, Types
from nepi.execution.resource import clsinit_copy, ResourceState
from nepi.resources.linux.tunnel import LinuxTunnel
from nepi.util.sshfuncs import ProcStatus
from nepi.util.timefuncs import tnow, tdiffsec

import re
import socket
import time
import os

@clsinit_copy
[docs]class LinuxGRETunnel(LinuxTunnel): _rtype = "linux::GRETunnel" _help = "Constructs a tunnel between two Linux endpoints using a UDP connection "
[docs] def log_message(self, msg): return " guid %d - GRE tunnel %s - %s - %s " % (self.guid, self.endpoint1.node.get("hostname"), self.endpoint2.node.get("hostname"), msg)
[docs] def get_endpoints(self): """ Returns the list of RM that are endpoints to the tunnel """ connected = [] for guid in self.connections: rm = self.ec.get_resource(guid) if hasattr(rm, "gre_connect"): connected.append(rm) return connected
[docs] def initiate_connection(self, endpoint, remote_endpoint): # Return the command to execute to initiate the connection to the # other endpoint connection_run_home = self.run_home(endpoint) connection_app_home = self.app_home(endpoint) data = endpoint.gre_connect(remote_endpoint, connection_app_home, connection_run_home) return data
[docs] def establish_connection(self, endpoint, remote_endpoint, data): pass
[docs] def verify_connection(self, endpoint, remote_endpoint): remote_ip = socket.gethostbyname(remote_endpoint.node.get("hostname")) command = "ping -c 4 %s" % remote_ip (out, err), proc = endpoint.node.execute(command, blocking = True) m = re.search("(\d+)% packet loss", str(out)) if not m or int(m.groups()[0]) == 100: msg = " Error establishing GRE Tunnel" self.error(msg, out, err) raise RuntimeError, msg
[docs] def terminate_connection(self, endpoint, remote_endpoint): pass
[docs] def check_state_connection(self): pass
[docs] def valid_connection(self, guid): # TODO: Validate! return True