Searching the Help
To search for information in the Help, type a word or phrase in the Search box. When you enter a group of words, OR is inferred. You can use Boolean operators to refine your search.
Results returned are case insensitive. However, results ranking takes case into account and assigns higher scores to case matches. Therefore, a search for "cats" followed by a search for "Cats" would return the same number of Help topics, but the order in which the topics are listed would be different.
Search for | Example | Results |
---|---|---|
A single word | cat
|
Topics that contain the word "cat". You will also find its grammatical variations, such as "cats". |
A phrase. You can specify that the search results contain a specific phrase. |
"cat food" (quotation marks) |
Topics that contain the literal phrase "cat food" and all its grammatical variations. Without the quotation marks, the query is equivalent to specifying an OR operator, which finds topics with one of the individual words instead of the phrase. |
Search for | Operator | Example |
---|---|---|
Two or more words in the same topic |
|
|
Either word in a topic |
|
|
Topics that do not contain a specific word or phrase |
|
|
Topics that contain one string and do not contain another | ^ (caret) |
cat ^ mouse
|
A combination of search types | ( ) parentheses |
|
- Develop
- Overview
- SA Platform API design
- Supported clients
- SA CLI methods
- Python API access with Pytwist
- Automation Platform Extensions (APX)
- Agent Tools
- Microsoft Windows PowerShell-SA integration
- Java RMI clients
- Web Services clients
- Pluggable checks
- Search filter syntax
- Rebuilding the Apache HTTP server and PHP
- Application Configuration
Python API access with Pytwist
Overview of Pytwist
Pytwist is a set of Python libraries that provide access to the SA API from managed servers and custom extensions. (The twist is the internal name for the Web Services Data Access Engine.) For managed servers, you can set up Python scripts that call SA APIs through Pytwist so that end users can invoke the scripts as DSEs or ISM controls. Created by HPE SA Professional Services, custom extensions are Python scripts that run in the Command Engine (way). Pytwist enables custom extensions to access recent additions to the SA data model, such as folders and software policies, which are not accessible from Command Engine scripts.
This topic is intended for developers and consultants who are already familiar with the SA data model, custom extensions, Agents, and the Python programming language.
Setup for Pytwist
Before trying out the examples in this section, make sure that your environment meets the following setup requirements, as detailed in the following sections.
Supported platforms for Pytwist
Pytwist is supported on managed servers and core servers. For a list of operating systems supported for these servers.
Pytwist relies on Python version 2.7.10, the version used by SA Agents and custom extensions.
Unlike Web Services and Java RMI clients, a Pytwist client relies on internal SA libraries. If your client program needs to access the SA API from a server that is not a managed or core server, then use a Web Services or Java RMI client, not Pytwist.
Access requirements for Pytwist
Pytwist needs to access port 1032 of the core server running the Web Services Data Access Engine. By default, the engine listens on port 1032.
Installing Pytwist libraries
The pytwist libraries need not be installed as they are part of the agent libraries.
Pytwist examples
The Python code examples in this section show how to get information from managed servers, create folders, and remediate software policies. Each Pytwist example performs the following operations:
- Import the packages.
When importing objects of the SA API name space, such asFilter
, the path includes the Java package name, preceded bypytwist
. Here are theimport
statements for theget_server_info.py
example:import sys
from pytwist import *
from pytwist.com.opsware.search import Filter - Create the
TwistServer
object:ts = twistserver.TwistServer()
See TwistServer method syntax for information about the method’s arguments. - Get a reference to the service.
The Python package name of the service is the same as the Java package name, but without the leadingopsware.com
. For example, the Javacom.opsware.server.ServerService
package maps to the Pytwistserver.ServerService
:
serverservice = ts.server.ServerService - Invoke the SA API methods of the service:
filter = Filter()
. . .
servers = serverservice.findServerRefs(filter)
. . .
for server in servers: vo = serverservice.getServerVO(server)
. . .
get_server_info.py
This script searches for all managed servers with host names containing the command-line argument. The search method, findServerRefs
, returns an array of references to server persistent objects. For each reference, the getServerVO
method returns the value object (VO), which is the data representation that holds the server’s attributes. Here is the code for the get_server_info.py
script:
#!/opt/opsware/agent/bin/python # get_server_info.py # Search for servers by partial hostname. import sys from pytwist import * from pytwist.com.opsware.search import Filter # Check for the command-line argument. if len(sys.argv) < 2: print "You must specify part of the hostname as the search target." print "Example: " + sys.argv[0] + " " + "opsware.com" sys.exit(2)
# Construct a search filter. filter = Filter() filter.expression = 'device_hostname *=* "%s" ' % (sys.argv[1]) # Create a TwistServer object. ts = twistserver.TwistServer() # Get a reference to ServerService. serverservice = ts.server.ServerService # Perform the search, returning a tuple of references. servers = serverservice.findServerRefs(filter) if len(servers) < 1: print "No matching servers found" sys.exit(3) # For each server found, get the server’s value object (VO) # and print some of the VO’s attributes. for server in servers: vo = serverservice.getServerVO(server) print "Name: " + vo.name print "Management IP: " + vo.managementIP print "OS Version: " + vo.osVersion
create_folder.py
This script creates a folder named /TestA/TestB
by invoking the createPath
method. Note that the path
parameter of createPath
does not contain slashes. Each string element in path
indicates a level in the folder. Next, the script retrieves and prints the names of all folders directly below the root folder. The listing for the create_folder.py
script follows:
#!/opt/opsware/agent/bin/python # create_folder.py # Create a folder in SA. import sys from pytwist import * # Create a TwistServer object. ts = twistserver.TwistServer() # Get a reference to FolderService. folderservice = ts.folder.FolderService # Get a reference to the root folder. rootfolder = folderservice.getRoot() # Construct the path of the new folder. path = 'TestA', 'TestB' # Create the folder /TestA/TestB relative to the root. folderservice.createPath(rootfolder, path) # Get the child folders of the root folder. rootchildren = folderservice.getChildren(rootfolder, 'com.opsware.folder.FolderRef') # Print the names of the child folders. for child in rootchildren: vo = folderservice.getFolderVO(child) print vo.name
remediate_policy.py
This script creates a software policy, attaches it to a server, and then remediates the policy. Several names are hard-coded in the script: the platform, server, and parent folder. Optionally, you can specify the policy name on the command-line, which is convenient if you run the script multiple times. The platform of the software policy must match the OS of the packages contained in the policy. Therefore, if you change the hard-coded platform name, then you also change the name in unitfilter.expression
.
The following listing has several bad line breaks. If you copy this code, be sure to fix the bad line breaks before running it. The comment lines beginning with "NOTE" point out the bad line breaks.
#!/opt/opsware/agent/bin/python # remediate_policy.py # Create, attach, and remediate a software policy. import sys from pytwist import * from pytwist.com.opsware.search import Filter from pytwist.com.opsware.swmgmt import SoftwarePolicyVO # Initialize the names used by this script. foldername = 'TestB' platformname = 'Windows 2003' servername = 'd04.example.com' # If a command-line argument is specified, # use it as the policy name if len(sys.argv) == 2: policyname = sys.argv[1] else: policyname = 'TestPolicyA' # Create a TwistServer object. ts = twistserver.TwistServer() ts.authenticate("SAUser", "SAPassword") # Get the references to the services used by this script. folderservice = ts.folder.FolderService swpolicyservice = ts.swmgmt.SoftwarePolicyService serverservice = ts.server.ServerService unitservice = ts.pkg.UnitService platformservice = ts.device.PlatformService # Search for the folder that will contain the policy. folderfilter = Filter() folderfilter.expression = 'FolderVO.name = %s' % foldername folderrefs = folderservice.findFolderRefs(folderfilter) if len(folderrefs) == 1: parent = folderrefs[0] elif len(folderrefs) < 1: print "No matching folders found." sys.exit(2) else: print "Non-unique folder name: " + foldername sys.exit(3) # Search for the reference to the platform "Windows Server 2003." platformfilter = Filter() platformfilter.objectType = 'platform' # Because the platform name contains spaces, # it’s enclosed in double quotes # NOTE: The following code line has a bad line break. # The assignment statement should be on a single line. platformfilter.expression = 'platform_name = "%s"' % platformname platformrefs = platformservice.findPlatformRefs(platformfilter) if len(platformrefs) == 0: print "No matching platforms found." sys.exit(4) # Search for the references to some software packages. unitfilter = Filter() unitfilter.objectType = 'software_unit' # NOTE: The following code line has a bad line break. # The assignment statement should be on a single line. unitfilter.expression = '((UnitVO.unitType = "MSI") & ( UnitVO.name contains "ismtool" ) & ( software_platform_name = "Windows 2003" ))' unitrefs = unitservice.findUnitRefs(unitfilter) # Create a value object for the new software policy. vo = SoftwarePolicyVO() vo.name = policyname vo.folder = parent vo.platforms = platformrefs vo.softwarePolicyItems = unitrefs # Create the software policy. swpolicyvo = swpolicyservice.create(vo) # Search by hostname for the reference to a managed server. serverfilter = Filter() serverfilter.objectType = 'server' # NOTE: The following code line has a bad line break. # The assignment statement should be on a single line. serverfilter.expression = 'ServerVO.hostname = %s' % servername serverrefs = serverservice.findServerRefs(serverfilter) if len(serverrefs) == 0: print "No matching servers found." sys.exit(5) # Create an array that has a reference to the # newly created policy. swpolicyrefs = [1] swpolicyrefs[0] = swpolicyvo.ref # Attach the software policy to the server. swpolicyservice.attachToPolicies(swpolicyrefs, serverrefs) # Remediate the policy and the server. # NOTE: The following code line has a bad line break. # The assignment statement should be on a single line. jobref = swpolicyservice.startRemediateNow(swpolicyrefs, serverrefs) print "The remediation job ID is %d" % jobref.id
Virtualization Pytwist examples
This section provides examples of creating and deploying virtual machines (VMs) using SA API. For more examples about Virtualization, see the Server Automation Using Guide on the HPE SSO portal.
createVM_WithOSBP.py
This basic example creates a VM on a VMware vCenter using CD boot with static IP configuration.
All properties have not been set in these examples. Please refer to API documentation (javadocs) to understand and set the properties for your use case.
#!/opt/opsware/agent/bin/python
from pytwist import twistserver
from pytwist.com.opsware.locality import CustomerRef, RealmRef
from pytwist.com.opsware.osprov import OSBuildPlanRef
from pytwist.com.opsware.pkg import UnknownPkgRef
from pytwist.com.opsware.v12n import AdapterIPSettings, V12nHypervisorRef, \
V12nHypervisorService, V12nInventoryFolderRef, V12nResourcePoolRef, \
V12nResourcePoolRef, V12nVIManagerService, VirtualCpuConfig,
VirtualDevice, \
VirtualDeviceChangeConfig, VirtualDeviceTypeConstant,
VirtualHardwareConfigSpec, \
VirtualMemoryConfig, VirtualServerCDProvisioningSpec,
VirtualServerComputeSpec, \
VirtualServerConfigSpec, VirtualServerCreateSpec,
VirtualStorageDeviceConstant, \
VirtualStorageDeviceHWConfig
from pytwist.com.opsware.v12n.vmware import V12nDatastoreRef, \
VmwareVirtualInterfaceBacking, VmwareVirtualNicHWConfig, \
VmwareVirtualServerDetails, VmwareVirtualServerStorageSpec, \
VmwareVirtualStorageFileBacking
import time
# This is a bare bones example of creating a Virtual Machine on a VMware
# vCenter while booting from CD with Static IP configuration. It also
# provisions the Virtual Machine with the give OS Build Plan. For more
# detailed information please refer to the java doc. All the properties have
# not been set in the example below, please review the java doc to understand
# and set the properties for your use case.
# This method constructs the create specification to create the Virtual
# Machine and provision it.
def constructCreateSpec():
# Construct VmwareVirtualServerDetails
detail = VmwareVirtualServerDetails()
# Virtual Machine Name
detail.name = "Test VM"
# Description for the Virtual Machine
detail.description = "Sample test create VM"
# This is the key for the guest operating system that will installed on
# the Virtual Machine.
# V12nVIManagerService.getGuestOSList() provides the supported list for
# the given V12n Manager and hypervisor.
detail.guestId = "rhel6Guest"
# This is folder where the VM will reside in you can see the list of
# folders at V12nInventoryFolderService.findV12nInventoryFolderRefs() it
# is the inventory location of the Virtual Machine
folder = V12nInventoryFolderRef(2020001)
detail.inventoryFolderRef = folder
# Configure the number of Virtual processors on the Virtual Machine
cpuConfig = VirtualCpuConfig()
cpuConfig.virtualCpuCount = 1
# Configure the Memory for the Virtual Machine
memoryConfig = VirtualMemoryConfig()
memoryConfig.size = 1024*1024*1024
# Configure NICs
# Construct the virtual device of type network i.e a NIC
virtualNetworkDevice = VirtualDevice()
virtualNetworkDevice.type = VirtualDeviceTypeConstant.NETWORK
# A unique identifier for the virtual device
virtualNetworkDevice.key = "4001"
backingNetwork = VmwareVirtualInterfaceBacking()
# This is the port group that the nic will be assigned to
backingNetwork.portGroup = "VLAN 625"
hwConfigNetwork = VmwareVirtualNicHWConfig()
# The kind of network adapter to use, other options are listed in
# VmwareVirtualNicHWConfig
hwConfigNetwork.adapterType = VmwareVirtualNicHWConfig.E1000
hwConfigNetwork.macAddressIsDynamic = True
virtualNetworkDevice.hwConfig = hwConfigNetwork
virtualNetworkDevice.backingInfo = backingNetwork
virtualNetworkDevice.connected = True
virtualNetworkDevice.startConnected = True
# Configure Hard Disk
virtualDiskDevice = VirtualDevice()
virtualDiskDevice.type = VirtualDeviceTypeConstant.STORAGE
backingStorage = VmwareVirtualStorageFileBacking()
# This is Ref for the data store on the hypervisor where the VM will be
# hosted. The list of datastores associated with the Hypervisors are
# listed at V12nHypervisorService.getV12nHypervisorVO() under storage
# config
dataStoreRef = V12nDatastoreRef(90001)
backingStorage.datastore = dataStoreRef
backingStorage.lazyAllocation = True
hwConfigStorage = VirtualStorageDeviceHWConfig()
hwConfigStorage.capacity = 10*1024*1024*1024
hwConfigStorage.usageType =
VirtualStorageDeviceConstant.USAGE_TYPE_DISK_DRIVE
virtualDiskDevice.hwConfig = hwConfigStorage
virtualDiskDevice.backingInfo = backingStorage
# Add both the virtual devices to be created, i.e. the hard disk and the
# nic
virtualDvcs_toAdd = []
virtualDvcs_toAdd.append(virtualNetworkDevice)
virtualDvcs_toAdd.append(virtualDiskDevice)
deviceChange = VirtualDeviceChangeConfig()
deviceChange.addList = virtualDvcs_toAdd
# Finalize the Config Spec
configSpec = VirtualServerConfigSpec()
configSpec.detail = detail
configSpec.virtualHardware = VirtualHardwareConfigSpec()
configSpec.virtualHardware.cpuConfig = cpuConfig
configSpec.virtualHardware.memoryConfig = memoryConfig
configSpec.virtualHardware.deviceChange = deviceChange
# Constructing the Compute Spec
computeSpec = VirtualServerComputeSpec()
# This is the hypervisor hosting the VM
hypervisorRef = V12nHypervisorRef(2030001)
computeSpec.computeProviderRef = hypervisorRef
# This is resource pool on the hypervisor/cluster that the VM belongs to
# It can be retrieved by using hypervisorVO.children or the Cluster
# children
resourcePool = V12nResourcePoolRef(2040001)
computeSpec.resourcePoolRef = resourcePool
storageSpec = VmwareVirtualServerStorageSpec()
storageSpec.datastore = dataStoreRef
# This example deals with provisioning a VM through CD boot and with
# static IP configuration. The example deals setting the boot ISO and
# network information to be used.
# All the information for this is contained in the
# VirtualServerCDProvisioningSpec
# Set all the network information
gateways =[]
gw ="192.168.135.33"
gateways.append(gw)
dnsServers =[]
dnsServer = "192.168.2.13"
dnsServers.append(dnsServer)
interfaces =[]
interface = AdapterIPSettings()
# Construct the network interface
interface.useDHCP=False
# Note this is the virtual device we have created above, we use the same
# device key to indicate to provisioning which virtual device is to be
# used for provisioning
interface.virtualDeviceKey="4001"
interface.gateways=gateways
interface.ipAddress="192.168.135.45"
interface.netmask="255.255.255.224"
interface.dnsServerList=dnsServers
interfaces.append(interface)
# This is the boot ISO Ref that will be used to get the server into
# maintenance mode
# The name and the id need to match the packages on the core.
# Use the UnitService.findUnitRefs() to find the boot ISO's
bootISORef = UnknownPkgRef(5340001)
bootISORef.name="HPSA_linux_boot_cd.iso"
# The realm assigned to the Virtual Machine will be the realm of the
# Virtualization Service
realmRef = RealmRef(30001)
# The OS Build Plan that needs be run on the Virtual Machine after the VM
# has been created.
osbpRef = OSBuildPlanRef(580001)
provisioningSpec = VirtualServerCDProvisioningSpec()
provisioningSpec.bootISORef = bootISORef
provisioningSpec.interfaces = interfaces
provisioningSpec.realmRef = realmRef
provisioningSpec.oSBuildPlanRef = osbpRef
# Finally put together all the information to be set on the Create
# Specification
createSpec = VirtualServerCreateSpec()
createSpec.configSpec = configSpec
createSpec.computeSpec = computeSpec
createSpec.storageSpec = storageSpec
createSpec.provisioningSpec = provisioningSpec
#Set the customer to be associated with the Virtual Machine
customer = CustomerRef(9)
createSpec.setCustomerRef(customer)
return createSpec
def createVirtualMachine():
twist = twistserver.TwistServer()
twist.authenticate("hp", "opsware")
vmService = twist.v12n.V12nVirtualServerService
createSpec = constructCreateSpec()
jobRef = vmService.startCreate(createSpec,4*60*60,"Sample create
VM",None, None)
createVirtualMachine()
deployVM.py
This basic example shows how to deploy a VM from a VM template on VMware vCenter and customize the guest OS of the deployed VM.
All properties have not been set in these examples. Please refer to API documentation (javadocs) to understand and set the properties for your use case.
#!/opt/opsware/agent/bin/python from pytwist import twistserver from pytwist.com.opsware.locality import CustomerRef, RealmRef from pytwist.com.opsware.osprov import OSBuildPlanRef from pytwist.com.opsware.pkg import UnknownPkgRef from pytwist.com.opsware.v12n import AdapterIPSettings, V12nHypervisorRef, \ V12nHypervisorService, V12nInventoryFolderRef, V12nResourcePoolRef, \ V12nResourcePoolRef, V12nVIManagerService, VirtualCpuConfig, VirtualDevice, \ VirtualDeviceChangeConfig, VirtualDeviceTypeConstant, VirtualHardwareConfigSpec, \ VirtualMemoryConfig, VirtualServerCDProvisioningSpec, VirtualServerComputeSpec, \ VirtualServerConfigSpec, VirtualServerCreateSpec, VirtualStorageDeviceConstant, \ VirtualStorageDeviceHWConfig, V12nVirtualServerTemplateRef, \ VirtualServerCloneSpec, VirtualServerGuestCustomizationSpec from pytwist.com.opsware.v12n.vmware import V12nDatastoreRef, \ VmwareVirtualInterfaceBacking, VmwareVirtualNicHWConfig, \ VmwareVirtualServerDetails, VmwareVirtualServerStorageSpec, \ VmwareVirtualStorageFileBacking import time # This is a bare bones example of deploying a Template VMware vCenter. It # deploys the template and then guest customizes the deployed Virtual Machine. # For more detailed information please refer to the java doc. All the # properties have not been set in the example below, please review the java # doc to understand and set the properties for your use case. # This method constructs the deploy specification to deploy the Template and # customizes it. def constructDeploySpec(sourceTemplateVO): # Construct the Deploy Spec clonespec = VirtualServerCloneSpec() clonespec.computeSpec = VirtualServerComputeSpec() # This is the hypervisor hosting the VM targetHypervisorRef = V12nHypervisorRef(2030001) clonespec.computeSpec.computeProviderRef = targetHypervisorRef computeSpec = VirtualServerComputeSpec() # This is the resource pool on the hypervisor/cluster that the VM belongs to # It can be retrieved by using hypervisorVO.children or the Cluster # children targetResourcePoolRef = V12nResourcePoolRef(2040001) computeSpec.resourcePoolRef = targetResourcePoolRef clonespec.computeSpec.resourcePoolRef = targetResourcePoolRef storageSpec = VmwareVirtualServerStorageSpec() dataStoreRef = V12nDatastoreRef(90001) storageSpec.datastore = dataStoreRef clonespec.storageSpec = storageSpec # Construct VmwareVirtualServerDetails detail = VmwareVirtualServerDetails() # Virtual Machine Name detail.name = "Test Deploy VM" # Description for the Virtual Machine detail.description = "Sample Deploy create VM" # This is the folder where the VM will reside in. You can see the list of # folders at V12nInventoryFolderService.findV12nInventoryFolderRefs(). It # is the inventory location of the Virtual Machine targetFolderRef = V12nInventoryFolderRef(2020001) detail.inventoryFolderRef = targetFolderRef configSpec = VirtualServerConfigSpec() configSpec.detail = detail clonespec.configSpec=configSpec # Create the Guest Customization Spec, this is needed to customized the # deployed VM so that it does not use the network settings and host name # of the source template # In this example all the interfaces are set to DHCP but you can # customize each of the interfaces by either providing static or DHCP # configuration details interfaces = createInterfaces(sourceTemplateVO) # The realm assigned to the Virtual Machine will be the realm of the # Virtualization Service realmRef = RealmRef(30001) clonespec.guestCustomizationSpec = createGuestCustomizationSpec("testDeployVM",realmRef,interfaces) clonespec.setPowerOn(True) # Set the customer to be associated with the Virtual Machine customerRef = CustomerRef(9) clonespec.customerRef = customerRef return clonespec def createGuestCustomizationSpec(newVmNameVal,realmRef,interfaces): gcSpec = VirtualServerGuestCustomizationSpec() gcSpec.computerName = newVmNameVal gcSpec.interfaces = interfaces gcSpec.realmRef = realmRef return gcSpec def createInterfaces(virtualServerVO): interfaces = [] virtualDevices = virtualServerVO.virtualHardware.deviceList vNICs = [vd for vd in virtualDevices if vd.type == VirtualDeviceTypeConstant.NETWORK] for vNIC in vNICs: intf = AdapterIPSettings() intf.useDHCP = True intf.hardwareAddress = vNIC.hwConfig.macAddress intf.virtualDeviceKey = vNIC.key interfaces.append(intf) return interfaces def deployVirtualMachine(): twist = twistserver.TwistServer() twist.authenticate("hp", "opsware") vmTemplateService = twist.v12n.V12nVirtualServerTemplateService vmService = twist.v12n.V12nVirtualServerBaseService sourceTemplateRef = V12nVirtualServerTemplateRef(1520001) sourceTemplateVO = vmService.getV12nVirtualServerBaseVO(sourceTemplateRef) deploySpec = constructDeploySpec(sourceTemplateVO) jobRef = vmTemplateService.startDeploy(sourceTemplateRef,deploySpec,30*60,"Sample Deploy VM",None, None); deployVirtualMachine()
Pytwist details
This section describes the behavior and syntax that is specific to Pytwist.
Authentication modes
The authentication mode of a Pytwist client is important because it affects the SA features and the resources that the client can access. A Pytwist client can run in one of the following modes:
- Authenticated: The client has called the
authenticate(username, password)
method on aTwistServer
object. After calling theauthenticate
method, the client is authorized as the SA user specified by theusername
parameter, much like an end user who logs onto the SA Client. - Not Authenticated: The client has not called the
TwistServer.authenticate
method. On a managed server, the client is authenticated as if it is the device that controls the Agent certificate. When used within a custom extension, a non-authenticated Pytwist client needs access to the Command Engine certificate. For more information on custom extensions and certificates, contact your technical support representative.
TwistServer method syntax
The TwistServer
method configures the connection from the client to the Web Services Data Access Engine. (For sample invocations, see Pytwist examples.) All of the arguments of TwistServer
are optional. The following table lists the default values for the arguments.
Argument |
Description |
Default |
---|---|---|
host |
The hostname to connect to. |
twist |
port |
The port number to connect to. |
1032 |
secure |
Whether to use https for the connection. Allowed values: 1 (true) or 0 (false). |
1 |
ctx |
The SSL context for the connection. |
None. (See also Authentication modes.) |
When the TwistServer
object is created, the client does not establish a connection with the server. Therefore, if a connectivity problem occurs, it is not encountered until the client calls authenticate
or an SA API method.
Error handling
If the TwistServer.authenticate
method or an SA API method encounters a problem, a Python exception is raised. You can catch these exceptions in an except
clause, as in the following example:
# Create the TwistServer object. ts = twistserver.TwistServer(’localhost’) # Authenticate by passing an SA user name and password. try: ts.authenticate(’jdoe’, ’secretpass’) except: print "Authentication failed." sys.exit(2)
Mapping Java package names and data types to Pytwist
The Pytwist interface is for Python, but the SA API is written in Java. Because of the differences between two programming languages a Pytwist client must follow the mapping rules described in this section.
In the SA API documentation, Java package names begin with com.opsware
. When specifying the package name in Pytwist, insert pytwist
at the beginning, for example:
from pytwist.com.opsware.compliance.sco import *
The SA API documentation specifies method parameters and return values as Java data types. The following table shows how to map the Java data types to Python for the API method invocations in Pytwist.
Java data type in SA API |
Python data type in Pytwist |
---|---|
|
An integer 1 for true or the integer 0 for false. |
|
As input parameters to API method calls, object arrays can be either Python tuples or lists. As output from API method calls, object arrays are returned as Python tuples. |
Map |
Dictionary |
|
A |
We welcome your comments!
To open the configured email client on this computer, open an email window.
Otherwise, copy the information below to a web mail client, and send this email to hpe_sa_docs@hpe.com.
Help Topic ID:
Product:
Topic Title:
Feedback: