2015-05-26 01:31:44 +02:00
---
layout: doc
title: YubiKey in Qubes
2015-10-28 22:14:40 +00:00
permalink: /doc/yubi-key/
redirect_from:
- /en/doc/yubi-key/
- /doc/YubiKey/
2015-05-26 01:31:44 +02:00
---
Using YubiKey to Qubes authentication
=====================================
You can use YubiKey to enhance Qubes user authentication, for example to mitigate
2018-02-03 14:51:06 -06:00
risk of snooping the password. This can also slightly improve security when you have [USB keyboard ](/doc/usb/#security-warning-about-usb-input-devices ).
2015-05-26 01:31:44 +02:00
2016-02-21 19:07:55 +01:00
There (at least) two possible configurations: using OTP mode and using challenge-response mode.
2015-05-26 01:31:44 +02:00
OTP mode
--------
This can be configured using
[app-linux-yubikey ](https://github.com/adubois/qubes-app-linux-yubikey )
package. This package does not support sharing the same key slot with other
applications (it will deny further authentications if you try).
2017-05-25 16:43:11 +10:00
Contrary to instruction there, currently there is no binary package in the Qubes
2017-05-11 18:48:59 +10:00
repository and you need to compile it yourself. This might change in the future.
2015-05-26 01:31:44 +02:00
2017-05-12 15:58:22 +10:00
Challenge-response mode
2015-05-26 01:31:44 +02:00
----------------------
2017-05-25 16:43:11 +10:00
In this mode, your YubiKey will generate a response based on the secret key, and
2015-05-26 01:31:44 +02:00
random challenge (instead of counter). This means that it isn't possible to
2017-05-25 16:43:11 +10:00
generate a response in advance even if someone gets access to your YubiKey. This
2017-05-11 18:48:59 +10:00
makes it reasonably safe to use the same YubiKey for other services (also in
2015-05-26 01:31:44 +02:00
challenge-response mode).
2017-05-25 16:43:11 +10:00
Same as in the OTP case, you will need to set up your YubiKey, choose a separate
2015-05-26 01:31:44 +02:00
password (other than your login password!) and apply the configuration.
2017-05-11 18:48:59 +10:00
To use this mode you need to:
2015-05-26 01:31:44 +02:00
2017-05-11 18:48:59 +10:00
1. Configure your YubiKey for challenge-response HMAC-SHA1 mode, for example
2015-05-26 01:31:44 +02:00
[following this
tutorial](https://www.yubico.com/products/services-software/personalization-tools/challenge-response/)
2017-05-25 16:43:11 +10:00
2. Install the `ykpers` package in template on which your USB VM is based.
2018-01-12 13:59:28 +01:00
3. Create `/usr/local/bin/yubikey-auth` script in dom0:
2015-05-26 01:31:44 +02:00
#!/bin/sh
key="$1"
if [ -z "$key" ]; then
echo "Usage: $0 < AESKEY > [< PASSWORD-HASH > ]"
exit 1
fi
# if password has given, verify it
if [ -n "$2" ]; then
# PAM appends \0 at the end
hash=`head -c -1 | openssl dgst -sha1 -r | cut -f1 -d ' '`
if [ "x$2" != "x$hash" ]; then
exit 1
fi
fi
challenge=`head -c64 /dev/urandom | xxd -c 64 -ps`
# You may need to adjust slot number and USB VM name here
2015-06-19 09:07:09 +02:00
response=`qvm-run -u root --nogui -p sys-usb "ykchalresp -2 -x $challenge"`
2015-05-26 01:31:44 +02:00
correct_response=`echo $challenge | xxd -r -ps | openssl dgst -sha1 -macopt hexkey:$key -mac HMAC -r | cut -f1 -d ' '`
test "x$correct_response" = "x$response"
exit $?
4. Adjust USB VM name (`sys-usb` above), and possibly YubiKey slot number (`2`
above), then make the script executable.
5. Edit `/etc/pam.d/xscreensaver` (or appropriate file if you are using other
screen locker program). Add this line at the beginning:
auth [success=done default=ignore] pam_exec.so expose_authtok quiet /usr/local/bin/yubikey-auth AESKEY PASSWORD-HASH
Replace `AESKEY` with hex-encoded key configured in the first step, then
replace `PASSWORD-HASH` with SHA1 hash for your YubiKey-linked password (other
than your standard Qubes password). You can calculate it using this command:
echo -n "PASSWORD" | openssl dgst -sha1
### Usage
2017-11-14 00:39:28 +01:00
When you want to unlock your screen...
1) Plug YubiKey into USB slot.
2) Enter password associated with YubiKey.
3) Press Enter.
4) If you configured so, YubiKey will request confirmation by pressing button on it (it will blink).
2015-05-26 01:31:44 +02:00
When everything is ok, your screen will be unlocked.
2017-05-11 18:48:59 +10:00
In any case you can still use your login password, but do it in a secure location
2015-05-26 01:31:44 +02:00
where no one can snoop your password.
2015-07-22 03:57:31 +02:00
Locking the screen when YubiKey is removed
------------------------------------------
2017-05-25 16:43:11 +10:00
You can setup your system to automatically lock the screen when you unplug your
2017-05-11 18:48:59 +10:00
YubiKey. This will require creating a simple qrexec service which will expose
2017-05-25 16:43:11 +10:00
the ability to lock the screen to your USB VM, and then adding a udev hook to
2015-07-22 03:57:31 +02:00
actually call that service.
2017-11-14 00:46:52 +01:00
In dom0:
1. First configure the qrexec service. Create `/etc/qubes-rpc/custom.LockScreen`
2017-05-12 10:12:02 +10:00
with a simple command to lock the screen. In the case of xscreensaver (used in Xfce)
2015-07-22 03:57:31 +02:00
it would be:
DISPLAY=:0 xscreensaver-command -lock
2017-05-11 18:48:59 +10:00
2. Allow your USB VM to call that service. Assuming that it's named `sys-usb` it
2015-07-22 03:57:31 +02:00
would require creating `/etc/qubes-rpc/policy/custom.LockScreen` with:
sys-usb dom0 allow
2017-11-14 00:46:52 +01:00
In your USB VM:
3. Create udev hook. Store it in `/rw/config` to have it
2017-05-25 17:14:49 +10:00
persist across VM restarts. For example name the file
2017-05-25 16:43:11 +10:00
`/rw/config/yubikey.rules` . Add the following line:
2015-07-22 03:57:31 +02:00
ACTION=="remove", SUBSYSTEM=="usb", ENV{ID_SECURITY_TOKEN}=="1", RUN+="/usr/bin/qrexec-client-vm dom0 custom.LockScreen"
4. Ensure that the udev hook is placed in the right place after VM restart. Append to `/rw/config/rc.local` :
ln -s /rw/config/yubikey.rules /etc/udev/rules.d/
udevadm control --reload
2017-11-14 00:46:52 +01:00
5. Then make `/rw/config/rc.local` executable.
sudo chmod +x /rw/config/rc.local
6. For changes to take effect, you need to call this script manually for the first time.
sudo /rw/config/rc.local
2015-07-22 03:57:31 +02:00
If you use KDE, the command(s) in first step would be different:
2017-05-12 10:12:02 +10:00
# In the case of USB VM being autostarted, it will not have direct access to D-Bus
2015-07-22 03:57:31 +02:00
# session bus, so find its address manually:
kde_pid=`pidof kdeinit4`
export `cat /proc/$kde_pid/environ|grep -ao 'DBUS_SESSION_BUS_ADDRESS=[[:graph:]]*'`
qdbus org.freedesktop.ScreenSaver /ScreenSaver Lock