gns3-server/gns3server/modules/dynamips/nios/nio_tap.py

77 lines
2.0 KiB
Python
Raw Normal View History

2013-12-22 00:42:33 +00:00
# -*- coding: utf-8 -*-
#
# Copyright (C) 2013 GNS3 Technologies Inc.
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# 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/>.
"""
Interface for TAP NIOs (UNIX based OSes only).
"""
2015-02-10 01:24:13 +00:00
import asyncio
2013-12-22 00:42:33 +00:00
from .nio import NIO
import logging
log = logging.getLogger(__name__)
2013-12-22 00:42:33 +00:00
2015-02-12 02:21:34 +00:00
class NIOTAP(NIO):
2015-02-13 13:43:28 +00:00
2013-12-22 00:42:33 +00:00
"""
Dynamips TAP NIO.
2014-02-28 04:50:46 +00:00
:param hypervisor: Dynamips hypervisor instance
2013-12-22 00:42:33 +00:00
:param tap_device: TAP device name (e.g. tap0)
"""
_instance_count = 0
def __init__(self, hypervisor, tap_device):
2015-02-13 22:11:14 +00:00
# create an unique ID and name
nio_id = NIOTAP._instance_count
2015-02-12 02:21:34 +00:00
NIOTAP._instance_count += 1
2015-02-13 22:11:14 +00:00
name = 'nio_tap' + str(nio_id)
2013-12-22 00:42:33 +00:00
self._tap_device = tap_device
2015-04-08 17:17:34 +00:00
super().__init__(name, hypervisor)
2013-12-22 00:42:33 +00:00
@classmethod
def reset(cls):
"""
Reset the instance count.
"""
cls._instance_count = 0
2015-02-10 01:24:13 +00:00
@asyncio.coroutine
def create(self):
yield from self._hypervisor.send("nio create_tap {name} {tap}".format(name=self._name, tap=self._tap_device))
log.info("NIO TAP {name} created with device {device}".format(name=self._name, device=self._tap_device))
2013-12-22 00:42:33 +00:00
@property
def tap_device(self):
"""
Returns the TAP device used by this NIO.
:returns: the TAP device name
"""
return self._tap_device
2015-02-13 22:11:14 +00:00
def __json__(self):
return {"type": "nio_tap",
"tap_device": self._tap_device}