No cofre da Hashicorp, como faço para obter um par KV específico de um conjunto de KVs que defini em um determinado caminho?
Por exemplo, se eu definir vários pares de chave-valor em /mysecrets, tenho que fazer isso:
http://localhost:8200/v1/kv/data/mysecrets
...e busca todos os pares.
Se eu tentar:
http://localhost:8200/v1/kv/data/mysecrets/key1
Eu entendo
{
"errors": []
}
Ao usar o mecanismo de segredos KV Versão 2 do HashiCorp Vault, a busca de uma chave específica de dentro de um caminho
/mysecrets
não é feita anexando o nome da chave ao caminho. O segredo inteiro (ou seja, todos os pares chave-valor naquele caminho) é buscado de uma vez usando a API:GET /v1/kv/data/mysecrets
Isso retorna uma estrutura como:
Então, se você quiser apenas a chave 1, você precisa buscar o segredo inteiro e extrair a chave 1
data.data.object
programaticamentepor que o abaixo não funciona?
Esse caminho seria válido somente se você armazenasse o segredo diretamente, conforme
/mysecrets/key1
abaixo:Então você poderia fazer
e receber
Conforme confirmado pela documentação da API , os endpoints e parâmetros suportam apenas a recuperação de um segredo KV2 em uma versão e caminho de montagem de mecanismo específicos. Se você quiser retornar apenas um par chave-valor dentro do segredo, será necessário analisar a resposta HTTP. Por exemplo, pode-se usar
jq
esta tarefa se, por exemplo, umcurl
comando também estiver sendo executado, pois a resposta será uma string no formato JSON e enviada para a saída padrão. Por exemplo, um segredomy_secret
com chavefoo
pode ser enviado para a saída padrão como:Existem outras maneiras de analisar a resposta para apenas um par de valores-chave no segredo usando os vários SDKs do Vault, se você preferir esse caminho.