Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/chrisns/kubectl-passman
kubectl plugin that provides the missing link/glue between common password managers and kubectl
https://github.com/chrisns/kubectl-passman
1password 1password-cli credential-storage credentials-helper gnome-keyring go golang gopass hacktoberfest k8s keychain kubectl-plugin kubectl-plugins kubernetes kubernetes-cli osx-keychain password-manager windows-credential-manager windows-credential-vault
Last synced: 5 days ago
JSON representation
kubectl plugin that provides the missing link/glue between common password managers and kubectl
- Host: GitHub
- URL: https://github.com/chrisns/kubectl-passman
- Owner: chrisns
- License: mit
- Created: 2019-09-23T14:17:51.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-12-17T22:40:16.000Z (16 days ago)
- Last Synced: 2024-12-22T05:10:01.619Z (12 days ago)
- Topics: 1password, 1password-cli, credential-storage, credentials-helper, gnome-keyring, go, golang, gopass, hacktoberfest, k8s, keychain, kubectl-plugin, kubectl-plugins, kubernetes, kubernetes-cli, osx-keychain, password-manager, windows-credential-manager, windows-credential-vault
- Language: Go
- Homepage:
- Size: 1.34 MB
- Stars: 121
- Watchers: 6
- Forks: 6
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
# kubectl user password manager glue
![CI status badge](https://github.com/chrisns/kubectl-passman/workflows/CI%20Pipeline/badge.svg)
![LICENSE](https://img.shields.io/github/license/chrisns/kubectl-passman)
![GitHub watchers](https://img.shields.io/github/watchers/chrisns/kubectl-passman?style)
![GitHub stars](https://img.shields.io/github/stars/chrisns/kubectl-passman)
![GitHub forks](https://img.shields.io/github/forks/chrisns/kubectl-passman)
![GitHub issues](https://img.shields.io/github/issues-raw/chrisns/kubectl-passman)
![GitHub closed issues](https://img.shields.io/github/issues-closed-raw/chrisns/kubectl-passman)
![GitHub pull requests](https://img.shields.io/github/issues-pr-raw/chrisns/kubectl-passman)
![GitHub closed pull requests](https://img.shields.io/github/issues-pr-closed-raw/chrisns/kubectl-passman)
![GitHub repo size](https://img.shields.io/github/repo-size/chrisns/kubectl-passman)
![GitHub contributors](https://img.shields.io/github/contributors/chrisns/kubectl-passman)
![GitHub last commit](https://img.shields.io/github/last-commit/chrisns/kubectl-passman)
[![Go Report Card](https://goreportcard.com/badge/github.com/chrisns/kubectl-passman)](https://goreportcard.com/report/github.com/chrisns/kubectl-passman)> :heavy_exclamation_mark: An easy way to store your kubernetes credentials in a keychain or password manager
### Does your `~/.kube/config` look like this:
```yaml
apiVersion: v1
kind: Config
users:
- name: my-prod-user
user:
token:
- name: docker-desktop
user:
client-certificate-data:
client-key-data:
```## :scream: :scream: :scream: :scream:
Do you scold your parents :man_teacher:/:woman_teacher: for maintaining a `passwords.doc` on their desktop?
Then you need kubectl-passman!## Works with (more coming)
Provider | Supports | Example command
--- | --- | ---
keychain | [Mac OS Keychain](https://support.apple.com/en-gb/guide/keychain-access/kyca1083/mac)
[GNOME Keyring](https://wiki.gnome.org/Projects/GnomeKeyring)
[Windows Credential Manager](http://blogs.msdn.com/b/visualstudioalm/archive/2015/12/08/announcing-the-git-credential-manager-for-windows-1-0.aspx) | `kubectl passman keychain [item] [token]`
1password | [1password](https://1password.com/)
requires [1password cli](https://1password.com/downloads/command-line/) | `kubectl passman 1password [item] [token]`
gopass | [gopass](https://www.gopass.pw/) | `kubectl passman gopass [item] [token]`## Installation
```bash
# with krew (recommended)
kubectl krew install passman# get a binary from https://github.com/chrisns/kubectl-passman/releases/latest
# place it in PATH and make sure it's called kubectl-passman# use go to get the most recent
go install github.com/chrisns/kubectl-passman
```## Usage
You need to JSON encode the credentials so that should look something like:
```json
{"token":"00000000-0000-0000-0000-000000000000"}
```or for a key pair:
```json
{
"clientCertificateData":"-----BEGIN REAL CERTIFICATE-----\nMIIC9DCCA.......-----END CERTIFICATE-----",
"clientKeyData":"-----BEGIN REAL RSA PRIVATE KEY-----\nMIIE......-----END REAL RSA PRIVATE KEY-----"
}
```or for a key pair from your kube config:
```json
{
"client-certificate-data":"LS0tLS1CRU...LS0tCg==",
"client-key-data":"LS0tLS1CRU...LS0tLS0K"
}
```If they are already in your kube config, you could retrieve them with something like:
```bash
kubectl config view --raw -o json | jq '.users[] | select(.name=="kubectl-prod-user") | .user' -c
```### Write it to the password manager
```bash
kubectl passman keychain kubectl-prod-user '[token]'
# or
kubectl passman 1password kubectl-prod-user '[token]'## so should look like:
kubectl passman 1password kubectl-prod-user '{"token":"00000000-0000-0000-0000-000000000000"}'
# or
kubectl passman 1password kubectl-prod-user '{"client-certificate-data":"...BASE64_ENCODE...","client-key-data":"...BASE64_ENCODE..."}'
```Then add it to the `~/.kube/config`:
```bash
kubectl config set-credentials \
kubectl-prod-user \
--exec-api-version=client.authentication.k8s.io/v1beta1 \
--exec-command=kubectl-passman \
--exec-arg=keychain \ # or 1password
--exec-arg=kubectl-prod-user # name of [item-name] you used when you wrote to the password manager
```## Build
``` bash
go build
```
> Note: kubectl-passman will build slightly differently on Darwin (Mac OS) to other operation systems because it uses the [go-keychain](https://github.com/keybase/go-keychain) library that needs libraries that only exist on a mac so that it can natively talk to the keychain. When compiling for other operating systems you'll get [go-keyring](https://github.com/zalando/go-keyring) instead but I've abstracted to make the interactions the same.## Contributing
I :heart: contributions, it'd be great if you could add support for your favourite password manager, work on something from the [TODO](#TODO) or any open issues as a priority, but anything else that takes your fancy too is great, though best to raise an issue to discuss before investing time into it.