summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristian Poessinger <christian@poessinger.com>2020-03-28 16:07:50 +0100
committerGitHub <noreply@github.com>2020-03-28 16:07:50 +0100
commitb53d0e10d0fc7ed9d18833008da1d4a1d2520a78 (patch)
treeea540b08dc630bf2efb01c2b50b54a1deb69fb63
parent792c00a018d0b237996e60845edf8ad970c4afbb (diff)
parent6a13bd7e89566b76f6c7daf09160f697c2af4df1 (diff)
downloadvyos-1x-b53d0e10d0fc7ed9d18833008da1d4a1d2520a78.tar.gz
vyos-1x-b53d0e10d0fc7ed9d18833008da1d4a1d2520a78.zip
Merge pull request #279 from thomas-mangin/T2057-better-mac
ifconfig: T2057: correctly provide the reason why a MAC could not be set
-rw-r--r--python/vyos/validate.py14
1 files changed, 11 insertions, 3 deletions
diff --git a/python/vyos/validate.py b/python/vyos/validate.py
index 48a18642b..0e6d34e7e 100644
--- a/python/vyos/validate.py
+++ b/python/vyos/validate.py
@@ -204,11 +204,19 @@ def assert_mtu(mtu, min=68, max=9000):
def assert_mac(m):
- octets = [int(i, 16) for i in m.split(':')]
+ split = m.split(':')
+ size = len(split)
# a mac address consits out of 6 octets
- if len(octets) != 6:
- raise ValueError(f'wrong number of MAC octets: {octets}')
+ if size != 6:
+ raise ValueError(f'wrong number of MAC octets ({size}): {m}')
+
+ octets = []
+ try:
+ for octet in split:
+ octets.append(int(octet, 16))
+ except ValueError:
+ raise ValueError(f'invalid hex number "{octet}" in : {m}')
# validate against the first mac address byte if it's a multicast
# address