# Cadeia de Chaves do macOS
Aprenda hacking AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)! Outras maneiras de apoiar o HackTricks: * Se você quiser ver sua **empresa anunciada no HackTricks** ou **baixar o HackTricks em PDF**, confira os [**PLANOS DE ASSINATURA**](https://github.com/sponsors/carlospolop)! * Adquira o [**swag oficial PEASS & HackTricks**](https://peass.creator-spring.com) * Descubra [**A Família PEASS**](https://opensea.io/collection/the-peass-family), nossa coleção exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family) * **Junte-se ao** 💬 [**grupo Discord**](https://discord.gg/hRep4RUj7f) ou ao [**grupo telegram**](https://t.me/peass) ou **siga-nos** no **Twitter** 🐦 [**@carlospolopm**](https://twitter.com/hacktricks\_live)**.** * **Compartilhe seus truques de hacking enviando PRs para os repositórios** [**HackTricks**](https://github.com/carlospolop/hacktricks) e [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud).
### [WhiteIntel](https://whiteintel.io)
[**WhiteIntel**](https://whiteintel.io) é um mecanismo de busca alimentado pela **dark web** que oferece funcionalidades **gratuitas** para verificar se uma empresa ou seus clientes foram **comprometidos** por **malwares de roubo**. O principal objetivo do WhiteIntel é combater a apropriação de contas e ataques de ransomware resultantes de malwares de roubo de informações. Você pode verificar o site deles e experimentar o mecanismo gratuitamente em: {% embed url="https://whiteintel.io" %} *** ## Principais Cadeias de Chaves * A **Cadeia de Chaves do Usuário** (`~/Library/Keychains/login.keycahin-db`), que é usada para armazenar **credenciais específicas do usuário** como senhas de aplicativos, senhas de internet, certificados gerados pelo usuário, senhas de rede e chaves públicas/privadas geradas pelo usuário. * A **Cadeia de Chaves do Sistema** (`/Library/Keychains/System.keychain`), que armazena **credenciais de todo o sistema** como senhas WiFi, certificados raiz do sistema, chaves privadas do sistema e senhas de aplicativos do sistema. ### Acesso à Cadeia de Chaves de Senhas Esses arquivos, embora não tenham proteção inerente e possam ser **baixados**, são criptografados e exigem a **senha em texto simples do usuário para serem descriptografados**. Uma ferramenta como [**Chainbreaker**](https://github.com/n0fate/chainbreaker) pode ser usada para descriptografar. ## Proteções de Entradas da Cadeia de Chaves ### ACLs Cada entrada na cadeia de chaves é governada por **Listas de Controle de Acesso (ACLs)** que ditam quem pode realizar várias ações na entrada da cadeia de chaves, incluindo: * **ACLAuhtorizationExportClear**: Permite ao detentor obter o texto claro do segredo. * **ACLAuhtorizationExportWrapped**: Permite ao detentor obter o texto claro criptografado com outra senha fornecida. * **ACLAuhtorizationAny**: Permite ao detentor realizar qualquer ação. As ACLs são acompanhadas por uma **lista de aplicativos confiáveis** que podem realizar essas ações sem solicitação. Isso poderia ser: * **N`il`** (nenhuma autorização necessária, **todos são confiáveis**) * Uma lista **vazia** (ninguém é confiável) * **Lista** de **aplicativos** específicos. Além disso, a entrada pode conter a chave **`ACLAuthorizationPartitionID`,** que é usada para identificar o **teamid, apple** e **cdhash.** * Se o **teamid** for especificado, então para **acessar o valor da entrada** sem um **prompt**, o aplicativo usado deve ter o **mesmo teamid**. * Se o **apple** for especificado, então o aplicativo precisa ser **assinado** pela **Apple**. * Se o **cdhash** for indicado, então o **aplicativo** deve ter o **cdhash** específico. ### Criando uma Entrada na Cadeia de Chaves Quando uma **nova** **entrada** é criada usando o **`Keychain Access.app`**, as seguintes regras se aplicam: * Todos os aplicativos podem criptografar. * **Nenhum aplicativo** pode exportar/descriptografar (sem solicitar ao usuário). * Todos os aplicativos podem ver a verificação de integridade. * Nenhum aplicativo pode alterar as ACLs. * O **partitionID** é definido como **`apple`**. Quando um **aplicativo cria uma entrada na cadeia de chaves**, as regras são ligeiramente diferentes: * Todos os aplicativos podem criptografar. * Apenas o **aplicativo criador** (ou qualquer outro aplicativo adicionado explicitamente) pode exportar/descriptografar (sem solicitar ao usuário). * Todos os aplicativos podem ver a verificação de integridade. * Nenhum aplicativo pode alterar as ACLs. * O **partitionID** é definido como **`teamid:[teamID aqui]`**. ## Acessando a Cadeia de Chaves ### `security` ```bash # Dump all metadata and decrypted secrets (a lot of pop-ups) security dump-keychain -a -d # Find generic password for the "Slack" account and print the secrets security find-generic-password -a "Slack" -g # Change the specified entrys PartitionID entry security set-generic-password-parition-list -s "test service" -a "test acount" -S ``` ### APIs {% hint style="success" %} A enumeração e dumping do **keychain** de segredos que **não gerará um prompt** pode ser feita com a ferramenta [**LockSmith**](https://github.com/its-a-feature/LockSmith) {% endhint %} Liste e obtenha **informações** sobre cada entrada do keychain: * A API **`SecItemCopyMatching`** fornece informações sobre cada entrada e existem alguns atributos que você pode definir ao usá-la: * **`kSecReturnData`**: Se verdadeiro, tentará descriptografar os dados (defina como falso para evitar possíveis pop-ups) * **`kSecReturnRef`**: Obtenha também a referência ao item do keychain (defina como verdadeiro no caso de você ver que pode descriptografar sem pop-up) * **`kSecReturnAttributes`**: Obtenha metadados sobre as entradas * **`kSecMatchLimit`**: Quantos resultados retornar * **`kSecClass`**: Que tipo de entrada do keychain Obtenha **ACLs** de cada entrada: * Com a API **`SecAccessCopyACLList`** você pode obter o **ACL para o item do keychain**, e ele retornará uma lista de ACLs (como `ACLAuhtorizationExportClear` e os outros mencionados anteriormente) onde cada lista tem: * Descrição * **Lista de Aplicativos Confiáveis**. Isso poderia ser: * Um aplicativo: /Applications/Slack.app * Um binário: /usr/libexec/airportd * Um grupo: group://AirPort Exporte os dados: * A API **`SecKeychainItemCopyContent`** obtém o texto simples * A API **`SecItemExport`** exporta as chaves e certificados, mas pode ser necessário definir senhas para exportar o conteúdo criptografado E estes são os **requisitos** para poder **exportar um segredo sem um prompt**: * Se **1+ aplicativos confiáveis** listados: * Precisa das **autorizações apropriadas** (**`Nil`**, ou fazer **parte** da lista permitida de aplicativos na autorização para acessar as informações secretas) * Precisa que a assinatura de código corresponda ao **PartitionID** * Precisa que a assinatura de código corresponda à de um **aplicativo confiável** (ou ser membro do grupo de acesso correto do Keychain) * Se **todos os aplicativos forem confiáveis**: * Precisa das **autorizações apropriadas** * Precisa que a assinatura de código corresponda ao **PartitionID** * Se **não houver PartitionID**, então isso não é necessário {% hint style="danger" %} Portanto, se houver **1 aplicativo listado**, você precisa **injetar código nesse aplicativo**. Se **apple** for indicado no **partitionID**, você poderá acessá-lo com **`osascript`** para qualquer coisa que confie em todos os aplicativos com apple no partitionID. **`Python`** também poderia ser usado para isso. {% endhint %} ### Dois atributos adicionais * **Invisível**: É uma sinalização booleana para **ocultar** a entrada do aplicativo **UI** Keychain * **Geral**: É para armazenar **metadados** (portanto, NÃO É CIFRADO) * A Microsoft estava armazenando em texto simples todos os tokens de atualização para acessar pontos finais sensíveis. ## Referências * [**#OBTS v5.0: "Lock Picking the macOS Keychain" - Cody Thomas**](https://www.youtube.com/watch?v=jKE1ZW33JpY) ### [WhiteIntel](https://whiteintel.io)
[**WhiteIntel**](https://whiteintel.io) é um mecanismo de busca alimentado pela **dark web** que oferece funcionalidades **gratuitas** para verificar se uma empresa ou seus clientes foram **comprometidos** por **malwares ladrões**. O objetivo principal do WhiteIntel é combater a apropriação de contas e ataques de ransomware resultantes de malwares que roubam informações. Você pode verificar o site deles e experimentar o mecanismo gratuitamente em: {% embed url="https://whiteintel.io" %}
Aprenda hacking AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)! Outras maneiras de apoiar o HackTricks: * Se você quiser ver sua **empresa anunciada no HackTricks** ou **baixar o HackTricks em PDF** Confira os [**PLANOS DE ASSINATURA**](https://github.com/sponsors/carlospolop)! * Adquira o [**swag oficial PEASS & HackTricks**](https://peass.creator-spring.com) * Descubra [**The PEASS Family**](https://opensea.io/collection/the-peass-family), nossa coleção exclusiva de [**NFTs**](https://opensea.io/collection/the-peass-family) * **Junte-se ao** 💬 [**grupo Discord**](https://discord.gg/hRep4RUj7f) ou ao [**grupo telegram**](https://t.me/peass) ou nos siga no **Twitter** 🐦 [**@carlospolopm**](https://twitter.com/hacktricks\_live)**.** * **Compartilhe seus truques de hacking enviando PRs para o** [**HackTricks**](https://github.com/carlospolop/hacktricks) e [**HackTricks Cloud**](https://github.com/carlospolop/hacktricks-cloud) github repos.