Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

installation_proxy: add install_from_bytes() #1266

Merged
merged 1 commit into from
Nov 26, 2024

Conversation

abdullah-albanna
Copy link
Contributor

@abdullah-albanna abdullah-albanna commented Oct 29, 2024

ability to install .ipa/.ipcc using bytes objects

why?

it's way nicer to directly install a package without dealing with paths.

someone could do something like so

import requests
from pymobiledevice3.lockdown import create_using_usbmux
from pymobiledevice3.services.installation_proxy import InstallationProxyService

file = requests.get(
    "https://raw.githubusercontent.com/Abdullah-Albanna/YemenIPCC/refs/heads/master/iPhone7Plus/iOS 15.8.2/Using Default Bundle/iPhone7Plus_iOS_15.8.2_CellularSouthLTE.ipcc",
)

lockdown = create_using_usbmux()

InstallationProxyService(lockdown).install(file.content)

without the need to save it to a file and then installing it and then deleting it !
too much work

this is also valid

from pathlib import Path

file = Path("file.ipa").read_bytes()

lockdown = create_using_usbmux()

InstallationProxyService(lockdown).install(file)

@doronz88
Copy link
Owner

I much rather it be explicitly done than implicit. I'm okay with the install_from_bytes(), but it should a different API instead of modifying the current

@abdullah-albanna
Copy link
Contributor Author

that makes sense, should be good now

pymobiledevice3/cli/apps.py Outdated Show resolved Hide resolved
pymobiledevice3/services/installation_proxy.py Outdated Show resolved Hide resolved
pymobiledevice3/services/installation_proxy.py Outdated Show resolved Hide resolved
pymobiledevice3/services/installation_proxy.py Outdated Show resolved Hide resolved
pymobiledevice3/services/installation_proxy.py Outdated Show resolved Hide resolved
@doronz88
Copy link
Owner

Just making sure you saw I left some comments still

@abdullah-albanna
Copy link
Contributor Author

sorry, I don't get what you mean

can you tell me what to edit please, I understood some of it, but others are kind of confusing

@doronz88
Copy link
Owner

There are still unresolved issues. See the existing comments

@abdullah-albanna
Copy link
Contributor Author

Yeah but could you take a look at my replies please

The unresolved ones are what confuses me, I have already put a reply to them

@doronz88
Copy link
Owner

image
I don't see any reply to any comment

@abdullah-albanna
Copy link
Contributor Author

my bad, I did not commit them

pymobiledevice3/services/installation_proxy.py Outdated Show resolved Hide resolved
pymobiledevice3/services/installation_proxy.py Outdated Show resolved Hide resolved
@abdullah-albanna
Copy link
Contributor Author

I like how it gets crazy over an unused import

@doronz88 doronz88 changed the title installation_proxy: bytes package install installation_proxy: add install_from_bytes() Nov 26, 2024
@doronz88 doronz88 merged commit 1b60f49 into doronz88:master Nov 26, 2024
17 checks passed
@doronz88
Copy link
Owner

Thanks for your contribution!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants