gns3-server/gns3server/modules/nios/nio.py

77 lines
2.0 KiB
Python
Raw Normal View History

2015-01-24 01:33:49 +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/>.
"""
Base interface for NIOs.
"""
class NIO(object):
2015-01-31 21:34:49 +00:00
2015-01-24 01:33:49 +00:00
"""
2015-02-16 19:08:04 +00:00
IOU NIO.
2015-01-24 01:33:49 +00:00
"""
def __init__(self):
self._capturing = False
self._pcap_output_file = ""
2015-02-16 19:08:04 +00:00
self._pcap_data_link_type = ""
2015-01-24 01:33:49 +00:00
2015-02-16 19:08:04 +00:00
def startPacketCapture(self, pcap_output_file, pcap_data_link_type="DLT_EN10MB"):
2015-01-24 01:33:49 +00:00
"""
:param pcap_output_file: PCAP destination file for the capture
2015-02-16 19:08:04 +00:00
:param pcap_data_link_type: PCAP data link type (DLT_*), default is DLT_EN10MB
2015-01-24 01:33:49 +00:00
"""
self._capturing = True
self._pcap_output_file = pcap_output_file
2015-02-16 19:08:04 +00:00
self._pcap_data_link_type = pcap_data_link_type
2015-01-24 01:33:49 +00:00
def stopPacketCapture(self):
self._capturing = False
self._pcap_output_file = ""
2015-02-16 19:08:04 +00:00
self._pcap_data_link_type = ""
2015-01-24 01:33:49 +00:00
@property
def capturing(self):
"""
Returns either a capture is configured on this NIO.
:returns: boolean
"""
return self._capturing
@property
def pcap_output_file(self):
"""
Returns the path to the PCAP output file.
:returns: path to the PCAP output file
"""
return self._pcap_output_file
2015-02-16 19:08:04 +00:00
@property
def pcap_data_link_type(self):
"""
Returns the PCAP data link type
:returns: PCAP data link type (DLT_* value)
"""
return self._pcap_data_link_type