PaloAltoNetworks/pan-os-php

Add "has.interface" as a filter in type=zone

taddairpanw opened this issue · 1 comments

Is your feature request related to a problem?

I would like to get a list of all the zones in all the templates in a panorama config which do not have an interface assigned to them. I am working with a config where a large migration was performed. This migration had multiple firewalls merged and interfaces consolidated, but many un-needed zones were left in the config as a result of this. These zones are referenced in policy but do not have any interfaces assigned to them, so I would like to remove these "dummy" zones from all policy and delete them from the config. Currently there is no filter to do this in type=zone.

- PAN-OS-PHP version: 2.1.12 [UNIX]
 - /spring/Expedition-Converter/pan-os-php/utils
 - PHP version: 7.4.3 

Describe the solution you'd like

I would like a filter added to the type=zone util, possibly nested under the "object" context, which checks for the existence of an interface assigned to the zone. A simple filter such as 'filter=(object has.interface)' should do the trick, because of the inverse filter logic native to pan-os-php. I could use 'filter=!(object has.interface)' to get the opposite effect.

Describe alternatives you've considered

Currently, I just exported the zones from the templates in question to a CSV file and highlighted all the ones that do not have interfaces. I copied these out to a text file so I can make a big filter for type=rule so I can remove the zones. The above feature request would make it easier to get a list of interface-less zones.

Additional context

Panorama config has thousands of firewall rules spread across multiple device groups. Customer wants these dummy zones gone because it clutters the drop-down menus when selecting zones when making new rules through the GUI.

published with #770