|
|
@ -1,29 +1,59 @@
|
|
|
|
from pathlib import Path
|
|
|
|
from pathlib import Path
|
|
|
|
|
|
|
|
|
|
|
|
from pymobiledevice3.lockdown import LockdownClient
|
|
|
|
from pymobiledevice3.lockdown import LockdownClient
|
|
|
|
from pymobiledevice3.cli.mounter import MobileImageMounterService
|
|
|
|
from pymobiledevice3.cli.mounter import MobileImageMounterService, download_developer_disk_image
|
|
|
|
from pymobiledevice3.cli.developer import DtSimulateLocation
|
|
|
|
from pymobiledevice3.cli.developer import DtSimulateLocation
|
|
|
|
from pymobiledevice3.services.diagnostics import DiagnosticsService
|
|
|
|
from pymobiledevice3.services.diagnostics import DiagnosticsService
|
|
|
|
|
|
|
|
from pymobiledevice3.exceptions import PasscodeRequiredError
|
|
|
|
|
|
|
|
import logging
|
|
|
|
|
|
|
|
from ispoof.utils import get_home_folder
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DEVELOPER_DISK_IMAGE_URL = 'https://github.com/pdso/DeveloperDiskImage/raw/master/{ios_version}/{ios_version}.zip'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class Device():
|
|
|
|
|
|
|
|
|
|
|
|
class Device:
|
|
|
|
def __init__(self):
|
|
|
|
def __init__(self):
|
|
|
|
self.lockdown = LockdownClient()
|
|
|
|
self.lockdown = LockdownClient()
|
|
|
|
self.mounter = MobileImageMounterService(self.lockdown)
|
|
|
|
|
|
|
|
self.diagnostics = DiagnosticsService(self.lockdown)
|
|
|
|
self.diagnostics = DiagnosticsService(self.lockdown)
|
|
|
|
|
|
|
|
self.mounter = None
|
|
|
|
self.location = None
|
|
|
|
self.location = None
|
|
|
|
|
|
|
|
|
|
|
|
def mount_image(self, image_path, signature_path):
|
|
|
|
def mount_image(self):
|
|
|
|
image_type = "Developer"
|
|
|
|
try:
|
|
|
|
|
|
|
|
self.mounter = MobileImageMounterService(self.lockdown)
|
|
|
|
|
|
|
|
except PasscodeRequiredError as e:
|
|
|
|
|
|
|
|
logger.error(e)
|
|
|
|
|
|
|
|
image_type = 'Developer'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if not self.mounter.is_image_mounted(image_type):
|
|
|
|
|
|
|
|
logger.debug("Image is not mounted yet")
|
|
|
|
|
|
|
|
logger.debug('trying to figure out the best suited DeveloperDiskImage')
|
|
|
|
|
|
|
|
version = self.lockdown.sanitized_ios_version
|
|
|
|
|
|
|
|
image_dir = f'{get_home_folder()}/DevDiskImage/'
|
|
|
|
|
|
|
|
image_path = f'{image_dir}/DeveloperDiskImage.dmg'
|
|
|
|
|
|
|
|
signature = f'{image_path}.signature'
|
|
|
|
|
|
|
|
developer_disk_image_dir = Path(image_dir)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if not developer_disk_image_dir.exists():
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
|
|
|
download_developer_disk_image(version, developer_disk_image_dir)
|
|
|
|
|
|
|
|
except PermissionError:
|
|
|
|
|
|
|
|
logger.error(
|
|
|
|
|
|
|
|
f'DeveloperDiskImage could not be saved to path ({developer_disk_image_dir}). '
|
|
|
|
|
|
|
|
f'Please make sure your user has the necessary permissions')
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
|
|
image_path = Path(image_path)
|
|
|
|
image_path = Path(image_path)
|
|
|
|
image = image_path.read_bytes()
|
|
|
|
signature = Path(signature)
|
|
|
|
signature_path = Path(signature_path)
|
|
|
|
image_path = image_path.read_bytes()
|
|
|
|
signature = signature_path.read_bytes()
|
|
|
|
signature = signature.read_bytes()
|
|
|
|
|
|
|
|
|
|
|
|
self.mounter.upload_image(image_type, image, signature)
|
|
|
|
self.mounter.upload_image(image_type, image_path, signature)
|
|
|
|
self.mounter.mount(image_type, signature)
|
|
|
|
self.mounter.mount(image_type, signature)
|
|
|
|
|
|
|
|
logger.info('DeveloperDiskImage mounted successfully')
|
|
|
|
return True
|
|
|
|
else:
|
|
|
|
|
|
|
|
logger.debug("Image is mounted.")
|
|
|
|
|
|
|
|
|
|
|
|
def spoof_gps(self, destination):
|
|
|
|
def spoof_gps(self, destination):
|
|
|
|
if self.location is None:
|
|
|
|
if self.location is None:
|
|
|
@ -35,6 +65,10 @@ class Device():
|
|
|
|
self.location.clear()
|
|
|
|
self.location.clear()
|
|
|
|
self.diagnostics.restart()
|
|
|
|
self.diagnostics.restart()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_ios_version(self):
|
|
|
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|