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 / unix / Perguntas / 473528
Accepted
Les Hazlewood
Les Hazlewood
Asked: 2018-10-06 10:06:59 +0800 CST2018-10-06 10:06:59 +0800 CST 2018-10-06 10:06:59 +0800 CST

Como você habilita o comando secret-tool (apoiado por gnome-keyring, libsecret e dbus) em um contêiner do CentOS Docker sem cabeça?

  • 772

Estou tentando usar o secret-toolcomando para armazenar um segredo com segurança em um contêiner do Docker headless do CentoS 7.5.1804, mas não consigo encontrar quais pacotes e/ou configuração são necessários para que isso funcione com êxito.

Especificamente, quero poder executar este comando:

printf "aPassword" | secret-tool store --label="test" foo bar

E ser capaz de ver essa senha executando:

secret-tool lookup foo bar

Quando executo o secret-tool storecomando, recebo isso:

printf 'aPassword' | secret-tool store --label="test" foo bar
** Message: Remote error from secret service: org.freedesktop.DBus.Error.UnknownMethod: No such interface 'org.freedesktop.Secret.Collection' on object at path /org/freedesktop/secrets/collection/login
secret-tool: No such interface 'org.freedesktop.Secret.Collection' on object at path /org/freedesktop/secrets/collection/login

Eu segui a página wiki do ArchLinux Gnome/Keyring e tentei fazer o mesmo em um contêiner CentOS Docker através das seguintes etapas:

docker run --privileged -it centos:centos7.5.1804 /bin/bash
# remainder of commands are in the container bash shell:
printf 'search localhost.localdomain\nnameserver 8.8.8.8\nameserver 8.8.4.4' > /etc/resolv.conf
yum -y update
yum -y install sudo gnome-keyring libsecret dbus-x11
yum clean all && rm -rf /var/cache/yum
export DISPLAY=“:0.0”
eval "$(dbus-launch --sh-syntax)"
mkdir -p ~/.cache
mkdir -p ~/.local/share/keyrings
eval $(gnome-keyring-daemon --start)
export SSH_AUTH_SOCK

Pelo que posso dizer, isso deve fornecer tudo o que é necessário (gnome-keyring daemon, dbus session e secret-tool + libsecret) para permitir que o secret-tool storecomando seja bem-sucedido, mas se falhar.

o que estou perdendo?

centos docker
  • 2 2 respostas
  • 8943 Views

2 respostas

  • Voted
  1. Best Answer
    Les Hazlewood
    2019-10-22T16:23:30+08:002019-10-22T16:23:30+08:00

    Um ano depois, e pude revisitar isso. Depois de um dia inteiro pesquisando e tentando várias coisas, finalmente consegui descobrir isso. Espero que esta resposta salve outros os dias de produtividade que perdi!

    O elo que faltava na cadeia era que um chaveiro precisa ser criado primeiro antes que as entradas possam ser salvas nele. Nesse contexto do docker, não há conta de usuário, login, etc - portanto, nenhum chaveiro que teria sido criado automaticamente por um gerenciador de desktop como o Gnome.

    Como resultado, você deve:

    1. Primeiro crie o chaveiro manualmente e depois
    2. Inicie o daemon de chaveiro manualmente

    Ao criar, o comando requer uma senha de stdin para inicializar o chaveiro. Neste exemplo do docker, porque é apenas para teste e não é realmente usado por um usuário real, estou usando uma senha fictícia de uma nova linha \nque é canalizada para o --unlockcenário (que cria um chaveiro na primeira vez que é chamado) e o --startcenário que realmente inicia o daemon.

    Aqui está o conjunto de comandos de trabalho final. Observe que a imagem do docker base oficial centosnão é usada - os serviços do systemd devem estar em execução para o DBus, portanto, devemos usar a centos/systemdimagem oficial:

    docker run --privileged -d -v /sys/fs/cgroup:/sys/fs/cgroup:ro --name centos-systemd centos/systemd
    docker exec -it centos-systemd /bin/bash
    
    # remainder of commands are in the container bash shell:
    yum -y install gnome-keyring libsecret dbus-x11
    
    eval "$(dbus-launch --sh-syntax)"
    
    mkdir -p ~/.cache
    mkdir -p ~/.local/share/keyrings # where the automatic keyring is created
    
    # 1. Create the keyring manually with a dummy password in stdin
    eval "$(printf '\n' | gnome-keyring-daemon --unlock)"
    
    # 2. Start the daemon, using the password to unlock the just-created keyring:
    eval "$(printf '\n' | /usr/bin/gnome-keyring-daemon --start)"
    

    Feito isso, agora podemos armazenar e pesquisar senhas:

    [root@603a122f7555 /]# secret-tool lookup foo bar
    [root@603a122f7555 /]# printf "aPassword" | secret-tool store --label="test" foo bar
    [root@603a122f7555 /]# secret-tool lookup foo bar
    aPassword
    [root@603a122f7555 /]#
    
    • 15
  2. alchemy
    2022-02-12T11:32:38+08:002022-02-12T11:32:38+08:00

    Aqui estão meus comandos em uma VM sem cabeça do Ubuntu:

    apt install dbus-x11 gnome-keyring libsecret # ~79MB
    export $(dbus-launch)
    eval "$(echo '\n' | gnome-keyring-daemon --unlock)"
    echo [email protected] | secret-tool store --label="main" email address
    echo $(secret-tool lookup email address)
    
    kill -9  $(pgrep -f gnome-keyring-daemon)
    # echo $(secret-tool lookup email address)  # no longer gives password
    

    Parece que o chaveiro precisará ser desbloqueado em qualquer script para recuperar os segredos.

    O truque estava realmente usando o comando eval que eu achava que era apenas para o Docker. Este é o erro sem isso, que não tem solução na rede, incluindo alguns projetos do GitHub.

    "secret-tool: Não é possível criar um item em uma coleção bloqueada"

    EDIT, isso só funcionou uma vez. Mesmo depois de usar -rpara reiniciar o daemon, matando os processos e reiniciando. Não consigo obter novos segredos, mesmo com nomes diferentes, nem recuperar o armazenado.
    Erro "secret-tool: não é possível criar um item em uma coleção bloqueada"

    • 0

relate perguntas

  • Por que meu switch não está obtendo um endereço do pool especificado

  • Como instalo o docker no RHEL 7 offline?

  • Preciso executar este arquivo de script apenas uma vez?

  • Criando menus personalizados na guia do menu Aplicativos no CentOS7 GNOME

  • Roteador estranho funciona com centos 6 [fechado]

Sidebar

Stats

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

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    ssh Não é possível negociar: "nenhuma cifra correspondente encontrada", está rejeitando o cbc

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    Como descarregar o módulo do kernel 'nvidia-drm'?

    • 13 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add retorna com: "Erro ao conectar ao agente: nenhum arquivo ou diretório" 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya Por que o Linux usa LF como caractere de nova linha? 2017-12-20 05:48:21 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

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