# Author: Alina Quereilhac <alina.quereilhac@inria.fr>
from nepi.execution.attribute import Attribute, Flags, Types
-from nepi.execution.resource import ResourceManager, clsinit_copy, ResourceState, \
+from nepi.execution.resource import clsinit_copy, ResourceState, \
reschedule_delay
from nepi.resources.linux.application import LinuxApplication
from nepi.resources.planetlab.node import PlanetlabNode
import time
# TODO: - routes!!!
-# - Instead of doing an infinite loop, open a port for communication allowing
-# to pass the fd to another process
+# - CREATE GRE - PlanetlabGRE - it only needs to set the gre and remote
+# properties when configuring the vif_up
PYTHON_VSYS_VERSION = "1.0"
"Name of the network interface (e.g. eth0, wlan0, etc)",
flags = Flags.ReadOnly)
- up = Attribute("up", "Link up", type = Types.Bool)
+ up = Attribute("up", "Link up",
+ type = Types.Bool)
- snat = Attribute("snat", "Set SNAT=1", type = Types.Bool,
- flags = Flags.ReadOnly)
+ snat = Attribute("snat", "Set SNAT=1",
+ type = Types.Bool,
+ flags = Flags.ExecReadOnly)
pointopoint = Attribute("pointopoint", "Peer IP address",
- flags = Flags.ReadOnly)
+ flags = Flags.ExecReadOnly)
tear_down = Attribute("tearDown", "Bash script to be executed before " + \
"releasing the resource",
return None
def upload_sources(self):
- depends = "mercurial make gcc"
- self.set("depends", depends)
+ # upload vif-creation python script
+ pl_vif_create = os.path.join(os.path.dirname(__file__), "scripts",
+ "pl-vif-create.py")
- install = ( " ( "
- " python -c 'import vsys, os; vsys.__version__ == \"%(version)s\" or os._exit(1)' "
- " ) "
- " ||"
- " ( "
- " cd ${SRC} ; "
- " hg clone http://nepi.inria.fr/code/python-vsys ; "
- " cd python-vsys ; "
- " make all ; "
- " sudo -S make install "
- " )" ) % ({
- "version": PYTHON_VSYS_VERSION
- })
+ self.node.upload(pl_vif_create,
+ os.path.join(self.node.src_dir, "pl-vif-create.py"),
+ overwrite = False)
- self.set("install", install)
+ # upload vif-stop python script
+ pl_vif_stop = os.path.join(os.path.dirname(__file__), "scripts",
+ "pl-vif-stop.py")
- def upload_start_command(self):
- # upload tap-creation python script
- pl_tap_create = os.path.join(os.path.dirname(__file__), "scripts",
- "pl-tap-create.py")
- self.node.upload(pl_tap_create,
- os.path.join(self.app_home, "pl-vif-create.py"),
+ self.node.upload(pl_vif_stop,
+ os.path.join(self.node.src_dir, "pl-vif-stop.py"),
overwrite = False)
- # upload start.sh
- start_command = self.replace_paths(self._start_command)
-
- self.info("Uploading command '%s'" % start_command)
-
- self.set("command", start_command)
+ # upload vif-connect python script
+ pl_vif_connect = os.path.join(os.path.dirname(__file__), "scripts",
+ "pl-vif-udp-connect.py")
- self.node.upload(start_command,
- os.path.join(self.app_home, "start.sh"),
- text = True,
+ self.node.upload(pl_vif_connect,
+ os.path.join(self.node.src_dir, "pl-vif-udp-connect.py"),
overwrite = False)
- # upload tap-stop python script
- pl_tap_stop = os.path.join(os.path.dirname(__file__), "scripts",
- "pl-tap-stop.py")
- self.node.upload(pl_tap_stop,
- os.path.join(self.app_home, "pl-vif-stop.py"),
+ # upload tun-connect python script
+ tunchannel = os.path.join(os.path.dirname(__file__), "..", "linux",
+ "scripts", "tunchannel.py")
+
+ self.node.upload(tunchannel,
+ os.path.join(self.node.src_dir, "tunchannel.py"),
overwrite = False)
# upload stop.sh script
text = True,
overwrite = False)
+ def upload_start_command(self):
+ super(PlanetlabTap, self).upload_start_command()
+
# We want to make sure the device is up and running
# before the deploy finishes (so things will be ready
# before other stuff starts running).
if not self.node or self.node.state < ResourceState.PROVISIONED:
self.ec.schedule(reschedule_delay, self.deploy)
else:
+ if not self.get("command"):
+ self.set("command", self._start_command)
+
+ if not self.get("depends"):
+ self.set("depends", self._dependencies)
+
+ if not self.get("install"):
+ self.set("install", self._install)
try:
self.discover()
raise
self.debug("----- READY ---- ")
- self._ready_time = tnow()
- self._state = ResourceState.READY
+ self.set_ready()
def start(self):
- if self._state == ResourceState.READY:
+ if self.state == ResourceState.READY:
command = self.get("command")
self.info("Starting command '%s'" % command)
- self._start_time = tnow()
- self._state = ResourceState.STARTED
+ self.set_started()
else:
msg = " Failed to execute command '%s'" % command
self.error(msg, out, err)
- self._state = ResourceState.FAILED
+ self.fail()
raise RuntimeError, msg
def stop(self):
command = self.get('command') or ''
- state = self.state
- if state == ResourceState.STARTED:
+ if self.state == ResourceState.STARTED:
self.info("Stopping command '%s'" % command)
command = "bash %s" % os.path.join(self.app_home, "stop.sh")
(out, err), proc = self.execute_command(command,
blocking = True)
- self._stop_time = tnow()
- self._state = ResourceState.STOPPED
+ self.set_stopped()
@property
def state(self):
if out.strip().find(self.get("deviceName")) == -1:
# tap is not running is not running (socket not found)
+ self._finish_time = tnow()
self._state = ResourceState.FINISHED
self._last_state_check = tnow()
return self._state
+ def release(self):
+ # Node needs to wait until all associated RMs are released
+ # to be released
+ from nepi.resources.linux.udptunnel import UdpTunnel
+ rms = self.get_connected(UdpTunnel.rtype())
+ for rm in rms:
+ if rm.state < ResourceState.STOPPED:
+ self.ec.schedule(reschedule_delay, self.release)
+ return
+
+ super(PlanetlabTap, self).release()
+
def wait_if_name(self):
""" Waits until the if_name file for the command is generated,
- and returns the if_name for the devide """
+ and returns the if_name for the device """
if_name = None
delay = 1.0
return if_name
+ def udp_connect_command(self, remote_ip, local_port_file,
+ remote_port_file, ret_file, cipher, cipher_key,
+ bwlimit, txqueuelen):
+ command = ["sudo -S "]
+ command.append("PYTHONPATH=$PYTHONPATH:${SRC}")
+ command.append("python ${SRC}/pl-vif-udp-connect.py")
+ command.append("-t %s" % self.vif_type)
+ command.append("-S %s " % self.sock_name)
+ command.append("-l %s " % local_port_file)
+ command.append("-r %s " % remote_port_file)
+ command.append("-H %s " % remote_ip)
+ command.append("-R %s " % ret_file)
+ if cipher:
+ command.append("-c %s " % cipher)
+ if cipher_key:
+ command.append("-k %s " % cipher_key)
+ if txqueuelen:
+ command.append("-q %s " % txqueuelen)
+ if bwlimit:
+ command.append("-b %s " % bwlimit)
+
+ command = " ".join(command)
+ command = self.replace_paths(command)
+ return command
+
@property
def _start_command(self):
- command = ["sudo -S python ${APP_HOME}/pl-vif-create.py"]
+ command = ["sudo -S python ${SRC}/pl-vif-create.py"]
command.append("-t %s" % self.vif_type)
command.append("-a %s" % self.get("ip4"))
@property
def _stop_command(self):
- command = ["sudo -S python ${APP_HOME}/pl-vif-stop.py"]
+ command = ["sudo -S python ${SRC}/pl-vif-stop.py"]
command.append("-S %s " % self.sock_name)
return " ".join(command)
def sock_name(self):
return os.path.join(self.run_home, "tap.sock")
+ @property
+ def _dependencies(self):
+ return "mercurial make gcc"
+
+ @property
+ def _install(self):
+ # Install python-vsys and python-passfd
+ install_vsys = ( " ( "
+ " python -c 'import vsys, os; vsys.__version__ == \"%(version)s\" or os._exit(1)' "
+ " ) "
+ " || "
+ " ( "
+ " cd ${SRC} ; "
+ " hg clone http://nepi.inria.fr/code/python-vsys ; "
+ " cd python-vsys ; "
+ " make all ; "
+ " sudo -S make install "
+ " )" ) % ({
+ "version": PYTHON_VSYS_VERSION
+ })
+
+ install_passfd = ( " ( python -c 'import passfd' ) "
+ " || "
+ " ( "
+ " cd ${SRC} ; "
+ " hg clone http://nepi.inria.fr/code/python-passfd ; "
+ " cd python-passfd ; "
+ " make all ; "
+ " sudo -S make install "
+ " )" )
+
+ return "%s ; %s" % ( install_vsys, install_passfd )
+
def valid_connection(self, guid):
# TODO: Validate!
return True