Skip to content

Home

PaloAltoNetworks

pan-os-upgrade, Automating PAN-OS and Panorama Upgrade Workflows

Contributors Forks Stars Issues License


Documentation: https://cdot65.github.io/pan-os-upgrade/

Source Code: https://github.com/cdot65/pan-os-upgrade


pan-os-upgrade is designed to provide network administrators and security professionals with an efficient tool to execute configuration backups, network state snapshots, system readiness checks, and operating system upgrades of Palo Alto Networks firewalls and Panorama appliances.

Key Features

  • Three Unique Upgrade Workflows Supported:
  • firewall: targets and upgrades an individual firewall
  • panorama: targets and upgrades an individual Panorama appliance
  • batch: targets a Panorama appliance and upgrades firewalls in batch
  • Automation of Routine Tasks: Reduces manual errors and saves time by automating upgrades, configurations, and system checks.
  • Support for Direct and Proxy Connections: Connect directly to firewalls or through a Panorama appliance, with support for targeting specific devices using filters.
  • Pre/Post Diff: Network snapshots are taken before and after the upgrade process, providing a PDF report of changes within the network environment after the upgrade completes.
  • Active/Passive and Active/Active High Availability (HA) Workflow: Fully supports upgrading devices in active/passive or active/active HA configurations when executed in batch mode, ensuring both members are properly upgraded and synchronized.
  • Multi-threading for Efficiency: Utilizes multi-threading to parallelize upgrades, especially beneficial when upgrading multiple devices through Panorama, enhancing performance and reducing overall upgrade time.
  • Customizable and Extensible: Execution of the script can be tailored to fit diverse network environments and requirements, offering flexibility for various deployment scenarios.
  • Comprehensive PAN-OS Interactions: Facilitates extensive interactions with Palo Alto Networks appliances for operations like readiness checks, state snapshots, and report generation.

Logic Workflow

You can view the logical workflow of the pan-os-upgrade subcommands by viewing these diagrams:


Execution

There are two primary methods to execute the pan-os-upgrade tool:

  • Python virtual environment
  • Docker container image

Python Virtual Environment Workflow

This approach involves setting up a Python virtual environment and running pan-os-upgrade within this isolated environment, ensuring compatibility and preventing any conflicts with system-wide Python installations.

Python Virtual Environment Features

  • Easy and isolated Python environment setup.
  • Full control over the Python version and dependencies.
  • Ideal for users familiar with Python and virtual environments.

Python Getting Started

Install pan-os-upgrade via pip in a Python virtual environment and configure it using command-line arguments or an interactive shell. Detailed instructions can be found in the User Guide.

Docker Container Workflow

Running pan-os-upgrade in a Docker container encapsulates the tool and its dependencies in an isolated environment, simplifying setup and ensuring consistency across different systems.

Docker Key Features

  • Simplified setup process with Docker.
  • Consistent runtime environment regardless of the host system.
  • Suitable for users who prefer Docker or require containerized environments.

Docker Getting Started

Pull the pan-os-upgrade Docker image, run the container with mounted directories for outputs, and interact with the tool in an isolated environment. More information is available in the User Guide.


Visit the User Guide for detailed insights into setting up and running pan-os-upgrade using either Python or Docker workflows.


Example Execution

โฏ pan-os-upgrade batch
Panorama hostname or IP: panorama1.cdot.io
Panorama username: officehours
Panorama password:
Firewall target version (ex: 10.1.2): 10.1.3-h3
Dry Run? [Y/n]: n
=================================================================================================
Welcome to the PAN-OS upgrade tool

This script software is provided on an 'as-is' basis with no warranties, and no support provided.

The selected `batch` subcommand will upgrade one or more firewalls.

Settings: No settings.yaml file was found, default values will be used.
You can create a settings.yaml file with 'pan-os-upgrade settings' command.

Inventory: No inventory.yaml file was found, firewalls will need be selected through the menu.
You can create an inventory.yaml file with 'pan-os-upgrade inventory' command.
=================================================================================================
๐Ÿš€ panorama1.cdot.io: Connection to the appliance successful.
โœ… panorama1.cdot.io: Connection to Panorama established. Firewall connections will be proxied!
๐Ÿ”ง panorama1.cdot.io: Retrieving a list of all firewalls connected to Panorama...
๐Ÿ”ง panorama1.cdot.io: Retrieving detailed information of each firewall...
โ•’โ•โ•โ•โ•โ•โ•คโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•คโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•คโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•คโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•คโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•คโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•คโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ••
โ”‚   # โ”‚ Hostname   โ”‚ IP Address     โ”‚ Model   โ”‚ PAN-OS    โ”‚ Content   โ”‚ HA Mode   โ”‚ Preempt   โ”‚
โ•žโ•โ•โ•โ•โ•โ•ชโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•ชโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•ชโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•ชโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•ชโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•ชโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•ชโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•ก
โ”‚   1 โ”‚ katy-fw1   โ”‚ 192.168.255.41 โ”‚ PA-VM   โ”‚ 10.1.3-h3 โ”‚ 8799-8509 โ”‚ passive   โ”‚ no        โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚   2 โ”‚ katy-fw2   โ”‚ 192.168.255.42 โ”‚ PA-VM   โ”‚ 10.1.3-h3 โ”‚ 8799-8509 โ”‚ active    โ”‚ no        โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚   3 โ”‚ lab-fw1    โ”‚ 192.168.255.11 โ”‚ PA-VM   โ”‚ 10.1.3    โ”‚ 8729-8157 โ”‚ disabled  โ”‚ N/A       โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚   4 โ”‚ lab-fw2    โ”‚ 192.168.255.12 โ”‚ PA-VM   โ”‚ 10.1.3    โ”‚ 8729-8157 โ”‚ disabled  โ”‚ N/A       โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚   5 โ”‚ lab-fw3    โ”‚ 192.168.255.13 โ”‚ PA-VM   โ”‚ 10.1.3    โ”‚ 8729-8157 โ”‚ disabled  โ”‚ N/A       โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚   6 โ”‚ lab-fw4    โ”‚ 192.168.255.14 โ”‚ PA-VM   โ”‚ 10.1.3    โ”‚ 8729-8157 โ”‚ disabled  โ”‚ N/A       โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚   7 โ”‚ lab-fw5    โ”‚ 192.168.255.15 โ”‚ PA-VM   โ”‚ 10.1.3    โ”‚ 8729-8157 โ”‚ disabled  โ”‚ N/A       โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚   8 โ”‚ lab-fw6    โ”‚ 192.168.255.16 โ”‚ PA-VM   โ”‚ 10.1.4-h4 โ”‚ 8729-8157 โ”‚ active    โ”‚ yes       โ”‚
โ”œโ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค
โ”‚   9 โ”‚ lab-fw7    โ”‚ 192.168.255.17 โ”‚ PA-VM   โ”‚ 10.1.4-h4 โ”‚ 8729-8157 โ”‚ passive   โ”‚ yes       โ”‚
โ•˜โ•โ•โ•โ•โ•โ•งโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•งโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•งโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•งโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•งโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•งโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•งโ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•โ•›
You can select devices by entering their numbers, ranges, or separated by commas.
Examples: '1', '2-4', '1,3,5-7'.
Type 'done' on a new line when finished.

Enter your selection(s): 3-4
  - lab-fw1 selected.
  - lab-fw2 selected.
Enter your selection(s): done
๐Ÿ”ง panorama1.cdot.io: Selected 2 firewalls from inventory.yaml for upgrade.
๐Ÿ“ panorama1.cdot.io: Upgrading 2 devices to version 10.1.3-h3...
๐Ÿ“ panorama1.cdot.io: Please confirm the selected firewalls:
  - lab-fw1 (192.168.255.11)
  - lab-fw2 (192.168.255.12)
๐ŸŸง panorama1.cdot.io: Dry run mode is disabled, upgrade workflow will be executed.
๐Ÿ“ panorama1.cdot.io: Do you want to proceed with the upgrade? [y/N]: y
๐Ÿš€ Proceeding with the upgrade...
๐Ÿš€ Proceeding with the upgrade...
๐Ÿ”ง panorama1.cdot.io: Using 10 threads.
๐Ÿ“ lab-fw1: 007054000654321 192.168.255.41
๐Ÿ“ lab-fw2: 007054000654322 192.168.255.42
๐Ÿ“ lab-fw1: HA mode: active
๐Ÿ“ lab-fw2: HA mode: passive
๐Ÿ“ lab-fw1: Local state: active, Local version: 10.1.3, Peer version: 10.1.3
๐Ÿ“ lab-fw1: Version comparison: equal
๐Ÿ” lab-fw1: Detected active target device in HA pair running the same version as its peer. Added target device to revisit list.
๐Ÿ“ lab-fw2: Local state: passive, Local version: 10.1.3, Peer version: 10.1.3
๐Ÿ“ lab-fw2: Version comparison: equal
๐Ÿ“ lab-fw2: Target device is passive
๐Ÿ“ lab-fw2: Current version: 10.1.3
๐Ÿ“ lab-fw2: Target version: 10.1.3-h3
โœ… lab-fw2: Upgrade required from 10.1.3 to 10.1.3-h3
๐Ÿ”ง lab-fw2: Refreshing list of available software versions
โœ… lab-fw2: version 10.1.3-h3 is available for download
โœ… lab-fw2: Base image for 10.1.3-h3 is already downloaded
๐Ÿš€ lab-fw2: Performing test to see if 10.1.3-h3 is already downloaded.
โœ… lab-fw2: version 10.1.3-h3 already on target device.
โœ… lab-fw2: 10.1.3-h3 has been downloaded and sync'd to HA peer.
๐Ÿš€ lab-fw2: Performing snapshot of network state information.
๐Ÿš€ lab-fw2: Attempting to capture network state snapshot (Attempt 1 of 3).
โœ… lab-fw2: Network snapshot created successfully on attempt 1.
๐Ÿ’พ lab-fw2: Network state snapshot collected and saved to assurance/snapshots/lab-fw2/pre/2024-02-25_04-14-15.json
๐Ÿš€ lab-fw2: Performing readiness checks of target firewall.
๐Ÿš€ lab-fw2: Performing readiness checks to determine if firewall is ready for upgrade.
โœ… lab-fw2: Passed Readiness Check: Check if active support is available
๐ŸŸจ lab-fw2: Skipped Readiness Check: Check if a given ARP entry is available in the ARP table
โœ… lab-fw2: Passed Readiness Check: Check if there are pending changes on device
๐ŸŸจ lab-fw2: Skipped Readiness Check: Check if the certificates' keys meet minimum size requirements
๐ŸŸจ lab-fw2: Skipped Readiness Check: Running Latest Content Version
โœ… lab-fw2: Passed Readiness Check: Check if any Dynamic Update job is scheduled to run within the specified time window
โœ… lab-fw2: Passed Readiness Check: No Expired Licenses
๐ŸŸจ lab-fw2: Skipped Readiness Check: Check if a there is enough space on the `/opt/panrepo` volume for downloading an PanOS image.
โœ… lab-fw2: Passed Readiness Check: Checks HA pair status from the perspective of the current device
๐ŸŸจ lab-fw2: Skipped Readiness Check: Check if a given IPsec tunnel is in active state
๐ŸŸจ lab-fw2: Skipped Readiness Check: Check for any job with status different than FIN
๐ŸŸจ lab-fw2: Skipped Readiness Check: Check if NTP is synchronized
โœ… lab-fw2: Passed Readiness Check: Check if the clock is synchronized between dataplane and management plane
โœ… lab-fw2: Passed Readiness Check: Check connectivity with the Panorama appliance
๐ŸŸจ lab-fw2: Skipped Readiness Check: Check if a critical session is present in the sessions table
โœ… lab-fw2: Readiness Checks completed
๐Ÿš€ lab-fw2: Checking if HA peer is in sync.
โœ… lab-fw2: HA peer sync test has been completed.
๐Ÿš€ lab-fw2: Performing backup of configuration to local filesystem.
๐Ÿ“ lab-fw2: Not a dry run, continue with upgrade.
๐Ÿš€ lab-fw2: Performing upgrade to version 10.1.3-h3.
๐Ÿ“ lab-fw2: The install will take several minutes, check for status details within the GUI.
๐Ÿš€ lab-fw2: Attempting upgrade to version 10.1.3-h3 (Attempt 1 of 3).
Device 007054000654322 installing version: 10.1.3-h3
โœ… lab-fw2: Upgrade completed successfully
๐Ÿš€ lab-fw2: Rebooting the target device.
๐ŸŸง lab-fw2: Retry attempt 1 due to error: 007054000654322 not connected
๐ŸŸง lab-fw2: Retry attempt 2 due to error: 007054000654322 not connected
๐ŸŸง lab-fw2: Retry attempt 3 due to error: 007054000654322 not connected
๐ŸŸง lab-fw2: Retry attempt 4 due to error: 007054000654322 not connected
๐ŸŸง lab-fw2: Retry attempt 5 due to error: 007054000654322 not connected
๐ŸŸง lab-fw2: Retry attempt 6 due to error: 007054000654322 not connected
๐ŸŸง lab-fw2: Retry attempt 7 due to error: 007054000654322 not connected
๐ŸŸง lab-fw2: Retry attempt 8 due to error: 007054000654322 not connected
๐Ÿ“ lab-fw2: Current device version: 10.1.3-h3
โœ… lab-fw2: Device rebooted to the target version successfully.
๐Ÿš€ lab-fw2: Performing backup of configuration to local filesystem.
๐Ÿ”ง lab-fw2: Waiting for the device to become ready for the post upgrade snapshot.
๐Ÿš€ lab-fw2: Performing snapshot of network state information.
๐Ÿš€ lab-fw2: Attempting to capture network state snapshot (Attempt 1 of 3).
โŒ lab-fw2: Error running snapshots: ElementTree.fromstring ParseError: junk after document element: line 1, column 3703
๐Ÿš€ lab-fw2: Attempting to capture network state snapshot (Attempt 1 of 3).
โœ… lab-fw2: Network snapshot created successfully on attempt 1.
๐Ÿ’พ lab-fw2: Network state snapshot collected and saved to assurance/snapshots/lab-fw2/post/2024-02-25_04-32-05.json
๐Ÿ’พ lab-fw2: Snapshot comparison PDF report saved to assurance/snapshots/lab-fw2/diff/2024-02-25_04-32-08_report.pdf
๐Ÿš€ panorama1.cdot.io: Revisiting firewalls that were active in an HA pair and had the same version as their peers.
๐Ÿ“ lab-fw1: 007054000654321 192.168.255.41
๐Ÿ“ lab-fw1: HA mode: active
๐Ÿ“ lab-fw1: Local state: active, Local version: 10.1.3, Peer version: 10.1.3-h3
Waiting for HA synchronization to complete on lab-fw1. Attempt 1/3
HA synchronization complete on lab-fw1. Proceeding with upgrade.
๐Ÿ“ lab-fw1: Version comparison: older
๐Ÿ“ lab-fw1: Target device is on an older version
๐Ÿ“ lab-fw1: Suspending HA state of active
๐ŸŸง lab-fw1: Error received when suspending active target device HA state: argument of type 'NoneType' is not iterable
๐Ÿ“ lab-fw1: Current version: 10.1.3
๐Ÿ“ lab-fw1: Target version: 10.1.3-h3
โœ… lab-fw1: Upgrade required from 10.1.3 to 10.1.3-h3
๐Ÿ”ง lab-fw1: Refreshing list of available software versions
โœ… lab-fw1: version 10.1.3-h3 is available for download
โœ… lab-fw1: Base image for 10.1.3-h3 is already downloaded
๐Ÿš€ lab-fw1: Performing test to see if 10.1.3-h3 is already downloaded.
โœ… lab-fw1: version 10.1.3-h3 already on target device.
โœ… lab-fw1: 10.1.3-h3 has been downloaded and sync'd to HA peer.
๐Ÿš€ lab-fw1: Performing snapshot of network state information.
๐Ÿš€ lab-fw1: Attempting to capture network state snapshot (Attempt 1 of 3).
โœ… lab-fw1: Network snapshot created successfully on attempt 1.
๐Ÿ’พ lab-fw1: Network state snapshot collected and saved to assurance/snapshots/lab-fw1/pre/2024-02-25_04-33-26.json
๐Ÿš€ lab-fw1: Performing readiness checks of target firewall.
๐Ÿš€ lab-fw1: Performing readiness checks to determine if firewall is ready for upgrade.
โœ… lab-fw1: Passed Readiness Check: Check if active support is available
๐ŸŸจ lab-fw1: Skipped Readiness Check: Check if a given ARP entry is available in the ARP table
โœ… lab-fw1: Passed Readiness Check: Check if there are pending changes on device
๐ŸŸจ lab-fw1: Skipped Readiness Check: Check if the certificates' keys meet minimum size requirements
๐ŸŸจ lab-fw1: Skipped Readiness Check: Running Latest Content Version
โœ… lab-fw1: Passed Readiness Check: Check if any Dynamic Update job is scheduled to run within the specified time window
โœ… lab-fw1: Passed Readiness Check: No Expired Licenses
๐ŸŸจ lab-fw1: Skipped Readiness Check: Check if a there is enough space on the `/opt/panrepo` volume for downloading an PanOS image.
๐ŸŸจ lab-fw1: Skipped Readiness Check: Checks HA pair status from the perspective of the current device
๐ŸŸจ lab-fw1: Skipped Readiness Check: Check if a given IPsec tunnel is in active state
๐ŸŸจ lab-fw1: Skipped Readiness Check: Check for any job with status different than FIN
๐ŸŸจ lab-fw1: Skipped Readiness Check: Check if NTP is synchronized
โœ… lab-fw1: Passed Readiness Check: Check if the clock is synchronized between dataplane and management plane
โœ… lab-fw1: Passed Readiness Check: Check connectivity with the Panorama appliance
๐ŸŸจ lab-fw1: Skipped Readiness Check: Check if a critical session is present in the sessions table
โœ… lab-fw1: Readiness Checks completed
๐Ÿš€ lab-fw1: Checking if HA peer is in sync.
โœ… lab-fw1: HA peer sync test has been completed.
๐Ÿš€ lab-fw1: Performing backup of configuration to local filesystem.
๐Ÿ“ lab-fw1: Not a dry run, continue with upgrade.
๐Ÿš€ lab-fw1: Performing upgrade to version 10.1.3-h3.
๐Ÿ“ lab-fw1: The install will take several minutes, check for status details within the GUI.
๐Ÿš€ lab-fw1: Attempting upgrade to version 10.1.3-h3 (Attempt 1 of 3).
Device 007054000654321 installing version: 10.1.3-h3
โœ… lab-fw1: Upgrade completed successfully
๐Ÿš€ lab-fw1: Rebooting the target device.
๐ŸŸง lab-fw1: Retry attempt 1 due to error: 007054000654321 not connected
๐ŸŸง lab-fw1: Retry attempt 2 due to error: 007054000654321 not connected
๐ŸŸง lab-fw1: Retry attempt 3 due to error: 007054000654321 not connected
๐ŸŸง lab-fw1: Retry attempt 4 due to error: 007054000654321 not connected
๐ŸŸง lab-fw1: Retry attempt 5 due to error: 007054000654321 not connected
๐ŸŸง lab-fw1: Retry attempt 6 due to error: 007054000654321 not connected
๐ŸŸง lab-fw1: Retry attempt 7 due to error: 007054000654321 not connected
๐Ÿ“ lab-fw1: Current device version: 10.1.3-h3
โœ… lab-fw1: Device rebooted to the target version successfully.
๐Ÿš€ lab-fw1: Performing backup of configuration to local filesystem.
๐Ÿ”ง lab-fw1: Waiting for the device to become ready for the post upgrade snapshot.
๐Ÿš€ lab-fw1: Performing snapshot of network state information.
๐Ÿš€ lab-fw1: Attempting to capture network state snapshot (Attempt 1 of 3).
โœ… lab-fw1: Network snapshot created successfully on attempt 1.
๐Ÿ’พ lab-fw1: Network state snapshot collected and saved to assurance/snapshots/lab-fw1/post/2024-02-25_04-50-28.json
๐Ÿ’พ lab-fw1: Snapshot comparison PDF report saved to assurance/snapshots/lab-fw1/diff/2024-02-25_04-50-29_report.pdf
โœ… panorama1.cdot.io: Completed revisiting firewalls

Here's an example of the PDF diff report that's generated:

PDF

For more examples and usage scenarios, refer to the Documentation.


Release Notes

Updates with each release are tracked at Release Notes.

Contributing

Contributions are welcome and greatly appreciated. Visit the Contributing page for guidelines on how to contribute.

License

This project is licensed under the Apache 2.0 License - see the License page for details.