hacktricks/mobile-pentesting/ios-pentesting/basic-ios-testing-operations.md
2023-06-06 18:56:34 +00:00

25 KiB

Obtendo o UDID de um dispositivo iOS

{% hint style="info" %} Realize essas ações tendo o dispositivo conectado ao computador via USB e tendo o dispositivo desbloqueado. {% endhint %}

O UDID é uma sequência única de 40 dígitos de letras e números para identificar um dispositivo iOS. Você pode encontrar o UDID do seu dispositivo iOS no macOS Catalina em diante no aplicativo Finder, já que o iTunes não está mais disponível no Catalina. Basta selecionar o dispositivo iOS conectado no Finder e clicar nas informações abaixo do nome do dispositivo iOS para iterar por ele. Além do UDID, você pode encontrar o número de série, IMEI e outras informações úteis.

Se você estiver usando uma versão do macOS anterior ao Catalina, pode encontrar o UDID do seu dispositivo iOS via iTunes, selecionando seu dispositivo e clicando em "Número de série" na guia Resumo. Ao clicar nisso, você iterará por diferentes metadados do dispositivo iOS, incluindo seu UDID.

Também é possível obter o UDID por meio de várias ferramentas de linha de comando no macOS enquanto o dispositivo está conectado via USB:

  • Usando a ferramenta I/O Registry Explorer ioreg:

      $ ioreg -p IOUSB -l | grep "USB Serial"
      |         "USB Serial Number" = "9e8ada44246cee813e2f8c1407520bf2f84849ec"
    
  • Usando ideviceinstaller (também disponível no Linux):

      $ brew install ideviceinstaller
      $ idevice_id -l
      316f01bd160932d2bf2f95f1f142bc29b1c62dbc
    
  • Usando o system_profiler:

      $ system_profiler SPUSBDataType | sed -n -e '/iPad/,/Serial/p;/iPhone/,/Serial/p;/iPod/,/Serial/p' | grep "Serial Number:"
      2019-09-08 10:18:03.920 system_profiler[13251:1050356] SPUSBDevice: IOCreatePlugInInterfaceForService failed 0xe00002be
                  Serial Number: 64655621de6ef5e56a874d63f1e1bdd14f7103b1
    
  • Usando instruments:

      $ instruments -s devices
    

Acessando o Shell do Dispositivo

Depois de fazer o jailbreak do dispositivo, você deve ter instalado algum novo gerenciador de aplicativos como o Cydia.

SSH

Para habilitar o acesso SSH ao seu dispositivo iOS, você pode instalar o pacote OpenSSH. Depois de instalado, você pode acessar seu dispositivo via ssh executando ssh root@<device_ip_address>, que fará login como usuário root:

$ ssh root@192.168.197.234
root@192.168.197.234's password:
iPhone:~ root#

Ao acessar seu dispositivo iOS via SSH, considere o seguinte:

  • Os usuários padrão são root e mobile.
  • A senha padrão para ambos é alpine.

Lembre-se de alterar a senha padrão para ambos os usuários root e mobile, pois qualquer pessoa na mesma rede pode encontrar o endereço IP do seu dispositivo e se conectar via senha padrão conhecida, o que lhes dará acesso root ao seu dispositivo.

Conectar a um dispositivo via SSH por USB

Durante um teste real de caixa preta, uma conexão Wi-Fi confiável pode não estar disponível. Nessa situação, você pode usar o usbmuxd para se conectar ao servidor SSH do seu dispositivo via USB.

Conecte o macOS a um dispositivo iOS instalando e iniciando o iproxy:

$ brew install libimobiledevice
$ iproxy 2222 22
waiting for connection

O comando acima mapeia a porta 22 do dispositivo iOS para a porta 2222 no localhost. Você também pode fazer o iproxy rodar automaticamente em segundo plano se não quiser executar o binário toda vez que quiser fazer SSH via USB.

Com o seguinte comando em uma nova janela do terminal, você pode se conectar ao dispositivo:

$ ssh -p 2222 root@localhost
root@localhost's password:
iPhone:~ root#

Pequena observação sobre o USB de um iDevice: em um dispositivo iOS, você não pode fazer conexões de dados após 1 hora de estar em um estado bloqueado, a menos que você o desbloqueie novamente devido ao Modo Restrito USB, que foi introduzido com o iOS 11.4.1.

Aplicativo Shell no Dispositivo

Embora geralmente usar um shell no dispositivo (emulador de terminal) possa ser muito tedioso em comparação com um shell remoto, pode ser útil para depurar em caso de, por exemplo, problemas de rede ou verificar alguma configuração. Por exemplo, você pode instalar o NewTerm 2 via Cydia para esse fim (ele suporta iOS 6.0 a 12.1.2 no momento em que este texto foi escrito).

Além disso, existem alguns jailbreaks que desabilitam explicitamente o SSH de entrada por motivos de segurança. Nesses casos, é muito conveniente ter um aplicativo shell no dispositivo, que você pode usar para primeiro fazer SSH para fora do dispositivo com um shell reverso e, em seguida, conectar-se a ele a partir do seu computador host.

Abrir um shell reverso via SSH pode ser feito executando o comando ssh -R <remote_port>:localhost:22 <username>@<host_computer_ip>.

No aplicativo shell no dispositivo, execute o seguinte comando e, quando solicitado, digite a senha do usuário mstg do computador host:

ssh -R 2222:localhost:22 mstg@192.168.197.235

No seu computador hospedeiro, execute o seguinte comando e, quando solicitado, digite a senha do usuário root do dispositivo iOS:

$ ssh -p 2222 root@localhost

Senha Esquecida

Se você esqueceu sua senha e deseja redefini-la para o padrão alpine:

  1. Edite o arquivo /private/etc/master.passwd em seu dispositivo iOS com jailbreak usando um terminal no dispositivo ou usando aplicativos como Filza ou iFile

  2. Encontre as linhas:

     root:xxxxxxxxx:0:0::0:0:System Administrator:/var/root:/bin/sh
     mobile:xxxxxxxxx:501:501::0:0:Mobile User:/var/mobile:/bin/sh
    
  3. Altere xxxxxxxxx para /smx7MYTQIi2M (que é a senha criptografada alpine)

  4. Salve e saia

Transferência de Dados

Copiando Arquivos de Dados do Aplicativo via SSH e SCP

Como sabemos agora, os arquivos do nosso aplicativo são armazenados no diretório Data. Agora você pode simplesmente arquivar o diretório Data com tar e puxá-lo do dispositivo com scp:

iPhone:~ root# tar czvf /tmp/data.tgz /private/var/mobile/Containers/Data/Application/8C8E7EB0-BC9B-435B-8EF8-8F5560EB0693
iPhone:~ root# exit
$ scp -P 2222 root@localhost:/tmp/data.tgz .

Usando o iFunbox

O iFunbox é um aplicativo GUI que pode ser usado para várias coisas (fazer upload/download de arquivos entre eles).
Outra ferramenta GUI para esse propósito é o iExplorer.

{% hint style="info" %} A partir da versão 8.4 do iOS, a Apple restringiu o acesso de gerenciadores de terceiros ao sandbox do aplicativo, então ferramentas como o iFunbox e o iExplorer não exibem/recuperam mais arquivos de aplicativos instalados no dispositivo se o dispositivo não estiver com jailbreak. {% endhint %}

Usando o Objection

Quando você inicia o Objection (objection --gadget com.apple.mobilesafari explorer), você encontrará o prompt dentro do diretório Bundle.

org.owasp.MSTG on (iPhone: 10.3.3) [usb] # pwd print
Current directory: /var/containers/Bundle/Application/DABF849D-493E-464C-B66B-B8B6C53A4E76/org.owasp.MSTG.app

Use o comando env para obter os diretórios do aplicativo e navegue até o diretório Documents.

org.owasp.MSTG on (iPhone: 10.3.3) [usb] # cd /var/mobile/Containers/Data/Application/72C7AAFB-1D75-4FBA-9D83-D8B4A2D44133/Documents
/var/mobile/Containers/Data/Application/72C7AAFB-1D75-4FBA-9D83-D8B4A2D44133/Documents

Com o comando file download <nome_do_arquivo> você pode baixar um arquivo do dispositivo iOS para o seu computador e analisá-lo posteriormente.

org.owasp.MSTG on (iPhone: 10.3.3) [usb] # file download .com.apple.mobile_container_manager.metadata.plist
Downloading /var/mobile/Containers/Data/Application/72C7AAFB-1D75-4FBA-9D83-D8B4A2D44133/.com.apple.mobile_container_manager.metadata.plist to .com.apple.mobile_container_manager.metadata.plist
Streaming file from device...
Writing bytes to destination...
Successfully downloaded /var/mobile/Containers/Data/Application/72C7AAFB-1D75-4FBA-9D83-D8B4A2D44133/.com.apple.mobile_container_manager.metadata.plist to .com.apple.mobile_container_manager.metadata.plist

Também é possível fazer upload de arquivos para o dispositivo iOS com file upload <local_file_path>.

Obtendo e Extraindo Aplicativos

Durante o desenvolvimento, os aplicativos são às vezes fornecidos aos testadores por meio de distribuição over-the-air (OTA). Nessa situação, você receberá um link itms-services, como o seguinte:

itms-services://?action=download-manifest&url=https://s3-ap-southeast-1.amazonaws.com/test-uat/manifest.plist

Você pode usar a ferramenta ITMS services asset downloader para baixar o IPA de uma URL de distribuição OTA. Instale-a via npm:

$ npm install -g itms-services

Salve o arquivo IPA localmente com o seguinte comando:

# itms-services -u "itms-services://?action=download-manifest&url=https://s3-ap-southeast-1.amazonaws.com/test-uat/manifest.plist" -o - > out.ipa

Adquirindo o Binário do Aplicativo

  1. A partir de um IPA:

    Se você tiver o IPA (provavelmente incluindo um binário de aplicativo já descriptografado), descompacte-o e estará pronto para começar. O binário do aplicativo está localizado no diretório do pacote principal (.app), por exemplo, Payload/Telegram X.app/Telegram X. Consulte a subseção a seguir para obter detalhes sobre a extração das listas de propriedades.

    No Finder do macOS, os diretórios .app são abertos clicando com o botão direito do mouse e selecionando "Mostrar conteúdo do pacote". No terminal, você pode simplesmente cd para eles.

  2. A partir de um dispositivo com Jailbreak:

    Se você não tiver o IPA original, precisará de um dispositivo com jailbreak onde irá instalar o aplicativo (por exemplo, via App Store). Depois de instalado, você precisa extrair o binário do aplicativo da memória e reconstruir o arquivo IPA. Devido ao DRM, o arquivo binário do aplicativo é criptografado quando armazenado no dispositivo iOS, portanto, simplesmente puxá-lo do Bundle (por meio de SSH ou Objection) não será suficiente para engenharia reversa (leia a próxima seção).

Descriptografia (Manual)

Ao contrário de um aplicativo Android, o binário de um aplicativo iOS só pode ser desmontado e não descompilado.
Quando um aplicativo é enviado à App Store, a Apple primeiro verifica a conduta do aplicativo e, antes de lançá-lo na App Store, a Apple criptografa o binário usando FairPlay. Portanto, o download do binário da App Store é criptografado, complicando as tarefas de engenharia reversa.

No entanto, observe que existem outros softwares de terceiros que podem ser usados para ofuscar os binários resultantes.

Para executar o binário criptografado, o dispositivo precisa descriptografá-lo na memória. Em seguida, é possível despejar o binário descriptografado da memória.

Primeiro, verifique se o binário é compilado com a flag PIE (Position Independent Code):

otool -Vh Original_App #Check the last word of the last line of this code
Home:
Mach header
      magic  cputype cpusubtype  caps    filetype ncmds sizeofcmds      flags
MH_MAGIC_64   X86_64        ALL  0x00     EXECUTE    47       6080   NOUNDEFS DYLDLINK TWOLEVEL PIE

Se estiver definido, você pode usar o script change_macho_flags.py para removê-lo com python2:

python change_mach_o_flags.py --no-pie Original_App
otool -Vh Hello_World
Hello_World:
Mach header
      magic  cputype cpusubtype  caps    filetype ncmds sizeofcmds      flags
   MH_MAGIC      ARM         V7  0x00     EXECUTE    22       2356   NOUNDEFS DYLDLINK TWOLEVEL MH_NO_HEAP_EXECUTION

Agora que a flag PIE não está definida, o sistema operacional carregará o programa em um local de início fixo toda vez. Para encontrar este local, você pode usar:

otool -l Original_App | grep -A 3 LC_SEGMENT | grep -A 1 __TEXT
  segname __TEXT
   vmaddr 0x00004000

Então, é necessário extrair o intervalo de memória que precisa ser despejado:

otool -l Original_App | grep -A 4 LC_ENCRYPTION_INFO
          cmd LC_ENCRYPTION_INFO
      cmdsize 20
     cryptoff 16384
    cryptsize 17416192
      cryptid 0

O valor de cryptoff indica o endereço de início do conteúdo criptografado e cryptsize indica o tamanho do conteúdo criptografado.

Portanto, o endereço de início para o despejo será vmaddr + cryptoff e o endereço final será o endereço de início + cryptsize.
Neste caso: endereço_inicial = 0x4000 + 0x4000 = 0x8000 __ e endereço_final = 0x8000 + 0x109c000 = 0x10a4000

Com essas informações, é necessário apenas executar o aplicativo no dispositivo com jailbreak, anexar ao processo com gdb (gdb -p <pid>) e despejar a memória:

dump memory dump.bin 0x8000 0x10a4000

Parabéns! Você descriptografou a seção criptografada em dump.bin. Agora transfira este dump para o seu computador e sobrescreva a seção criptografada com a seção descriptografada:

dd bs=1 seek=<starting_address> conv=notrunc if=dump.bin of=Original_App

Existe mais um passo a ser concluído. O aplicativo ainda está indicando em seus metadados que está criptografado, mas na verdade não está. Então, quando executado, o dispositivo tentará descriptografar a seção que já foi descriptografada e falhará.
No entanto, você pode usar ferramentas como o MachOView para alterar essas informações. Basta abrir o binário e definir o cryptid como 0:

Descriptografia (Automática)

frida-ios-dump

Você pode usar ferramentas como o frida-ios-dump para remover automaticamente a criptografia de um aplicativo.

Primeiro, certifique-se de que a configuração no arquivo dump.py do Frida-ios-dump esteja definida como localhost com a porta 2222 ao usar o iproxy, ou para o endereço IP real e a porta do dispositivo do qual você deseja despejar o binário.

Agora você pode usar a ferramenta com segurança para enumerar os aplicativos instalados:

$ python dump.py -l
 PID  Name             Identifier
----  ---------------  -------------------------------------
 860  Cydia            com.saurik.Cydia
1130  Settings         com.apple.Preferences
 685  Mail             com.apple.mobilemail
 834  Telegram         ph.telegra.Telegraph
   -  Stocks           com.apple.stocks
   ...

e você pode despejar um dos binários listados:

$ python3 dump.py -u "root" -p "<PASSWORD>" ph.telegra.Telegraph

Start the target app ph.telegra.Telegraph
Dumping Telegram to /var/folders/qw/gz47_8_n6xx1c_lwq7pq5k040000gn/T
[frida-ios-dump]: HockeySDK.framework has been loaded.
[frida-ios-dump]: Load Postbox.framework success.
[frida-ios-dump]: libswiftContacts.dylib has been dlopen.
...
start dump /private/var/containers/Bundle/Application/14002D30-B113-4FDF-BD25-1BF740383149/Telegram.app/Frameworks/libswiftsimd.dylib
libswiftsimd.dylib.fid: 100%|██████████| 343k/343k [00:00<00:00, 1.54MB/s]
start dump /private/var/containers/Bundle/Application/14002D30-B113-4FDF-BD25-1BF740383149/Telegram.app/Frameworks/libswiftCoreData.dylib
libswiftCoreData.dylib.fid: 100%|██████████| 82.5k/82.5k [00:00<00:00, 477kB/s]
5.m4a: 80.9MB [00:14, 5.85MB/s]
0.00B [00:00, ?B/s]Generating "Telegram.ipa"

Depois disso, o arquivo Telegram.ipa será criado no seu diretório atual. Você pode validar o sucesso do dump removendo o aplicativo e reinstalando-o (por exemplo, usando o ios-deploy ios-deploy -b Telegram.ipa). Note que isso só funcionará em dispositivos com jailbreak, caso contrário, a assinatura não será válida.

flexdecrypt

Para obter o arquivo ipa de um aplicativo instalado, você também pode usar a ferramenta flexdecrypt ou um wrapper da ferramenta chamado flexdump.
Em qualquer caso, você precisará instalar o flexdecrypt no dispositivo executando algo como:

wget https://github.com/JohnCoates/flexdecrypt/releases/download/1.1/flexdecrypt.deb
dpkg -i flexdecrypt.deb
rm flexdecrypt.deb

e para usar o flexdump:

apt install zip unzip
wget https://gist.githubusercontent.com/defparam/71d67ee738341559c35c684d659d40ac/raw/30c7612262f1faf7871ba8e32fbe29c0f3ef9e27/flexdump -P /usr/local/bin; chmod +x /usr/local/bin/flexdump
flexdump list #List apps
flexdump dump Twitter.app #Create .ipa file from app

r2flutch

r2flutch é uma ferramenta que usa radare e frida para descriptografar e dump ios apps.

Veja o github para mais informações.

Instalando aplicativos

Quando você instala um aplicativo sem usar a App Store da Apple, isso é chamado de sideloading. Existem várias maneiras de fazer sideloading, que são descritas abaixo. No dispositivo iOS, o processo real de instalação é então tratado pelo daemon installd, que irá descompactar e instalar o aplicativo. Para integrar serviços de aplicativos ou ser instalado em um dispositivo iOS, todos os aplicativos devem ser assinados com um certificado emitido pela Apple. Isso significa que o aplicativo só pode ser instalado após a verificação bem-sucedida da assinatura do código. Em um telefone com jailbreak, no entanto, você pode contornar esse recurso de segurança com AppSync, um pacote disponível na loja Cydia. Ele contém inúmeros aplicativos úteis que aproveitam os privilégios de root fornecidos pelo jailbreak para executar funcionalidades avançadas. AppSync é um ajuste que corrige o installd, permitindo a instalação de pacotes IPA falsamente assinados.

Existem diferentes métodos para instalar um pacote IPA em um dispositivo iOS, que são descritos em detalhes abaixo.

Observe que o iTunes não está mais disponível no macOS Catalina. Se você estiver usando uma versão mais antiga do macOS, o iTunes ainda estará disponível, mas desde o iTunes 12.7 não é possível instalar aplicativos.

Cydia Impactor

Cydia Impactor foi originalmente criado para fazer jailbreak em iPhones, mas foi reescrito para assinar e instalar pacotes IPA em dispositivos iOS via sideloading (e até mesmo arquivos APK em dispositivos Android). O Cydia Impactor está disponível para Windows, macOS e Linux. Um guia passo a passo e etapas de solução de problemas estão disponíveis em yalujailbreak.net.

libimobiledevice

No Linux e também no macOS, você pode usar alternativamente o libimobiledevice, uma biblioteca de protocolo de software multiplataforma e um conjunto de ferramentas para comunicação nativa com dispositivos iOS. Isso permite que você instale aplicativos por meio de uma conexão USB executando o ideviceinstaller. A conexão é implementada com o daemon de multiplexação USB usbmuxd, que fornece um túnel TCP sobre USB.

O pacote para libimobiledevice estará disponível no gerenciador de pacotes do seu Linux. No macOS, você pode instalar o libimobiledevice via brew:

$ brew install libimobiledevice
$ brew install ideviceinstaller

Depois da instalação, você terá vários novos comandos disponíveis na linha de comando, como ideviceinfo, ideviceinstaller ou idevicedebug.

# The following command will show detailed information about the iOS device connected via USB.
$ ideviceinfo
# The following command will install the IPA to your iOS device.
$ ideviceinstaller -i iGoat-Swift_v1.0-frida-codesigned.ipa
...
Install: Complete
# The following command will start the app in debug mode, by providing the bundle name. The bundle name can be found in the previous command after "Installing".
$ idevicedebug -d run OWASP.iGoat-Swift

ipainstaller

O IPA também pode ser instalado diretamente no dispositivo iOS via linha de comando com o ipainstaller. Após copiar o arquivo para o dispositivo, por exemplo, via scp, você pode executar o ipainstaller com o nome do arquivo IPA:

$ ipainstaller App_name.ipa

ios-deploy

No macOS, você também pode usar a ferramenta ios-deploy para instalar aplicativos iOS a partir da linha de comando. Você precisará descompactar seu IPA, já que o ios-deploy usa os pacotes de aplicativos para instalar aplicativos.

$ unzip Name.ipa
$ ios-deploy --bundle 'Payload/Name.app' -W -d -v

Depois que o aplicativo é instalado no dispositivo iOS, você pode simplesmente iniciá-lo adicionando a flag -m, que iniciará a depuração diretamente sem instalar o aplicativo novamente.

$ ios-deploy --bundle 'Payload/Name.app' -W -d -v -m

Xcode

Também é possível usar o IDE Xcode para instalar aplicativos iOS seguindo os seguintes passos:

  1. Inicie o Xcode
  2. Selecione Window/Devices and Simulators
  3. Selecione o dispositivo iOS conectado e clique no sinal de + em Installed Apps.

Permitir a instalação de aplicativos em um dispositivo que não seja iPad

Às vezes, um aplicativo pode exigir o uso em um dispositivo iPad. Se você só tiver dispositivos iPhone ou iPod touch, poderá forçar a instalação e o uso do aplicativo nesses tipos de dispositivos. Você pode fazer isso alterando o valor da propriedade UIDeviceFamily para o valor 1 no arquivo Info.plist.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>

  <key>UIDeviceFamily</key>
  <array>
    <integer>1</integer>
  </array>

</dict>
</plist>

É importante observar que a alteração desse valor irá quebrar a assinatura original do arquivo IPA, portanto, você precisa re-assinar o IPA, após a atualização, para instalá-lo em um dispositivo no qual a validação da assinatura não tenha sido desativada.

Essa técnica de bypass pode não funcionar se o aplicativo requer recursos específicos de iPads modernos enquanto seu iPhone ou iPod é um pouco mais antigo.

Os possíveis valores para a propriedade UIDeviceFamily podem ser encontrados na documentação do desenvolvedor da Apple.

☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥