Skip to content

Getting Started with pan-scm-sdk

Welcome to the pan-scm-sdk! This guide will walk you through the initial setup and basic usage of the SDK to interact with Palo Alto Networks Strata Cloud Manager.

Installation

Requirements:

  • Python 3.10 or higher

Install the package via pip:

pip install pan-scm-sdk

Authentication

Before using the SDK, you need to authenticate with Strata Cloud Manager using your client credentials.

Example:

from scm.client import Scm
# Initialize the SCM client with your credentialsapi_client = Scm(
client_id="your_client_id",
client_secret="your_client_secret",
tsg_id="your_tsg_id",
)
# The SCM client is now ready to use
  • client_id: Your OAuth2 client ID.
  • client_secret: Your OAuth2 client secret.
  • tsg_id: Your Tenant Service Group ID.

Basic Usage

The SDK provides classes to manage various configuration objects. Below are examples of how to use the SDK to manage addresses, address groups, and applications.

Managing Addresses

from scm.config.objects import Address
# Create an Address instanceaddress = Address(api_client)
# Create a new addressaddress_data = {
"name": "test-address",
"fqdn": "test.example.com",
"description": "Created via pan-scm-sdk",
"folder": "Texas",
}

new_address = address.create(address_data)
print(f"Created address with ID: {new_address.id}")
# List addressesaddresses = address.list(folder='Prisma Access')
for addr in addresses:
print(f"Address Name: {addr.name}, IP: {addr.ip_netmask or addr.fqdn}")

Managing Address Groups

from scm.config.objects import AddressGroup
# Create an AddressGroup instanceaddress_group = AddressGroup(api_client)
# Create a new address groupaddress_group_data = {
"name": "example-group",
"description": "Test address group",
"static": ["test-address"],
"folder": "Texas",
}

new_group = address_group.create(address_group_data)
print(f"Created address group with ID: {new_group.id}")
# List address groupsgroups = address_group.list(folder='Prisma Access')
for group in groups:
print(f"Address Group Name: {group.name}")

Managing Applications

from scm.config.objects import Application
# Create an Application instanceapplication = Application(api_client)
# Create a new applicationapplication_data = {
"name": "test-app",
"category": "collaboration",
"subcategory": "internet-conferencing",
"technology": "client-server",
"risk": 1,
"description": "Created via pan-scm-sdk",
"ports": ["tcp/80,443"],
"folder": "Texas",
}

new_application = application.create(application_data)
print(f"Created application with ID: {new_application.id}")
# List applicationsapplications = application.list(folder='Prisma Access')
for app in applications:
print(f"Application Name: {app.name}, Category: {app.category}")

Next Steps