PyJamfPro is a basic Python wrapper for synchronous communication with the Jamf Pro (and/or Classic) API. The goal is to simplify the process of communicating with the Jamf Pro device management server API by handling authentication and decoding, allowing you to focus on using the data, not retrieving it.
PyJamfPro is not endorsed, sponsored, or affilitated with Jamf in any way.
Begin by installing the PyJamfPro module, using pip
.
pip install pyjamfpro
In your code, simply import the PyJamfPro module and instantiate a new client object. The constructor requires three arguments:
- base_url - the base URL of your Jamf Pro server
- client_id
- client_secret
- Note: PyJamfPro uses Client Credentials with your Jamf Pro server. You will need to ensure an API Client has been created with the correct permissions for the actions you would like to perform with the API.
from pyjamfpro import jamfpro
client = jamfpro.Client('https://example.jamfserver.com', 'client_id', 'client_secret')
Once you have a client, you can start making synchronous calls to the API.
# returns list of all mobile devices, using the Classic API
devices = client.classic_mobile_devices()
# returns a dictionary of inventory data for the mobile device with ID 1234,
# using the Classic API
device = client.classic_mobile_device_for_id(1234)
# returns a list of all computers, using the Jamf Pro API
computers = client.pro_computers()
Refer to the endpoints.py
file for other built-in methods. Additionally, you can use the make_api_request
method to access any Jamf API endpoint. Full support for GET, POST, PUT, and DELETE are included.
If you have a feature or idea you would like to see added to PyJamPro, please create an issue explaining your idea.
Likewise, if you come across a bug, please create an issue explaining the bug with as much detail as possible.
The Jamf Pro API provides access to a lot of information and, unfortunately, we don't have time to research and implement every endpoint. Please feel free to open a pull request with any additional endpoints you create. We would love to have as many of the core endpoints covered as possible.
PyJamPro is released under an MIT license. See LICENSE for more information.