Merge remote-tracking branch 'origin/pr/191'
* origin/pr/191: Fixed parsing port ranges in VM settings Better handling of port/service names for VM settings
This commit is contained in:
commit
d5a4ddb7ef
@ -104,18 +104,17 @@ class NewFwRuleDlg(QtGui.QDialog, ui_newfwruledlg.Ui_NewFwRuleDlg):
|
|||||||
"192.168.1.100", "192.168.0.0/16",
|
"192.168.1.100", "192.168.0.0/16",
|
||||||
"*"
|
"*"
|
||||||
]
|
]
|
||||||
displayed_services = [
|
example_services = [
|
||||||
'',
|
'', '22', '80', '1024-1234',
|
||||||
'http', 'https', 'ftp', 'ftps', 'smtp',
|
'http', 'https', 'ftp', 'ftps', 'smtp',
|
||||||
'smtps', 'pop3', 'pop3s', 'imap', 'imaps', 'odmr',
|
'pop3', 'pop3s', 'imap', 'imaps', 'odmr',
|
||||||
'nntp', 'nntps', 'ssh', 'telnet', 'telnets', 'ntp',
|
'nntp', 'nntps', 'ssh', 'telnet', 'telnets', 'ntp',
|
||||||
'snmp', 'ldap', 'ldaps', 'irc', 'ircs', 'xmpp-client',
|
'snmp', 'ldap', 'ldaps', 'irc', 'ircs-u', 'xmpp-client',
|
||||||
'syslog', 'printer', 'nfs', 'x11',
|
'syslog', 'printer', 'nfs', 'x11'
|
||||||
'1024-1234'
|
|
||||||
]
|
]
|
||||||
for address in example_addresses:
|
for address in example_addresses:
|
||||||
self.addressComboBox.addItem(address)
|
self.addressComboBox.addItem(address)
|
||||||
for service in displayed_services:
|
for service in example_services:
|
||||||
self.serviceComboBox.addItem(service)
|
self.serviceComboBox.addItem(service)
|
||||||
|
|
||||||
def address_editing_finished(self):
|
def address_editing_finished(self):
|
||||||
@ -143,8 +142,11 @@ class QubesFirewallRulesModel(QtCore.QAbstractItemModel):
|
|||||||
def __init__(self, parent=None):
|
def __init__(self, parent=None):
|
||||||
QtCore.QAbstractItemModel.__init__(self, parent)
|
QtCore.QAbstractItemModel.__init__(self, parent)
|
||||||
|
|
||||||
self.__column_names = {0: "Address", 1: "Service", 2: "Protocol", }
|
self.__column_names = {0: "Address", 1: "Port/Service", 2: "Protocol", }
|
||||||
self.__services = list()
|
self.__services = list()
|
||||||
|
|
||||||
|
self.port_range_pattern = re.compile(r'\d+-\d+')
|
||||||
|
|
||||||
pattern = re.compile(
|
pattern = re.compile(
|
||||||
r"(?P<name>[a-z][a-z0-9-]+)\s+(?P<port>[0-9]+)/"
|
r"(?P<name>[a-z][a-z0-9-]+)\s+(?P<port>[0-9]+)/"
|
||||||
r"(?P<protocol>[a-z]+)",
|
r"(?P<protocol>[a-z]+)",
|
||||||
@ -176,7 +178,7 @@ class QubesFirewallRulesModel(QtCore.QAbstractItemModel):
|
|||||||
def get_service_name(self, port):
|
def get_service_name(self, port):
|
||||||
for service in self.__services:
|
for service in self.__services:
|
||||||
if str(service[1]) == str(port):
|
if str(service[1]) == str(port):
|
||||||
return service[0]
|
return "{0} ({1})".format(str(port), service[0])
|
||||||
return str(port)
|
return str(port)
|
||||||
|
|
||||||
def get_service_port(self, name):
|
def get_service_port(self, name):
|
||||||
@ -381,7 +383,7 @@ class QubesFirewallRulesModel(QtCore.QAbstractItemModel):
|
|||||||
elif dialog.udp_radio.isChecked():
|
elif dialog.udp_radio.isChecked():
|
||||||
rule.proto = 'udp'
|
rule.proto = 'udp'
|
||||||
|
|
||||||
if '-' in service:
|
if self.port_range_pattern.fullmatch(service):
|
||||||
try:
|
try:
|
||||||
rule.dstports = service
|
rule.dstports = service
|
||||||
except ValueError:
|
except ValueError:
|
||||||
|
@ -53,7 +53,7 @@
|
|||||||
<item row="1" column="0">
|
<item row="1" column="0">
|
||||||
<widget class="QLabel" name="label_4">
|
<widget class="QLabel" name="label_4">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Service</string>
|
<string>Port/Service</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
@ -98,6 +98,9 @@
|
|||||||
</item>
|
</item>
|
||||||
<item row="1" column="1" colspan="3">
|
<item row="1" column="1" colspan="3">
|
||||||
<widget class="QComboBox" name="serviceComboBox">
|
<widget class="QComboBox" name="serviceComboBox">
|
||||||
|
<property name="toolTip">
|
||||||
|
<string><html><head/><body><p>Port/service can be provided as either port number (e.g. 122), port range (1024-1234) or service name (e.g. smtp) . For full list of services known, see /etc/services in dom0.</p></body></html></string>
|
||||||
|
</property>
|
||||||
<property name="editable">
|
<property name="editable">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
</property>
|
</property>
|
||||||
|
Loading…
Reference in New Issue
Block a user