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:
Marek Marczykowski-Górecki 2019-08-02 20:03:35 +02:00
commit d5a4ddb7ef
No known key found for this signature in database
GPG Key ID: 063938BA42CFA724
2 changed files with 16 additions and 11 deletions

View File

@ -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:

View File

@ -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>&lt;html&gt;&lt;head/&gt;&lt;body&gt;&lt;p&gt;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.&lt;/p&gt;&lt;/body&gt;&lt;/html&gt;</string>
</property>
<property name="editable"> <property name="editable">
<bool>true</bool> <bool>true</bool>
</property> </property>