Tectia Plugins
The Tectia server can use external programs, known as plugins , for flexible handling of tasks like changing passwords [5.4.2.3], driving the process for keyboard-interactive authentication [5.4.5.2], or performing arbitrary checks for access control. [5.5.6] We’ll demonstrate how to use plugins with several examples:
Handling expired passwords
Extending keyboard-interactive authentication
Authorization
11.7.1 A Plugin for Changing Expired Passwords
Remember our discussion of expired passwords in Chapter 5? [5.4.2.3] We showed how Tectia’s SSH server can detect an expired password at authentication time, and prompt the user to change it:
$ ssh server.example.com rebecca's password:Authentication successful. < ... the following output is from running the passwd forced command ... > Changing password for user rebecca. Changing password for rebecca (current) UNIX password:
< ... old, expired password ... >
New password:
< ... old, expired password, again ... >
Retype new password:
< ... new password ... >
passwd: all authentication tokens updated successfully. Connection to server.example.com closed.
< ... new password, again ... >
The SSH server accomplishes this by calling either the system
password-change program (e.g., passwd) or an
alternative program specified by the PasswdPath
configuration keyword. This
technique, which is the default, uses a forced command to change the
password. This method is conceptually simple but has several
drawbacks:
No explicit indication ...
Get SSH, The Secure Shell: The Definitive Guide, 2nd Edition now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.