F5 Networks Python SDK
This project implements an SDK for the iControl® REST interface for BIG-IP®. Use this library to use python to automate a BIG-IP® via its REST API.
Please see the project documentation on Read the Docs: http://f5-sdk.readthedocs.io.
$ pip install f5-sdk
If you are using a pre-release version you must use the --pre option for the pip command.
from f5.bigip import ManagementRoot # Connect to the BIG-IP mgmt = ManagementRoot("bigip.example.com", "admin", "somepassword") # Get a list of all pools on the BigIP and print their name and their # members' name pools = mgmt.tm.ltm.pools.get_collection() for pool in pools: print pool.name for member in pool.members_s.get_collection(): print member.name # Create a new pool on the BigIP mypool = mgmt.tm.ltm.pools.pool.create(name='mypool', partition='Common') # Load an existing pool and update its description pool_a = mgmt.tm.ltm.pools.pool.load(name='mypool', partition='Common') pool_a.description = "New description" pool_a.update() # Delete a pool if it exists if mgmt.tm.ltm.pools.pool.exists(name='mypool', partition='Common'): pool_b = mgmt.tm.ltm.pools.pool.load(name='mypool', partition='Common') pool_b.delete()
I intend the SDK to be easy to use and easy to hack. These overarching goals have a strong influence on my thinking when I am reviewing contributions, this means it is in their own interest that I make them as explicit as possible!
The original interface specification was given to me by Shawn Wormke, who I believe was influenced by the Jira and Django projects. At the time I was reading Brett Slatkin’s ‘Effective Python’, and I tried to follow its advice where possible.
For list additions assign @zancas as the PR reviewer.
This is a strong contract we offer the consumer of the SDK. If an SDK function is invoked with the call operator () the program is initiating a communication with the device. That communication may fail before reaching the wire, but it has nonetheless been initiated. Conversely, if an SDK user evaluates an SDK expression that DOES NOT invoke the () call operator, then the SDK does NOT initiate a communication with the device. Any extension to the SDK that is not consistent with this contract is unlikely to be incorporated into the supported repository.
The SDK doesn’t decide things for the consumer, it’s simply an interface so that Python programs can manipulate device resources without implementing custom URI/HTTP/network logic. Implications:
e.g. ‘create’ and ‘_create’ XXX add content here.
The SDK intends to provide a rational interface to consumers that does the right thing. This means that one case where it does NOT simply do the stupid thing is when it handles a known idiosyncrasy in the device REST server. For example, some? resources ignore ‘disable’ and ‘enable’ configuration options when they are set to ‘False’. Rather than force a consumer to learn about this quirk in the server, the SDK guesses that ‘“disable”: False’ means ‘“enable”: True’ , and submits that value on the consumers behalf.
Solve the problem concretely and simply, if the same problem arises again, solve it concretely, then take the two concrete solutions and use them as your specification to generate an abstraction. In the SDK this usually goes something like this:
Python API for configuring objects on a BIG-IP® device and gathering information from the device via the REST API.
See the Issues section of Contributing.
Before you open a pull request, your code must have passing pytest unit tests. In addition, you should include a set of functional tests written to use a real BIG-IP device for testing. Information on how to run our set of tests is included below.
We use pytest for our unit tests.
If you haven’t already, install the required test packages listed in requirements.test.txt in your virtual environment.
$ pip install -r requirements.test.txt
Run the tests and produce a coverage report. The --cov-report=html will create a htmlcov/ directory that you can view in your browser to see the missing lines of code.
py.test --cov ./icontrol --cov-report=html open htmlcov/index.html
We use the hacking module for our style checks (installed as part of step 1 in the Unit Test section).
$ flake8 ./
Copyright 2014-2016 F5 Networks Inc.
Licensed under the Apache License, Version 2.0 (the “License”); you may not use this file except in compliance with the License. You may obtain a copy of the License at
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an “AS IS” BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.