14 KiB
AppArmor
Aprenda hacking no AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)!
Outras formas de apoiar o HackTricks:
- Se você quer ver sua empresa anunciada no HackTricks ou baixar o HackTricks em PDF, confira os PLANOS DE ASSINATURA!
- Adquira o material oficial PEASS & HackTricks
- Descubra A Família PEASS, nossa coleção de NFTs exclusivos
- Junte-se ao grupo 💬 Discord ou ao grupo telegram ou siga-me no Twitter 🐦 @carlospolopm.
- Compartilhe suas técnicas de hacking enviando PRs para os repositórios github HackTricks e HackTricks Cloud.
Informações Básicas
AppArmor é um aprimoramento do kernel para confinar programas a um conjunto limitado de recursos com perfis por programa. Os perfis podem permitir capacidades como acesso à rede, acesso a socket raw e a permissão para ler, escrever ou executar arquivos em caminhos correspondentes.
É um Controle de Acesso Obrigatório ou MAC que vincula atributos de controle de acesso aos programas em vez de aos usuários.
O confinamento do AppArmor é fornecido através de perfis carregados no kernel, tipicamente durante a inicialização.
Os perfis do AppArmor podem estar em um de dois modos:
- Enforcement: Perfis carregados no modo de enforcement resultarão na execução da política definida no perfil assim como no relatório de tentativas de violação da política (seja via syslog ou auditd).
- Complain: Perfis no modo complain não executarão a política, mas em vez disso relatarão tentativas de violação da política.
O AppArmor difere de alguns outros sistemas MAC no Linux: é baseado em caminhos, permite a mistura de perfis nos modos de enforcement e complain, usa arquivos de inclusão para facilitar o desenvolvimento e tem uma barreira de entrada muito menor do que outros sistemas MAC populares.
Componentes do AppArmor
- Módulo do kernel: Realiza o trabalho real
- Políticas: Define o comportamento e o confinamento
- Parser: Carrega as políticas no kernel
- Utilitários: Programas em modo usuário para interagir com o apparmor
Caminho dos perfis
Os perfis do apparmor são geralmente salvos em /etc/apparmor.d/
Com sudo aa-status
você poderá listar os binários que estão restritos por algum perfil. Se você puder mudar o caractere "/" por um ponto no caminho de cada binário listado, você obterá o nome do perfil do apparmor dentro da pasta mencionada.
Por exemplo, um perfil do apparmor para /usr/bin/man estará localizado em /etc/apparmor.d/usr.bin.man
Comandos
aa-status #check the current status
aa-enforce #set profile to enforce mode (from disable or complain)
aa-complain #set profile to complain mode (from diable or enforcement)
apparmor_parser #to load/reload an altered policy
aa-genprof #generate a new profile
aa-logprof #used to change the policy when the binary/program is changed
aa-mergeprof #used to merge the policies
Criando um perfil
- Para indicar o executável afetado, caminhos absolutos e curingas são permitidos (para correspondência de arquivos) para especificar arquivos.
- Para indicar o acesso que o binário terá sobre arquivos, os seguintes controles de acesso podem ser usados:
- r (leitura)
- w (escrita)
- m (mapear memória como executável)
- k (bloqueio de arquivo)
- l (criação de links rígidos)
- ix (para executar outro programa com a nova política herdada)
- Px (executar sob outro perfil, após limpar o ambiente)
- Cx (executar sob um perfil filho, após limpar o ambiente)
- Ux (executar sem restrições, após limpar o ambiente)
- Variáveis podem ser definidas nos perfis e podem ser manipuladas de fora do perfil. Por exemplo: @{PROC} e @{HOME} (adicionar #include <tunables/global> ao arquivo de perfil)
- Regras de negação são suportadas para sobrescrever regras de permissão.
aa-genprof
Para começar a criar um perfil facilmente, o apparmor pode ajudá-lo. É possível fazer com que o apparmor inspecione as ações realizadas por um binário e depois permita que você decida quais ações deseja permitir ou negar.
Você só precisa executar:
sudo aa-genprof /path/to/binary
Então, em um console diferente, execute todas as ações que o binário normalmente realizará:
/path/to/binary -a dosomething
Então, no primeiro console pressione "s" e depois nas ações gravadas indique se deseja ignorar, permitir ou o que for. Quando terminar, pressione "f" e o novo perfil será criado em /etc/apparmor.d/caminho.para.binario
{% hint style="info" %} Usando as teclas de seta, você pode selecionar o que deseja permitir/negar/o que for {% endhint %}
aa-easyprof
Você também pode criar um modelo de perfil apparmor de um binário com:
sudo aa-easyprof /path/to/binary
# vim:syntax=apparmor
# AppArmor policy for binary
# ###AUTHOR###
# ###COPYRIGHT###
# ###COMMENT###
#include <tunables/global>
# No template variables specified
"/path/to/binary" {
#include <abstractions/base>
# No abstractions specified
# No policy groups specified
# No read paths specified
# No write paths specified
}
{% hint style="info" %}
Observe que, por padrão em um perfil criado, nada é permitido, portanto, tudo é negado. Você precisará adicionar linhas como /etc/passwd r,
para permitir que o binário leia /etc/passwd
, por exemplo.
{% endhint %}
Você pode então forçar o novo perfil com
sudo apparmor_parser -a /etc/apparmor.d/path.to.binary
Modificando um perfil a partir de logs
A seguinte ferramenta lerá os logs e perguntará ao usuário se ele deseja permitir algumas das ações proibidas detectadas:
sudo aa-logprof
{% hint style="info" %} Usando as teclas de seta, você pode selecionar o que deseja permitir/negar/qualquer coisa {% endhint %}
Gerenciando um Perfil
#Main profile management commands
apparmor_parser -a /etc/apparmor.d/profile.name #Load a new profile in enforce mode
apparmor_parser -C /etc/apparmor.d/profile.name #Load a new profile in complain mode
apparmor_parser -r /etc/apparmor.d/profile.name #Replace existing profile
apparmor_parser -R /etc/apparmor.d/profile.name #Remove profile
Logs
Exemplo de logs AUDIT e DENIED do /var/log/audit/audit.log do executável service_bin
:
type=AVC msg=audit(1610061880.392:286): apparmor="AUDIT" operation="getattr" profile="/bin/rcat" name="/dev/pts/1" pid=954 comm="service_bin" requested_mask="r" fsuid=1000 ouid=1000
type=AVC msg=audit(1610061880.392:287): apparmor="DENIED" operation="open" profile="/bin/rcat" name="/etc/hosts" pid=954 comm="service_bin" requested_mask="r" denied_mask="r" fsuid=1000 ouid=0
Você também pode obter essa informação utilizando:
sudo aa-notify -s 1 -v
Profile: /bin/service_bin
Operation: open
Name: /etc/passwd
Denied: r
Logfile: /var/log/audit/audit.log
Profile: /bin/service_bin
Operation: open
Name: /etc/hosts
Denied: r
Logfile: /var/log/audit/audit.log
AppArmor denials: 2 (since Wed Jan 6 23:51:08 2021)
For more information, please see: https://wiki.ubuntu.com/DebuggingApparmor
Apparmor no Docker
Observe como o perfil docker-profile do docker é carregado por padrão:
sudo aa-status
apparmor module is loaded.
50 profiles are loaded.
13 profiles are in enforce mode.
/sbin/dhclient
/usr/bin/lxc-start
/usr/lib/NetworkManager/nm-dhcp-client.action
/usr/lib/NetworkManager/nm-dhcp-helper
/usr/lib/chromium-browser/chromium-browser//browser_java
/usr/lib/chromium-browser/chromium-browser//browser_openjdk
/usr/lib/chromium-browser/chromium-browser//sanitized_helper
/usr/lib/connman/scripts/dhclient-script
docker-default
Por padrão, o perfil Apparmor docker-default é gerado a partir de https://github.com/moby/moby/tree/master/profiles/apparmor
Resumo do perfil docker-default:
- Acesso a toda a rede
- Nenhuma capacidade é definida (No entanto, algumas capacidades virão da inclusão de regras básicas de base, ou seja, #include <abstractions/base>)
- Escrever em qualquer arquivo /proc não é permitido
- Outros subdiretórios/arquivos de /proc e /sys têm acesso de leitura/escrita/trava/link/execução negado
- Montagem não é permitida
- Ptrace só pode ser executado em um processo que está confinado pelo mesmo perfil apparmor
Uma vez que você execute um contêiner docker, você deve ver a seguinte saída:
1 processes are in enforce mode.
docker-default (825)
Observe que o apparmor bloqueará até mesmo os privilégios de capacidades concedidos ao container por padrão. Por exemplo, ele será capaz de bloquear a permissão de escrever dentro do /proc mesmo se a capacidade SYS_ADMIN for concedida porque por padrão o perfil apparmor do docker nega este acesso:
docker run -it --cap-add SYS_ADMIN --security-opt seccomp=unconfined ubuntu /bin/bash
echo "" > /proc/stat
sh: 1: cannot create /proc/stat: Permission denied
Você precisa desativar o apparmor para contornar suas restrições:
docker run -it --cap-add SYS_ADMIN --security-opt seccomp=unconfined --security-opt apparmor=unconfined ubuntu /bin/bash
Observe que, por padrão, o AppArmor também proibirá o container de montar pastas internamente, mesmo com a capacidade SYS_ADMIN.
Note que você pode adicionar/remover capacidades ao container do docker (isso ainda será restrito por métodos de proteção como AppArmor e Seccomp):
--cap-add=SYS_ADMIN
concede a capacidadeSYS_ADMIN
--cap-add=ALL
concede todas as capacidades--cap-drop=ALL --cap-add=SYS_PTRACE
remove todas as capacidades e concede apenasSYS_PTRACE
{% hint style="info" %} Geralmente, quando você descobre que tem uma capacidade privilegiada disponível dentro de um container docker mas alguma parte do exploit não está funcionando, isso ocorrerá porque o apparmor do docker estará impedindo. {% endhint %}
Exemplo
(Exemplo de aqui)
Para ilustrar a funcionalidade do AppArmor, criei um novo perfil Docker "mydocker" com a seguinte linha adicionada:
deny /etc/* w, # deny write for all files directly in /etc (not in a subdir)
Para ativar o perfil, precisamos fazer o seguinte:
sudo apparmor_parser -r -W mydocker
Para listar os perfis, podemos executar o seguinte comando. O comando abaixo está listando meu novo perfil AppArmor.
$ sudo apparmor_status | grep mydocker
mydocker
Como mostrado abaixo, recebemos um erro ao tentar alterar “/etc/” pois o perfil do AppArmor está impedindo o acesso de escrita a “/etc”.
$ docker run --rm -it --security-opt apparmor:mydocker -v ~/haproxy:/localhost busybox chmod 400 /etc/hostname
chmod: /etc/hostname: Permission denied
Contorno do AppArmor no Docker Bypass1
Você pode descobrir qual perfil apparmor está executando um container usando:
docker inspect 9d622d73a614 | grep lowpriv
"AppArmorProfile": "lowpriv",
"apparmor=lowpriv"
Então, você pode executar a seguinte linha para encontrar o perfil exato em uso:
find /etc/apparmor.d/ -name "*lowpriv*" -maxdepth 1 2>/dev/null
No caso incomum de você poder modificar o perfil do apparmor docker e recarregá-lo, você poderia remover as restrições e "bypassá-las".
AppArmor Docker Bypass2
O AppArmor é baseado em caminho, isso significa que mesmo que ele possa estar protegendo arquivos dentro de um diretório como /proc
, se você puder configurar como o contêiner será executado, você poderia montar o diretório proc do host dentro de /host/proc
e ele não será mais protegido pelo AppArmor.
AppArmor Shebang Bypass
Neste bug, você pode ver um exemplo de como mesmo impedindo que o perl seja executado com certos recursos, se você apenas criar um script shell especificando na primeira linha #!/usr/bin/perl
e executar o arquivo diretamente, você poderá executar o que quiser. Exemplo:
echo '#!/usr/bin/perl
use POSIX qw(strftime);
use POSIX qw(setuid);
POSIX::setuid(0);
exec "/bin/sh"' > /tmp/test.pl
chmod +x /tmp/test.pl
/tmp/test.pl
Aprenda hacking no AWS do zero ao herói com htARTE (HackTricks AWS Red Team Expert)!
Outras formas de apoiar o HackTricks:
- Se você quer ver sua empresa anunciada no HackTricks ou baixar o HackTricks em PDF, confira os PLANOS DE ASSINATURA!
- Adquira o material oficial PEASS & HackTricks
- Descubra A Família PEASS, nossa coleção exclusiva de NFTs
- Junte-se ao grupo 💬 Discord ou ao grupo telegram ou siga-me no Twitter 🐦 @carlospolopm.
- Compartilhe suas técnicas de hacking enviando PRs para os repositórios github HackTricks e HackTricks Cloud.