Skip to content

Latest commit

 

History

History
178 lines (119 loc) · 8.81 KB

File metadata and controls

178 lines (119 loc) · 8.81 KB

Howdy provides Windows Hello™ style authentication for Linux. Use your built-in IR emitters and camera in combination with facial recognition to prove who you are.

Using the central authentication system (PAM), this works everywhere you would otherwise need your password: Login, lock screen, sudo, su, etc.

Installation

Howdy is currently available and packaged for Debian/Ubuntu, Arch Linux, Fedora and openSUSE. If you’re interested in packaging Howdy for your distro, don’t hesitate to open an issue.

Note: The build of dlib can hang on 100% for over a minute, give it time.

Ubuntu or Linux Mint

Run the installer by pasting (ctrl+shift+V) the following commands into the terminal one at a time:

sudo add-apt-repository ppa:boltgolt/howdy
sudo apt update
sudo apt install howdy

This will guide you through the installation.

Debian

Download the .deb file from the Releases page and install with gdebi.

Arch Linux

Maintainer wanted.

Install the howdy package from the AUR. For AUR installation instructions, take a look at this wiki page.

You will need to do some additional configuration steps. Please read the ArchWiki entry for more information.

Fedora

Maintainer: @luyatshimbalanga

The howdy package is available as a Fedora COPR repository, install it by simply executing the following commands in a terminal:

sudo dnf copr enable principis/howdy
sudo dnf --refresh install howdy

Note: Fedora 41 removed support for Python2, but at this point in time Howdy still depends on it. If the install fails, you can fix this by installing the beta Repository and removing the release version:

sudo dnf copr remove principis/howdy
sudo dnf copr enable principis/howdy-beta
sudo dnf --refresh install howdy

See the link to the COPR repository for detailed configuration steps.

openSUSE

Maintainer: @dmafanasyev

Go to the openSUSE wiki page for detailed installation instructions.

Building from source

If you want to build Howdy from source, a few dependencies are required.

Dependencies

  • Python 3.6 or higher
    • pip
    • setuptools
    • wheel
  • meson version 0.64 or higher
  • ninja
  • INIReader (can be pulled from git automatically if not found)
  • libevdev

To install them on Debian/Ubuntu for example:

sudo apt-get update && sudo apt-get install -y \
python3 python3-pip python3-setuptools python3-wheel \
cmake make build-essential \
libpam0g-dev libinih-dev libevdev-dev python3-opencv \
python3-dev libopencv-dev

Build

meson setup build
meson compile -C build

You can also install Howdy to your system with meson install -C build.

Setup

After installation, Howdy needs to learn what you look like so it can recognise you later. Run sudo howdy add to add a face model.

If nothing went wrong we should be able to run sudo by just showing your face. Open a new terminal and run sudo -i to see it in action. Please check this wiki page if you're experiencing problems or search for similar issues.

If you're curious you can run sudo howdy config to open the central config file and see the options Howdy has to offer. On most systems this will open the nano editor, where you have to press ctrl+x to save your changes.

CLI

The installer adds a howdy command to manage face models for the current user. Use howdy --help or man howdy to list the available options.

Usage:

howdy [-U user] [-y] command [argument]
Command Description
add Add a new face model for a user
clear Remove all face models for a user
config Open the config file in your default editor
disable Disable or enable howdy
list List all saved face models for a user
remove Remove a specific model for a user
snapshot Take a snapshot of your camera input
test Test the camera and recognition methods
version Print the current version number

Contributing

The easiest ways to contribute to Howdy is by starring the repository and opening GitHub issues for features you'd like to see. If you want to do more, you can also buy me a coffee.

Code contributions are also very welcome. If you want to port Howdy to another distro, feel free to open an issue for that too.

Troubleshooting

Any Python errors get logged directly into the console and should indicate what went wrong. If authentication still fails but no errors are printed, you could take a look at the last lines in /var/log/auth.log to see if anything has been reported there.

Please first check the wiki on common issues and if you encounter an error that hasn't been reported yet, don't be afraid to open a new issue.

Hardware notes

ASUS laptops with Sonix IR cameras (3277:0018 and similar)

On a number of ASUS laptops (Vivobook X1607C, ProArt PX13, ProArt H7606WX, Zenbook S16 UM5606, …), the IR emitter is controlled by the laptop's proximity sensor, not by a UVC extension-unit control. The LED sleeps when no motion is detected in front of the camera and pulses on when a person sits down to authenticate. This means:

  • howdy test shows a black feed when no one is in front of the camera. That is expected — your face entering the frame at auth time triggers the LED.
  • Do not run linux-enable-ir-emitter configure on these models. Its brute-force step has been reported to wedge the USB bus on the Sonix 3277:0018 chipset, requiring a hard reboot (see linux-enable-ir-emitter#195). It will not find a working sequence anyway, because the LED is not chipset-controlled.
  • Howdy works out of the box with device_path = /dev/video2 (or whichever node is the IR camera) on these models — no extra configuration required.

On many of these laptops the IR LED emitter is physically located in the same bezel cutout as the RGB camera, not in the IR-camera cutout. If you use a privacy shutter, covering "the regular camera" can dim the IR feed even though Howdy never opens the RGB device. You can verify this by holding a phone camera in front of the bezel while running howdy test — the IR LED is visible as a faint violet/white blink through the phone screen, and it will be in the RGB cutout, not the IR one.

For background data and the empirical investigation that led to these notes, see #1109.

A note on security

This package is in no way as secure as a password and will never be. Although it's harder to fool than normal face recognition, a person who looks similar to you, or a well-printed photo of you could be enough to do it. Howdy is a more quick and convenient way of logging in, not a more secure one.

To minimize the chance of this program being compromised, it's recommended to leave Howdy in /lib/security and to keep it read-only.

DO NOT USE HOWDY AS THE SOLE AUTHENTICATION METHOD FOR YOUR SYSTEM.