Fixed overzealous firewall hostname checking
Checking is now done only on the core-admin-client side; there's no reason to reject rules that would be valid from core-admin-client side. fixes QubesOS/qubes-issues#5943
This commit is contained in:
parent
a6a7560bab
commit
f8c19ca984
@ -31,55 +31,12 @@ class FirewallModifiedOutsideError(ValueError):
|
||||
pass
|
||||
|
||||
|
||||
class QIPAddressValidator(QtGui.QValidator):
|
||||
# pylint: disable=too-few-public-methods
|
||||
def __init__(self, parent=None):
|
||||
super(QIPAddressValidator, self).__init__(parent)
|
||||
|
||||
def validate(self, input_string, pos):
|
||||
# pylint: disable=too-many-return-statements,no-self-use
|
||||
hostname = str(input_string)
|
||||
|
||||
if len(hostname) > 255 or not hostname:
|
||||
return QtGui.QValidator.Intermediate, input_string, pos
|
||||
|
||||
if hostname == "*":
|
||||
return QtGui.QValidator.Acceptable, input_string, pos
|
||||
|
||||
unmask = hostname.split("/", 1)
|
||||
if len(unmask) == 2:
|
||||
hostname = unmask[0]
|
||||
mask = unmask[1]
|
||||
if mask.isdigit() or mask == "":
|
||||
if re.match(r"^([0-9]{1,3}\.){3}[0-9]{1,3}$", hostname) is None:
|
||||
return QtGui.QValidator.Invalid, input_string, pos
|
||||
if mask != "":
|
||||
mask = int(unmask[1])
|
||||
if mask < 0 or mask > 32:
|
||||
return QtGui.QValidator.Invalid, input_string, pos
|
||||
else:
|
||||
return QtGui.QValidator.Invalid, input_string, pos
|
||||
|
||||
if hostname[-1:] == ".":
|
||||
hostname = hostname[:-1]
|
||||
|
||||
if hostname[-1:] == "-":
|
||||
return QtGui.QValidator.Intermediate, input_string, pos
|
||||
|
||||
allowed = re.compile(r"(?!-)[A-Z\d-]{1,63}(?<!-)$", re.IGNORECASE)
|
||||
if all(allowed.match(x) for x in hostname.split(".")):
|
||||
return QtGui.QValidator.Acceptable, input_string, pos
|
||||
|
||||
return QtGui.QValidator.Invalid, input_string, pos
|
||||
|
||||
|
||||
class NewFwRuleDlg(QtWidgets.QDialog, ui_newfwruledlg.Ui_NewFwRuleDlg):
|
||||
def __init__(self, parent=None):
|
||||
super(NewFwRuleDlg, self).__init__(parent)
|
||||
self.setupUi(self)
|
||||
|
||||
self.set_ok_state(False)
|
||||
self.addressComboBox.setValidator(QIPAddressValidator())
|
||||
self.addressComboBox.editTextChanged.connect(
|
||||
self.address_editing_finished)
|
||||
self.serviceComboBox.setValidator(QtGui.QRegExpValidator(
|
||||
@ -94,8 +51,8 @@ class NewFwRuleDlg(QtWidgets.QDialog, ui_newfwruledlg.Ui_NewFwRuleDlg):
|
||||
|
||||
def try_to_create_rule(self):
|
||||
# return True if successful, False otherwise
|
||||
address = str(self.addressComboBox.currentText())
|
||||
service = str(self.serviceComboBox.currentText())
|
||||
address = str(self.addressComboBox.currentText().strip())
|
||||
service = str(self.serviceComboBox.currentText().strip())
|
||||
|
||||
rule = qubesadmin.firewall.Rule(None, action='accept')
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user