Skip to content

Instantly share code, notes, and snippets.

@pirkla
Last active October 16, 2020 15:00
Show Gist options
  • Save pirkla/1a70b50717053d5ebc3e53567afea3c3 to your computer and use it in GitHub Desktop.
Save pirkla/1a70b50717053d5ebc3e53567afea3c3 to your computer and use it in GitHub Desktop.
#!/usr/bin/env python3
####################################################################################################
#
# Copyright (c) 2021, JAMF Software, LLC. All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
# * Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# * Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
# * Neither the name of the JAMF Software, LLC nor the
# names of its contributors may be used to endorse or promote products
# derived from this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY JAMF SOFTWARE, LLC "AS IS" AND ANY
# EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
# DISCLAIMED. IN NO EVENT SHALL JAMF SOFTWARE, LLC BE LIABLE FOR ANY
# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
####################################################################################################
# This script moves all devices in Jamf School to the same location as the assigned user
# Note: This will not move the device if the user is in the top level location
# To use fill in the correct networkId, apiKey, and baseURL then run the script script
import json
import requests
import datetime
import sys
networkId=''
apiKey=''
baseURL='https://yoururl.jamfschool.com'
r1=requests.get(baseURL +"/api/devices", auth=(networkId,apiKey))
devicesJson = json.loads(r1.text)['devices']
locByUDID = []
for device in devicesJson:
if device['locationId'] != device['owner']['locationId'] and device['owner']['id'] != 0 and device['owner']['locationId'] != 0:
locByUDID.append((device['UDID'],device['owner']['locationId']))
input("Found " + str(len(locByUDID)) + " devices to migrate. Press enter to continue...")
fileName = "failedUdids" + datetime.datetime.now().strftime("%d.%m.%Y-%H:%M:%S") +".csv"
with open(fileName,'w+') as f:
for el in locByUDID:
print("Migrating " + str(el[0]) + " to " + str(el[1]))
jsonData=dict(locationId=el[1],onlyDevice=False)
r2 = requests.put(baseURL + "/api/devices/{udid}/migrate".format(udid=el[0]),auth=(networkId,apiKey),json=jsonData)
if r2.status_code != 200:
print(r2.status_code)
print("uh oh - something went wrong. Cancelling run.")
exit()
result=json.loads(r2.text)
if result['code'] != 200:
f.writelines(el[0]+', ' + result['message'] + ', ' + baseURL + "/devices/details/"+el[0] +'\n')
print("Failed: " + result['message'] + ". UDID recorded in " +fileName)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment