#はじめに
パスワード管理するのに1passwordを買って利用していました。(月払の前に)
1passwordはすごいけど毎月お金は払いたくなかったので悩んでいました。
あるコミュニティーでpassの記事を見て「これだ」と思いました。
CLI環境でパスワード管理が出来る良いツールpassについてのメモです。
#やりたいこと
- GPGの導入
- passの導入
#環境
ubuntu 20.04
#GPGの導入
GnuPG (PGP : Pretty Good Privacy)
暗号化ソフトウェア
私もGPGに詳しくないので下記のURLを参考 ここ
インストール
yum install gnupg2
##鍵の生成
gpg2 --full-gen-key
実際生成してみたらこんな感じです。
root@b41dda24a688:/# gpg2 --full-gen-key
gpg (GnuPG) 2.2.19; Copyright (C) 2019 Free Software Foundation, Inc.
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
Please select what kind of key you want:
(1) RSA and RSA (default)
(2) DSA and Elgamal
(3) DSA (sign only)
(4) RSA (sign only)
(14) Existing key from card
Your selection?
RSA keys may be between 1024 and 4096 bits long.
What keysize do you want? (3072)
Requested keysize is 3072 bits
Please specify how long the key should be valid.
0 = key does not expire
<n> = key expires in n days
<n>w = key expires in n weeks
<n>m = key expires in n months
<n>y = key expires in n years
Key is valid for? (0)
Key does not expire at all
Is this correct? (y/N) y
GnuPG needs to construct a user ID to identify your key.
Real name: Spider-Man
Email address:
Comment: pass test
You selected this USER-ID:
"Spider-Man (pass test)"
〜
諸略
〜
pub rsa3072 2021-12-25 [SC]
F5B6DA3F9275602FFF594E3E4BEE7AEC82XXXXXX
uid Spider-Man (pass test)
sub rsa3072 2021-12-25 [E]
root@b41dda24a688:/#
passphraseを入れる画面が最後に出るので入れます。
passphraseは作成したパスワードを確認するときに利用するので覚えておきます。
作成した鍵の確認
root@b41dda24a688:/# gpg --list-keys
gpg: checking the trustdb
gpg: marginals needed: 3 completes needed: 1 trust model: pgp
gpg: depth: 0 valid: 1 signed: 0 trust: 0-, 0q, 0n, 0m, 0f, 1u
/root/.gnupg/pubring.kbx
------------------------
pub rsa3072 2021-12-15 [SC]
F5B6DA3F9275602FFF594E3E4BEE7AEC82XXXXXX
uid [ultimate] Spider-Man (pass test)
sub rsa3072 2021-12-15 [E]
root@b41dda24a688:/#
後ろの8バイトがKey ID 「82XXXXXX」です。
passの導入
ここからが本番です。
passはCLIでpasswordの管理が出来るツールです。
gitを利用して共有も簡単に出来ます。
詳しい説明は passwordstore ここに
インストール
apt-get install pass
passの初期化
先作成したKey IDを利用します。
pass init 82XXXXXX
やってみると
root@b41dda24a688:/# pass init 82XXXXXX
mkdir: created directory '/root/.password-store/'
Password store initialized for 82XXXXXX
root@b41dda24a688:/# pass
Password Store
root@b41dda24a688:/#
初期化完了です。
##パスワード作成
パスワードを作成してみます。
pass generate [Path/to/credential] [password length]
やってみると
root@b41dda24a688:/# pass generate site/google.com 16
mkdir: created directory '/root/.password-store/site'
The generated password for site/google.com is:
Z`e@^[knB-+3RX]I
root@b41dda24a688:/#
「Z`e@^[knB-+3RX]I」16文字のパスワードが作成されました。
pass insert -m [Path/to/credential]
上記のようにinsertすると情報などを入力することも出来ます。
##パスワード確認
これからは保存してあるパスワードを確認します。
root@b41dda24a688:/# pass
Password Store
`-- site
`-- google.com
root@b41dda24a688:/#
すべてのパスワードの一覧が確認出来ます。
google.comのパスワードを見たい時には
root@b41dda24a688:/# pass site/google.com
Z`e@^[knB-+3RX]I
root@b41dda24a688:/#
passphraseを入れると先作成したパスワードが見れます。
詳しくoptionはpasswordstoreで確認お願いします。
gitを利用
gitを利用することが可能です。
これで他のPCやiphoneなので共有することが簡単にできます。
ios アプリは こちら
gitの初期化、使い方
pass git init
pass git remote add origin [Repository address]
pass git push -u origin master
...
pass git pull
pass git push
passの後ろにgitをつけると私達が知っているgitを使えます。
gitで共有される中身
保存したパスワードは「/[User]/.password-store」の中に暗号化されて保存されます。
root@b41dda24a688:~/.password-store# pwd
/root/.password-store
root@b41dda24a688:~/.password-store# ll
total 24
drwx------ 4 root root 4096 Dec 15 02:45 ./
drwx------ 1 root root 4096 Dec 15 02:21 ../
drwx------ 7 root root 4096 Dec 15 02:45 .git/
-rw------- 1 root root 15 Dec 15 02:45 .gitattributes
-rw------- 1 root root 9 Dec 15 02:21 .gpg-id
drwx------ 2 root root 4096 Dec 15 02:39 site/
root@b41dda24a688:~/.password-store# cat site/google.com.gpg
��ܔڻt��
hՏ�nP���{ǃ�ۆ�L˺�=��v��B��m��r1�EH�Yδ�@�-��J���܅�S���D��ׇ>��=������5с@/�9Vp�����a������k��&�JX��H�W|��}ār��7�H�}���J��Wߓk�7�^���� �����+Wߣ�gs�g4n\A�vv�I��P����tw��!%
�T���`����%��
����tD�����MpJEB���kA��驟R��s_��y-���#���OğI��ڣ�#�
H���������>�́{t�31���ͣ������W�������B
����
����}���͖�_�Zz�c)�z��~���W>�]
root@b41dda24a688:~/.password-store#
site/google.com.gpgの中身は暗号化されています。
それをgitで共有する感じです。
もちろん、内容を見る時はさきほど利用した秘密鍵が必要です。
#最後に
GPGで暗号化するのでGPGについても勉強したりしないとですが
かなり便利です。
iOSでは顔認証で自動入力も可能なので、さらに便利です。
初期化する時鍵を複数追加すると他の人たちと利用することも可能になります。
#参考
https://www.passwordstore.org/
https://www.clien.net/service/board/lecture/12700741
https://termina.io/posts/pass-overview
passを教えてくれたヤンさんありがとうございます。