Module to provide Palo Alto compatibility to Salt
Spencer Ervin <spencer_ervin@hotmail.com>
new
none
unix
New in version 2018.3.0.
This module accepts connection configuration details either as parameters, or as configuration settings in pillar as a Salt proxy. Options passed into opts will be ignored if options are passed into pillar.
See also
This execution module was designed to handle connections to a Palo Alto based firewall. This module adds support to send connections directly to the device through the XML API or through a brokered connection to Panorama.
salt.modules.panos.
add_config_lock
()Prevent other users from changing configuration until the lock is released.
CLI Example:
salt '*' panos.add_config_lock
salt.modules.panos.
check_antivirus
()Get anti-virus information from PaloAlto Networks server
CLI Example:
salt '*' panos.check_antivirus
salt.modules.panos.
check_software
()Get software information from PaloAlto Networks server.
CLI Example:
salt '*' panos.check_software
salt.modules.panos.
clear_commit_tasks
()Clear all commit tasks.
CLI Example:
salt '*' panos.clear_commit_tasks
salt.modules.panos.
commit
()Commits the candidate configuration to the running configuration.
CLI Example:
salt '*' panos.commit
salt.modules.panos.
deactivate_license
(key_name=None)Deactivates an installed license. Required version 7.0.0 or greater.
key_name(str): The file name of the license key installed.
CLI Example:
salt '*' panos.deactivate_license key_name=License_File_Name.key
salt.modules.panos.
delete_license
(key_name=None)Remove license keys on disk.
key_name(str): The file name of the license key to be deleted.
CLI Example:
salt '*' panos.delete_license key_name=License_File_Name.key
salt.modules.panos.
download_antivirus
()Download the most recent anti-virus package.
CLI Example:
salt '*' panos.download_antivirus
salt.modules.panos.
download_software_file
(filename=None, synch=False)Download software packages by filename.
CLI Example:
salt '*' panos.download_software_file PanOS_5000-8.0.0
salt '*' panos.download_software_file PanOS_5000-8.0.0 True
salt.modules.panos.
download_software_version
(version=None, synch=False)Download software packages by version number.
CLI Example:
salt '*' panos.download_software_version 8.0.0
salt '*' panos.download_software_version 8.0.0 True
salt.modules.panos.
fetch_license
(auth_code=None)Get new license(s) using from the Palo Alto Network Server.
The license authorization code.
CLI Example:
salt '*' panos.fetch_license
salt '*' panos.fetch_license auth_code=foobar
salt.modules.panos.
get_address
(address=None, vsys='1')Get the candidate configuration for the specified get_address object. This will not return address objects that are marked as pre-defined objects.
address(str): The name of the address object.
vsys(str): The string representation of the VSYS ID.
CLI Example:
salt '*' panos.get_address myhost
salt '*' panos.get_address myhost 3
salt.modules.panos.
get_address_group
(addressgroup=None, vsys='1')Get the candidate configuration for the specified address group. This will not return address groups that are marked as pre-defined objects.
addressgroup(str): The name of the address group.
vsys(str): The string representation of the VSYS ID.
CLI Example:
salt '*' panos.get_address_group foobar
salt '*' panos.get_address_group foobar 3
salt.modules.panos.
get_admins_active
()Show active administrators.
CLI Example:
salt '*' panos.get_admins_active
salt.modules.panos.
get_admins_all
()Show all administrators.
CLI Example:
salt '*' panos.get_admins_all
salt.modules.panos.
get_antivirus_info
()Show information about available anti-virus packages.
CLI Example:
salt '*' panos.get_antivirus_info
salt.modules.panos.
get_cli_idle_timeout
()Show timeout information for this administrative session.
CLI Example:
salt '*' panos.get_cli_idle_timeout
salt.modules.panos.
get_cli_permissions
()Show cli administrative permissions.
CLI Example:
salt '*' panos.get_cli_permissions
salt.modules.panos.
get_disk_usage
()Report filesystem disk space usage.
CLI Example:
salt '*' panos.get_disk_usage
salt.modules.panos.
get_dns_server_config
()Get the DNS server configuration from the candidate configuration.
CLI Example:
salt '*' panos.get_dns_server_config
salt.modules.panos.
get_domain_config
()Get the domain name configuration from the candidate configuration.
CLI Example:
salt '*' panos.get_domain_config
salt.modules.panos.
get_dos_blocks
()Show the DoS block-ip table.
CLI Example:
salt '*' panos.get_dos_blocks
salt.modules.panos.
get_fqdn_cache
()Print FQDNs used in rules and their IPs.
CLI Example:
salt '*' panos.get_fqdn_cache
salt.modules.panos.
get_ha_config
()Get the high availability configuration.
CLI Example:
salt '*' panos.get_ha_config
salt.modules.panos.
get_ha_link
()Show high-availability link-monitoring state.
CLI Example:
salt '*' panos.get_ha_link
salt.modules.panos.
get_ha_path
()Show high-availability path-monitoring state.
CLI Example:
salt '*' panos.get_ha_path
salt.modules.panos.
get_ha_state
()Show high-availability state information.
CLI Example:
salt '*' panos.get_ha_state
salt.modules.panos.
get_ha_transitions
()Show high-availability transition statistic information.
CLI Example:
salt '*' panos.get_ha_transitions
salt.modules.panos.
get_hostname
()Get the hostname of the device.
CLI Example:
salt '*' panos.get_hostname
salt.modules.panos.
get_interface_counters
(name='all')Get the counter statistics for interfaces.
name (str) -- The name of the interface to view. By default, all interface statistics are viewed.
CLI Example:
salt '*' panos.get_interface_counters
salt '*' panos.get_interface_counters ethernet1/1
salt.modules.panos.
get_interfaces
(name='all')Show interface information.
name (str) -- The name of the interface to view. By default, all interface statistics are viewed.
CLI Example:
salt '*' panos.get_interfaces
salt '*' panos.get_interfaces ethernet1/1
salt.modules.panos.
get_job
(jid=None)List all a single job by ID.
The ID of the job to retrieve.
CLI Example:
salt '*' panos.get_job jid=15
salt.modules.panos.
get_jobs
(state='all')List all jobs on the device.
The state of the jobs to display. Valid options are all, pending, or processed. Pending jobs are jobs that are currently in a running or waiting state. Processed jobs are jobs that have completed execution.
CLI Example:
salt '*' panos.get_jobs
salt '*' panos.get_jobs state=pending
salt.modules.panos.
get_license_info
()Show information about owned license(s).
CLI Example:
salt '*' panos.get_license_info
salt.modules.panos.
get_license_tokens
()Show license token files for manual license deactivation.
CLI Example:
salt '*' panos.get_license_tokens
salt.modules.panos.
get_lldp_config
()Show lldp config for interfaces.
CLI Example:
salt '*' panos.get_lldp_config
salt.modules.panos.
get_lldp_counters
()Show lldp counters for interfaces.
CLI Example:
salt '*' panos.get_lldp_counters
salt.modules.panos.
get_lldp_local
()Show lldp local info for interfaces.
CLI Example:
salt '*' panos.get_lldp_local
salt.modules.panos.
get_lldp_neighbors
()Show lldp neighbors info for interfaces.
CLI Example:
salt '*' panos.get_lldp_neighbors
salt.modules.panos.
get_local_admins
()Show all local administrator accounts.
CLI Example:
salt '*' panos.get_local_admins
salt.modules.panos.
get_logdb_quota
()Report the logdb quotas.
CLI Example:
salt '*' panos.get_logdb_quota
salt.modules.panos.
get_master_key
()Get the master key properties.
CLI Example:
salt '*' panos.get_master_key
salt.modules.panos.
get_ntp_config
()Get the NTP configuration from the candidate configuration.
CLI Example:
salt '*' panos.get_ntp_config
salt.modules.panos.
get_ntp_servers
()Get list of configured NTP servers.
CLI Example:
salt '*' panos.get_ntp_servers
salt.modules.panos.
get_operational_mode
()Show device operational mode setting.
CLI Example:
salt '*' panos.get_operational_mode
salt.modules.panos.
get_panorama_status
()Show panorama connection status.
CLI Example:
salt '*' panos.get_panorama_status
salt.modules.panos.
get_permitted_ips
()Get the IP addresses that are permitted to establish management connections to the device.
CLI Example:
salt '*' panos.get_permitted_ips
salt.modules.panos.
get_platform
()Get the platform model information and limitations.
CLI Example:
salt '*' panos.get_platform
salt.modules.panos.
get_predefined_application
(application=None)Get the configuration for the specified pre-defined application object. This will only return pre-defined application objects.
application(str): The name of the pre-defined application object.
CLI Example:
salt '*' panos.get_predefined_application saltstack
salt.modules.panos.
get_security_rule
(rulename=None, vsys='1')Get the candidate configuration for the specified security rule.
rulename(str): The name of the security rule.
vsys(str): The string representation of the VSYS ID.
CLI Example:
salt '*' panos.get_security_rule rule01
salt '*' panos.get_security_rule rule01 3
salt.modules.panos.
get_service
(service=None, vsys='1')Get the candidate configuration for the specified service object. This will not return services that are marked as pre-defined objects.
service(str): The name of the service object.
vsys(str): The string representation of the VSYS ID.
CLI Example:
salt '*' panos.get_service tcp-443
salt '*' panos.get_service tcp-443 3
salt.modules.panos.
get_service_group
(servicegroup=None, vsys='1')Get the candidate configuration for the specified service group. This will not return service groups that are marked as pre-defined objects.
servicegroup(str): The name of the service group.
vsys(str): The string representation of the VSYS ID.
CLI Example:
salt '*' panos.get_service_group foobar
salt '*' panos.get_service_group foobar 3
salt.modules.panos.
get_session_info
()Show device session statistics.
CLI Example:
salt '*' panos.get_session_info
salt.modules.panos.
get_snmp_config
()Get the SNMP configuration from the device.
CLI Example:
salt '*' panos.get_snmp_config
salt.modules.panos.
get_software_info
()Show information about available software packages.
CLI Example:
salt '*' panos.get_software_info
salt.modules.panos.
get_system_date_time
()Get the system date/time.
CLI Example:
salt '*' panos.get_system_date_time
salt.modules.panos.
get_system_files
()List important files in the system.
CLI Example:
salt '*' panos.get_system_files
salt.modules.panos.
get_system_info
()Get the system information.
CLI Example:
salt '*' panos.get_system_info
salt.modules.panos.
get_system_services
()Show system services.
CLI Example:
salt '*' panos.get_system_services
salt.modules.panos.
get_system_state
(mask=None)Show the system state variables.
Filters by a subtree or a wildcard.
CLI Example:
salt '*' panos.get_system_state
salt '*' panos.get_system_state mask=cfg.ha.config.enabled
salt '*' panos.get_system_state mask=cfg.ha.*
salt.modules.panos.
get_uncommitted_changes
()Retrieve a list of all uncommitted changes on the device. Requires PANOS version 8.0.0 or greater.
CLI Example:
salt '*' panos.get_uncommitted_changes
salt.modules.panos.
get_users_config
()Get the local administrative user account configuration.
CLI Example:
salt '*' panos.get_users_config
salt.modules.panos.
get_xpath
(xpath='')Retrieve a specified xpath from the candidate configuration.
xpath(str): The specified xpath in the candidate configuration.
CLI Example:
salt '*' panos.get_xpath /config/shared/service
salt.modules.panos.
get_zone
(zone='', vsys='1')Get the candidate configuration for the specified zone.
zone(str): The name of the zone.
vsys(str): The string representation of the VSYS ID.
CLI Example:
salt '*' panos.get_zone trust
salt '*' panos.get_zone trust 2
salt.modules.panos.
get_zones
(vsys='1')Get all the zones in the candidate configuration.
vsys(str): The string representation of the VSYS ID.
CLI Example:
salt '*' panos.get_zones
salt '*' panos.get_zones 2
salt.modules.panos.
install_antivirus
(version=None, latest=False, synch=False, skip_commit=False)Install anti-virus packages.
version (str) -- The version of the PANOS file to install.
latest (bool) -- If true, the latest anti-virus file will be installed. The specified version option will be ignored.
synch (bool) -- If true, the anti-virus will synch to the peer unit.
skip_commit (bool) -- If true, the install will skip committing to the device.
CLI Example:
salt '*' panos.install_antivirus 8.0.0
salt.modules.panos.
install_license
()Install the license key(s).
CLI Example:
salt '*' panos.install_license
salt.modules.panos.
install_software
(version=None)Upgrade to a software package by version.
version (str) -- The version of the PANOS file to install.
CLI Example:
salt '*' panos.install_license 8.0.0
salt.modules.panos.
refresh_fqdn_cache
(force=False)Force refreshes all FQDNs used in rules.
Forces all fqdn refresh
CLI Example:
salt '*' panos.refresh_fqdn_cache
salt '*' panos.refresh_fqdn_cache force=True
salt.modules.panos.
remove_config_lock
()Release config lock previously held.
CLI Example:
salt '*' panos.remove_config_lock
salt.modules.panos.
resolve_address
(address=None, vsys=None)Resolve address to ip address. Required version 7.0.0 or greater.
Address name you want to resolve.
The vsys name.
CLI Example:
salt '*' panos.resolve_address foo.bar.com
salt '*' panos.resolve_address foo.bar.com vsys=2
salt.modules.panos.
save_device_config
(filename=None)Save device configuration to a named file.
The filename to save the configuration to.
CLI Example:
salt '*' panos.save_device_config foo.xml
salt.modules.panos.
save_device_state
()Save files needed to restore device to local disk.
CLI Example:
salt '*' panos.save_device_state
salt.modules.panos.
set_authentication_profile
(profile=None, deploy=False)Set the authentication profile of the Palo Alto proxy minion. A commit will be required before this is processed.
CLI Example:
salt '*' panos.set_authentication_profile foo
salt '*' panos.set_authentication_profile foo deploy=True
salt.modules.panos.
set_hostname
(hostname=None, deploy=False)Set the hostname of the Palo Alto proxy minion. A commit will be required before this is processed.
CLI Example:
salt '*' panos.set_hostname newhostname
salt '*' panos.set_hostname newhostname deploy=True
salt.modules.panos.
set_management_http
(enabled=True, deploy=False)Enables or disables the HTTP management service on the device.
CLI Example:
salt '*' panos.set_management_http
salt '*' panos.set_management_http enabled=False deploy=True
salt.modules.panos.
set_management_https
(enabled=True, deploy=False)Enables or disables the HTTPS management service on the device.
CLI Example:
salt '*' panos.set_management_https
salt '*' panos.set_management_https enabled=False deploy=True
salt.modules.panos.
set_management_icmp
(enabled=True, deploy=False)Enables or disables the ICMP management service on the device.
CLI Example:
salt '*' panos.set_management_icmp
salt '*' panos.set_management_icmp enabled=False deploy=True
salt.modules.panos.
set_management_ocsp
(enabled=True, deploy=False)Enables or disables the HTTP OCSP management service on the device.
CLI Example:
salt '*' panos.set_management_ocsp
salt '*' panos.set_management_ocsp enabled=False deploy=True
salt.modules.panos.
set_management_snmp
(enabled=True, deploy=False)Enables or disables the SNMP management service on the device.
CLI Example:
salt '*' panos.set_management_snmp
salt '*' panos.set_management_snmp enabled=False deploy=True
salt.modules.panos.
set_management_ssh
(enabled=True, deploy=False)Enables or disables the SSH management service on the device.
CLI Example:
salt '*' panos.set_management_ssh
salt '*' panos.set_management_ssh enabled=False deploy=True
salt.modules.panos.
set_management_telnet
(enabled=True, deploy=False)Enables or disables the Telnet management service on the device.
CLI Example:
salt '*' panos.set_management_telnet
salt '*' panos.set_management_telnet enabled=False deploy=True
salt.modules.panos.
set_ntp_authentication
(target=None, authentication_type=None, key_id=None, authentication_key=None, algorithm=None, deploy=False)Set the NTP authentication of the Palo Alto proxy minion. A commit will be required before this is processed.
CLI Example:
target (str) -- Determines the target of the authentication. Valid options are primary, secondary, or both.
authentication_type (str) -- The authentication type to be used. Valid options are symmetric, autokey, and none.
key_id (int) -- The NTP authentication key ID.
authentication_key (str) -- The authentication key.
algorithm (str) -- The algorithm type to be used for a symmetric key. Valid options are md5 and sha1.
deploy (bool) -- If true then commit the full candidate configuration, if false only set pending change.
salt '*' ntp.set_authentication target=both authentication_type=autokey
salt '*' ntp.set_authentication target=primary authentication_type=none
salt '*' ntp.set_authentication target=both authentication_type=symmetric key_id=15 authentication_key=mykey algorithm=md5
salt '*' ntp.set_authentication target=both authentication_type=symmetric key_id=15 authentication_key=mykey algorithm=md5 deploy=True
salt.modules.panos.
set_ntp_servers
(primary_server=None, secondary_server=None, deploy=False)Set the NTP servers of the Palo Alto proxy minion. A commit will be required before this is processed.
CLI Example:
salt '*' ntp.set_servers 0.pool.ntp.org 1.pool.ntp.org
salt '*' ntp.set_servers primary_server=0.pool.ntp.org secondary_server=1.pool.ntp.org
salt '*' ntp.ser_servers 0.pool.ntp.org 1.pool.ntp.org deploy=True
salt.modules.panos.
set_permitted_ip
(address=None, deploy=False)Add an IPv4 address or network to the permitted IP list.
CLI Example:
salt '*' panos.set_permitted_ip 10.0.0.1
salt '*' panos.set_permitted_ip 10.0.0.0/24
salt '*' panos.set_permitted_ip 10.0.0.1 deploy=True
salt.modules.panos.
set_timezone
(tz=None, deploy=False)Set the timezone of the Palo Alto proxy minion. A commit will be required before this is processed.
CLI Example:
salt '*' panos.set_timezone UTC
salt '*' panos.set_timezone UTC deploy=True
salt.modules.panos.
test_fib_route
(ip=None, vr='vr1')Perform a route lookup within active route table (fib).
ip (str): The destination IP address to test.
vr (str): The name of the virtual router to test.
CLI Example:
salt '*' panos.test_fib_route 4.2.2.2
salt '*' panos.test_fib_route 4.2.2.2 my-vr
salt.modules.panos.
test_security_policy
(sourcezone=None, destinationzone=None, source=None, destination=None, protocol=None, port=None, application=None, category=None, vsys='1', allrules=False)Checks which security policy as connection will match on the device.
sourcezone (str): The source zone matched against the connection.
destinationzone (str): The destination zone matched against the connection.
source (str): The source address. This must be a single IP address.
destination (str): The destination address. This must be a single IP address.
protocol (int): The protocol number for the connection. This is the numerical representation of the protocol.
port (int): The port number for the connection.
application (str): The application that should be matched.
category (str): The category that should be matched.
vsys (int): The numerical representation of the VSYS ID.
allrules (bool): Show all potential match rules until first allow rule.
CLI Example:
salt '*' panos.test_security_policy sourcezone=trust destinationzone=untrust protocol=6 port=22
salt '*' panos.test_security_policy sourcezone=trust destinationzone=untrust protocol=6 port=22 vsys=2