Commit Graph

374 Commits

Author SHA1 Message Date
Pim van Pelt
b4c5a8d337 Only mock config for vppcfg plan 2023-07-05 17:50:02 +02:00
Pim van Pelt
2396b96252 bugfix: add 'err' scoped exception 2023-06-23 00:52:44 +02:00
Pim van Pelt
6975757303 Merge ACL plugin work so-far 2023-06-23 00:50:19 +02:00
Pim van Pelt
91122c70a4 acl: add dumper for acls
A reasonable attempt will be made to shorten the output of terms, but
due to the nature of the ACL plugin in VPP, all ACLs will be unrolled
into their individual ACEs (called 'terms').

- src/dst-port will only be emitted with UDP/TCP
- icmp-typc/code will only be emitted with ICMP/ICMPv6
- icmp-code/type and source/destination-ports ranges will be collapsed
  where appropriate.
- if protocol is 0, only L3 information will be emitted

NOTE: a bug in the VPP plugin will allow for ICMP 'sport' and 'dport'
upper value to be 16 bits. If an ACE is retrieved from the dataplane
regarding an ICMP or ICMPv6 (referring the 16 bit values to icmp type
and code), they will be truncated and a warning issued.
2023-06-23 00:42:24 +02:00
Pim van Pelt
7d615fd338 Set MPLS for loopback and interface. Allow for --novpp and VPP changes 2023-06-23 00:42:08 +02:00
Pim van Pelt
1bebb8d68d acl: add dumper for acls
A reasonable attempt will be made to shorten the output of terms, but
due to the nature of the ACL plugin in VPP, all ACLs will be unrolled
into their individual ACEs (called 'terms').

- src/dst-port will only be emitted with UDP/TCP
- icmp-typc/code will only be emitted with ICMP/ICMPv6
- icmp-code/type and source/destination-ports ranges will be collapsed
  where appropriate.
- if protocol is 0, only L3 information will be emitted

NOTE: a bug in the VPP plugin will allow for ICMP 'sport' and 'dport'
upper value to be 16 bits. If an ACE is retrieved from the dataplane
regarding an ICMP or ICMPv6 (referring the 16 bit values to icmp type
and code), they will be truncated and a warning issued.
2023-06-23 00:41:43 +02:00
Pim van Pelt
28b8ba1485 Protect API calls that are missing, print a warning 2023-06-23 00:40:46 +02:00
Pim van Pelt
603e26a313 Set MPLS for loopback and interface. Allow for --novpp and VPP changes 2023-06-23 00:38:39 +02:00
Pim van Pelt
c7ba451016 Collapse the error messages to force consistency 2023-06-23 00:33:39 +02:00
Pim van Pelt
a4dfbf055f Refuse to work with ACLs if there are duplicate tags -- it means something/somebody has been inserting them outside of vppcfg, and this breaks the requirement that vppcfg.acls. is the same uniquely identified vpp.acl.tag 2023-06-23 00:33:21 +02:00
Pim van Pelt
871e5a7d8b acl: add dumper for acls
A reasonable attempt will be made to shorten the output of terms, but
due to the nature of the ACL plugin in VPP, all ACLs will be unrolled
into their individual ACEs (called 'terms').

- src/dst-port will only be emitted with UDP/TCP
- icmp-typc/code will only be emitted with ICMP/ICMPv6
- icmp-code/type and source/destination-ports ranges will be collapsed
  where appropriate.
- if protocol is 0, only L3 information will be emitted

NOTE: a bug in the VPP plugin will allow for ICMP 'sport' and 'dport'
upper value to be 16 bits. If an ACE is retrieved from the dataplane
regarding an ICMP or ICMPv6 (referring the 16 bit values to icmp type
and code), they will be truncated and a warning issued.
2023-06-23 00:32:51 +02:00
Pim van Pelt
7a69f657db Protect API calls that are missing, print a warning 2023-06-23 00:31:48 +02:00
Pim van Pelt
52864aac2c Add documentation for MPLS on loopback interfaces 2023-06-23 00:31:21 +02:00
Pim van Pelt
1c9590dcce Set MPLS for loopback and interface. Allow for --novpp and VPP changes 2023-06-23 00:31:19 +02:00
Pim van Pelt
9a42cc91c3 Allow MPLS on loopbacks too -- needed for BVIs and such. Add tests. 2023-06-23 00:30:03 +02:00
Pim van Pelt
52b8cb5477 Add MPLS config option and interface.is_mpls()
Also add tests and documentation
2023-06-23 00:30:03 +02:00
najieb
0f27a15bee Update schema.yaml 2023-06-23 00:30:03 +02:00
Pim van Pelt
b442bc1aae Fix some formatting issues 2023-06-23 00:30:03 +02:00
Pim van Pelt
8077d20bc7 Cut 0.0.4 2023-06-23 00:30:03 +02:00
Pim van Pelt
367aad8dbe Add address.get_canonical() and is_canonical()
These functions will take either an IPv4/IPv6 address, or an IPv4/IPv6
prefix, and cast them to their canonical form. Notably for IPv6 addresses,
this means lower case and with the 0-tuples correctly formatted:

2001:DB8::1 becomes 2001:db8::1
2001:db8:0:0::1 becomes 2001:db8::1

This avoids spurious diffs in vppcfg when comparing to the output of the VPP
dataplane.
2023-06-23 00:30:03 +02:00
Pim van Pelt
f961e41ce6 Add address.get_canonical() and is_canonical()
These functions will take either an IPv4/IPv6 address, or an IPv4/IPv6
prefix, and cast them to their canonical form. Notably for IPv6 addresses,
this means lower case and with the 0-tuples correctly formatted:

2001:DB8::1 becomes 2001:db8::1
2001:db8:0:0::1 becomes 2001:db8::1

This avoids spurious diffs in vppcfg when comparing to the output of the VPP
dataplane.
2023-06-23 00:30:03 +02:00
Pim van Pelt
cf5f1f0944 Add device-type, to ensure that plan --novpp generates MTU statements 2023-06-23 00:30:03 +02:00
Pim van Pelt
3249432681 Move to checkout@v3 for node 16 2023-06-23 00:30:03 +02:00
Pim van Pelt
8cf915e873 Bugfix: Run vppcfg plan --novpp cleanly with bondethernet and MAC addresses 2023-06-23 00:30:03 +02:00
Pim van Pelt
d804422f55 Merge pull request #13 from pimvanpelt/mpls_iface
Support MPLS Interfaces
2023-06-23 00:17:57 +02:00
Pim van Pelt
20b29735fc Merge pull request #12 from najieb/main
Update schema.yaml to allow for DPDK interfaces that have hexadecimal names, such as `GigabitEthernetb/0/0`. h/t najieb for the simple fix.
2023-06-23 00:13:06 +02:00
Pim van Pelt
1dc9b4f393 Protect API calls that are missing, print a warning 2023-06-11 18:55:44 +02:00
Pim van Pelt
d274a47888 Add documentation for MPLS on loopback interfaces 2023-06-11 18:45:30 +02:00
Pim van Pelt
0cf4473ca1 Set MPLS for loopback and interface. Allow for --novpp and VPP changes 2023-06-11 18:43:43 +02:00
Pim van Pelt
9efcf345e0 Allow MPLS on loopbacks too -- needed for BVIs and such. Add tests. 2023-06-11 18:18:05 +02:00
Pim van Pelt
4681aec952 Add MPLS config option and interface.is_mpls()
Also add tests and documentation
2023-06-11 18:05:33 +02:00
najieb
7b160c9a82 Update schema.yaml 2023-05-31 10:04:36 +07:00
Pim van Pelt
85e553c437 Fix some formatting issues 2023-05-25 18:32:54 +02:00
Pim van Pelt
d5dbd11d2d Cut 0.0.4 2023-05-25 18:29:52 +02:00
Pim van Pelt
0183822505 Add address.get_canonical() and is_canonical()
These functions will take either an IPv4/IPv6 address, or an IPv4/IPv6
prefix, and cast them to their canonical form. Notably for IPv6 addresses,
this means lower case and with the 0-tuples correctly formatted:

2001:DB8::1 becomes 2001:db8::1
2001:db8:0:0::1 becomes 2001:db8::1

This avoids spurious diffs in vppcfg when comparing to the output of the VPP
dataplane.
2023-05-25 18:29:52 +02:00
Pim van Pelt
abd3b2adbc Add address.get_canonical() and is_canonical()
These functions will take either an IPv4/IPv6 address, or an IPv4/IPv6
prefix, and cast them to their canonical form. Notably for IPv6 addresses,
this means lower case and with the 0-tuples correctly formatted:

2001:DB8::1 becomes 2001:db8::1
2001:db8:0:0::1 becomes 2001:db8::1

This avoids spurious diffs in vppcfg when comparing to the output of the VPP
dataplane.
2023-05-25 18:24:46 +02:00
Pim van Pelt
9d1d8a32d6 Add device-type, to ensure that plan --novpp generates MTU statements 2023-05-25 16:56:53 +02:00
Pim van Pelt
adf4378239 Move to checkout@v3 for node 16 2023-02-25 13:37:42 +01:00
Pim van Pelt
0a0413927a Bugfix: Run vppcfg plan --novpp cleanly with bondethernet and MAC addresses 2023-02-25 13:15:24 +01:00
Pim van Pelt
b890a08c7e Collapse the error messages to force consistency 2023-01-16 22:22:27 +00:00
Pim van Pelt
818c45e09c acl: consistency in error messages, reformatted, and updated unittests 2023-01-16 22:20:41 +00:00
Pim van Pelt
7914659fa5 icmp-type/code also match for proto 58 (ipv6-icmp) 2023-01-16 21:09:08 +00:00
Pim van Pelt
c190dfbd2b Add a warning in case the tag contains ' or " characters 2023-01-16 20:57:49 +00:00
Pim van Pelt
5fd2d0859c Remove dangling file 2023-01-16 19:52:46 +00:00
Pim van Pelt
16e946c92c Copy over the acl.tag into the description when dumping 2023-01-16 19:12:33 +00:00
Pim van Pelt
ace08ac052 Refuse to work with ACLs if there are duplicate tags -- it means something/somebody has been inserting them outside of vppcfg, and this breaks the requirement that vppcfg.acls. is the same uniquely identified vpp.acl.tag 2023-01-16 19:07:04 +00:00
Pim van Pelt
f654e78ed5 Fix pylint warning 2023-01-16 18:00:24 +00:00
Pim van Pelt
02ca2e22cd acl: add dumper for acls
A reasonable attempt will be made to shorten the output of terms, but
due to the nature of the ACL plugin in VPP, all ACLs will be unrolled
into their individual ACEs (called 'terms').

- src/dst-port will only be emitted with UDP/TCP
- icmp-typc/code will only be emitted with ICMP/ICMPv6
- icmp-code/type and source/destination-ports ranges will be collapsed
  where appropriate.
- if protocol is 0, only L3 information will be emitted

NOTE: a bug in the VPP plugin will allow for ICMP 'sport' and 'dport'
upper value to be 16 bits. If an ACE is retrieved from the dataplane
regarding an ICMP or ICMPv6 (referring the 16 bit values to icmp type
and code), they will be truncated and a warning issued.
2023-01-16 17:12:48 +00:00
Pim van Pelt
efef03ea42 address pylint 2023-01-16 14:41:07 +00:00
Pim van Pelt
9a175e1bba Add an ACE with a an example prefixlist 2023-01-16 14:36:05 +00:00