AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / ubuntu / Perguntas / 1314921
Accepted
Mr. T
Mr. T
Asked: 2021-02-10 02:33:19 +0800 CST2021-02-10 02:33:19 +0800 CST 2021-02-10 02:33:19 +0800 CST

Impedir que os Snaps acessem o diretório inicial do usuário?

  • 772

Estou tentando sandbox todos os meus aplicativos por padrão usando firejail. O Firejail não oferece suporte a aplicativos de snap.

Parece que, por padrão, se solicitado por um snap, o snapd concederá ao snap acesso de leitura/gravação ao diretório inicial do usuário. Isso significa que, por padrão, se houver uma vulnerabilidade explorada em um aplicativo snap "sandboxed" com acesso à rede, seria trivial para um invasor pegar todos os arquivos em $HOME, incluindo chaves GPG, chaves SSH e, é claro, os arquivos do usuário. documentos e outros arquivos.

Fazer algumas pesquisas on-line me levou a ser capaz de fazer um snap disconnect <snap>:<plug interface> <snap>:<slot interface>que, em teoria, bloquearia o acesso ao diretório inicial. Infelizmente, esta é uma abordagem 'tudo ou nada' (sem capacidade de definir quais pastas em home permitir/negar) e deve ser aplicada a cada snap individualmente após a instalação.

Existe uma maneira de aplicar uma política "sem acesso $ HOME" por padrão a todos os snaps? Em caso afirmativo, existe uma maneira de permitir o acesso a alguns diretórios em $HOME enquanto nega o acesso a outros? Meu entendimento é que o apparmor não pode ser usado para isso devido à maneira como os contêineres de encaixe são projetados.

Plano alternativo: Existe algum truque através do qual eu poderia remontar uma parte da página inicial (digamos /home/folderforsnaps) e enganar os snaps para pensar que é o diretório inicial?

snap
  • 2 2 respostas
  • 307 Views

2 respostas

  • Voted
  1. Best Answer
    user535733
    2021-02-10T07:17:41+08:002021-02-10T07:17:41+08:00

    [I] seria trivial para um invasor pegar todos os arquivos em $HOME

    1. Sim, e isso é verdade para todos os aplicativos não-Snap envenenados já escritos também. Sinta-se à vontade para ajudar a testar Snaps em busca de atividades nefastas (afinal, é uma comunidade) e denunciar quaisquer Snaps envenenados que você descobrir.

      Um ótimo lugar para discutir a segurança do Snap são os fóruns https://snapcraft.io . Soltar de.

    2. O snapd/AppArmor realmente tem proteção parcial para este ataque em particular: A interface inicial torna o conteúdo de todos os arquivos ocultos (como ~/.sshou ~/.thunderbird) ilegíveis.

      home permite o acesso a arquivos não ocultos pertencentes ao usuário no diretório home do usuário ($HOME).


    Existe uma maneira de aplicar uma política "sem acesso $ HOME" por padrão a todos os snaps?

    Não. O arquivo YAML de cada Snap define a política de acesso que o Snap precisa para funcionar. Uma política global quebraria Snaps que precisam de acesso a $HOME, exatamente o que os desenvolvedores não pretendiam.


    Existe algum truque através do qual eu poderia remontar uma parte da página inicial (digamos /home/folderforsnaps) e enganar os snaps a pensar que é o diretório inicial?

    Claro: você pode criar um contêiner LXD, ligar a parte de /home e instalar o Snap no contêiner.

    Ou você pode simplesmente executar o Snap como um usuário diferente com um conjunto limitado de dados em /home.

    • 2
  2. user4124
    2021-02-10T11:53:12+08:002021-02-10T11:53:12+08:00

    Você pode usar o seguinte para ver quais pacotes de snap usam a homeinterface.

    snap interfaces :home
    

    Em seguida, você pode escrever um script para disconnectcada pacote snap dessa interface. Defina SNAPLISTpara a saída que você obteve de cima.

    SNAPLIST=snap1,snap2,snap3
    for i in $(echo $SNAPLIST | sed "s/,/ /g")
    do
        # call your procedure/other scripts here below
        snap disconnect ${i}:home :home
    done
    
    • 1

relate perguntas

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Existe um comando para listar todos os usuários? Também para adicionar, excluir, modificar usuários, no terminal?

    • 9 respostas
  • Marko Smith

    Como excluir um diretório não vazio no Terminal?

    • 4 respostas
  • Marko Smith

    Como descompactar um arquivo zip do Terminal?

    • 9 respostas
  • Marko Smith

    Como instalo um arquivo .deb por meio da linha de comando?

    • 11 respostas
  • Marko Smith

    Como instalo um arquivo .tar.gz (ou .tar.bz2)?

    • 14 respostas
  • Marko Smith

    Como listar todos os pacotes instalados

    • 24 respostas
  • Martin Hope
    Flimm Como posso usar o docker sem sudo? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    led-Zepp Como faço para salvar a saída do terminal em um arquivo? 2014-02-15 11:49:07 +0800 CST
  • Martin Hope
    ubuntu-nerd Como descompactar um arquivo zip do Terminal? 2011-12-11 20:37:54 +0800 CST
  • Martin Hope
    TheXed Como instalo um arquivo .deb por meio da linha de comando? 2011-05-07 09:40:28 +0800 CST
  • Martin Hope
    Ivan Como listar todos os pacotes instalados 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    David Barry Como determino o tamanho total de um diretório (pasta) na linha de comando? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher "Os seguintes pacotes foram retidos:" Por que e como resolvo isso? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford Como os PPAs podem ser removidos? 2010-07-30 01:09:42 +0800 CST

Hot tag

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve