A collection of scripts to make OpenPGP key generation and YubiKey manipulation easy. Key generation and gpg setup things are inspired by the perfect key pair.
It generates "the perfect key pair", puts in some reasonable values for account / user id information and optionally transfers keys to a Yubikey device.
The Yubikey is also provided with user info and PIN setup.
The scripts do also feature a fully automatic heuristic for finding and setting up the correct (Windows) smart card slot device in case gpg does not find your Yubikey automatically.
Remember: On most installations, scripts may be interrupted by pressing Ctrl+C.
- YUBISET
- What does it do?
- Supported Environments
- Supported Yubikeys
- Prerequisites
- Download
- Usage
- For Developers
- Windows (CMD)
- Windows (git-bash)
- Unix (Bash)
- Yubikey NEO
- Yubikey 4
- Yubikey 5
The only thing you'll need is a working gpg installation:
Use the GnuPG package provided with your distribution or follow the instructions on https://gnupg.org.
https://github.com/JanMosigItemis/yubiset/releases
Every release comes as a zip file of the form yubiset_[TAG].[TIMESTAMP].zip
.
The file is accompanied by the SHA-512 hash code of the zip stored into [ZIP_FILE_NAME].sha512
. You may verify the hash code of your download like this:
# This makes sure, you downloaded an exact copy of the release from GitHub.
sha512sum -c yubiset_vt.t.t.test.201907042021.sha512
yubiset_vt.t.t.test.201907042021.zip: OK # This is the supposed output.
There is a third file called [ZIP_FILE_NAME].sha512.gpg
. This can be used to verify that the hash code has not been tempered with. The verification is done via GPG like this:
gpg --verify yubiset_vt.t.t.test.201907042021.sha512.gpg
gpg: Signature made 07/04/19 20:21:11 W. Europe Daylight Time
gpg: using RSA key 0xE9EC6651133A788F
gpg: Good signature from "Jan Mosig itemis GitHub Signing Key (Signing key for GitHub release artifacts of JanMosigItemis) <ja
n.mosig@itemis.de>" [ultimate]
Primary key fingerprint: DFC5 B2E2 74B5 A83E DC56 2A48 3622 572E E5F1 E2D4
Subkey fingerprint: BE63 6888 FDA6 4B7C E7F7 1BF7 E9EC 6651 133A 788F
If you perform both steps, there is a very high chance that your download is legit.
In case you are missing my public GitHub signing key, you can download it here: https://gist.github.com/JanMosigItemis/ce1ffd36a4ab860962009f7a9a6ff2ec. Unzip the file and import the key like this:
gpg --import JanMosigItemisGitHub.asc
cd windows\cmd
yubiset.bat
In case your Yubikey does only support subkeys of 2048bit length (like the NEO), use yubiset.bat 4
instead.
The main script will use Powershell if it is available in order to hide the passphrase input prompt. This is a measure to prevent eavesdropping. If Powershell is not available the passphrase entered will be visible to eavesdroppers. The check for Powershell and its usage are a bit slow, i. e. script loading time is increased. This is normal and not a bug.
The following scripts may be used standalone but are also called from the yubiset
main script:
cd windows\cmd
setupyubi.bat "Given Name Surname" "my.email@provider.com" "PGP key id" "passphrase"
If passphrase
is omitted, it will be prompted for. The prompt will be hidden if Powershell is available. Otherwise it will be a plain visible prompt that may be eavesdropped.
BE AWARE: Only tested with Yubikey 4 NEO and Yubikey 5
cd windows\cmd
resetyubi.bat
cd windows\cmd
findyubi.bat
It is possible to "brand" your generated keys, i. e. give the user name and the comment a custom touch e. g. for your company. This can be controlled by editing the file windows\cmd\lib\branding.bat
.
The default will produce a key like this:
sec rsa4096/0x94AF5E3D1575AC6A 2019-07-01 [C] [expires: 2020-06-30]
Key fingerprint = 3B90 7B16 76E6 9F6F 59D1 D103 94AF 5E3D 1575 AC6A
uid [ultimate] Max Muster <max.muster@host.de>
However a branding.bat
like this:
@ECHO OFF
SETLOCAL ENABLEEXTENSIONS ENABLEDELAYEDEXPANSION
REM
REM Arg 1: User name
REM
set branded_user_name=%~1 (itemis AG)
set branded_user_comment=Vocational key of itemis AG's Max Muster
REM What follows is a trick to get the variables into the context of the calling script (which should be a local context as well) without polluting the global env.
REM See https://stackoverflow.com/a/16167938
endlocal&set "branded_user_name=%branded_user_name%"&set "branded_user_comment=%branded_user_comment%"
will produce the following key:
sec rsa4096/0x94AF5E3D1575AC6A 2019-07-01 [C] [expires: 2020-06-30]
Key fingerprint = 3B90 7B16 76E6 9F6F 59D1 D103 94AF 5E3D 1575 AC6A
uid [ultimate] Max Muster (itemis AG) (Vocational OpenPGP key of itemis AG's Max Muster) <max.muster@host.de>
Be aware: GPG does not support arbitrary charaters in key comments. Especially parantheses '(' and ')' will cause problems. On Windows some additional characters may cause trouble, e. g. * ? & or %. Don't use them.
cd unix/bash
sh yubiset.sh
In case your Yubikey does only support subkeys of 2048bit length (like the NEO), use sh yubiset.sh 4
instead.
The following scripts may be used standalone but are also called from the yubiset
main script:
cd unix/bash
sh setupyubi.sh "Given Name Surname" "my.email@provider.com" "PGP key id" "passphrase"
Due to security reasons the passphrase may also be omitted. In this case the user will be prompted to enter it.
BE AWARE: Only tested with Yubikey 4 NEO and Yubikey 5
cd unix/bash
sh resetyubi.sh
cd unix/bash
sh findyubi.sh
It is possible to "brand" your generated keys, i. e. give the user name and the comment a custom touch e. g. for your company. This can be controlled by editing the file unix/bash/lib/branding.sh
.
The default will produce a key like this:
sec rsa4096/0x94AF5E3D1575AC6A 2019-07-01 [C] [expires: 2020-06-30]
Key fingerprint = 3B90 7B16 76E6 9F6F 59D1 D103 94AF 5E3D 1575 AC6A
uid [ultimate] Max Muster <max.muster@host.de>
However a branding.sh
like this:
declare -r branded_user_name="${user_name} (itemis AG)"
declare -r branded_user_comment="Vocational key of itemis AG's Max Muster"
will produce the following key:
sec rsa4096/0x94AF5E3D1575AC6A 2019-07-01 [C] [expires: 2020-06-30]
Key fingerprint = 3B90 7B16 76E6 9F6F 59D1 D103 94AF 5E3D 1575 AC6A
uid [ultimate] Max Muster (itemis AG) (Vocational OpenPGP key of itemis AG's Max Muster) <max.muster@host.de>
Be aware: GPG does not support arbitrary charaters in key comments. Especially parantheses '(' and ')' will cause problems. Don't use them.
Since the original bash scripts have been developed on Windows with git-bash and gpg4win, it was necessary to override the gpg binaries provided by git-bash with those of gpg4win.
This feature is still active and officially supported, i. e. it is possible to manually tell yubiset which binaries to use.
This is done via the YUBISET_GPG_OVERRIDE
environment varibale. Its value should be a valid path to a bash script that sets variables with paths for relevant binaries. Example:
declare -r YUBISET_GPG_BIN="/c/devtools/gnupg/bin/gpg" # absolute path to gpg binary.
declare -r YUBISET_GPG_CONNECT_AGENT="/c/devtools/gnupg/bin/gpg-connect-agent" # absolute path to gpg-connect-agent binary.
declare -r YUBISET_GPG_CONF="gpgconfw" # Bash functions or aliases are also supported.
declare -r YUBISET_SCDAEMON_IS_WINDOWS="true" # Wether or not the scdaemon in use is a Windows binary or not. With gpg4win this is true of course.
You could define the YUBISET_GPG_OVERRIDE
variable in your .bashrc
but it may be more convenient to use the ad hoc definition when running commands in bash like so:
YUBISET_GPG_OVERRIDE=/path/to/yubiset_gpg_override.sh sh yubiset.sh
The script will list the binaries in use before the start.
git clone git@github.com:JanMosigItemis/yubiset.git
Be aware that all Windows batch files need CRLF as line endings (as opposed to LF on Unix) in order for batch labels to work appropriately.
Be aware that on some file systems / operating systems generating (log) files may take some time and in order for the gpg-agent and scdaemon to recognize changes it may also take some time, so retrying probes etc. is advised in order to make sure the script does not unnecessarily fail.
This README's TOC has been generated with markdown-toc.