SSH AuthorizedKeysCommand for Trust Manager System (TMS)
Command line program to support the SSH AuthorizedKeysCommand option for retrieving authorized public keys for a user during ssh login.
This program accepts 4 arguments and calls the Trust Manager System (TMS) server to fetch the associated public key. Public keys are looked up using the login username and fingerprint of the public key. If a public key is found it is written to stdout. If no public key is found then nothing is written to stdout. All other output is written to the log file.
The following 4 arguments must be passed in on the command line:
- %u - login username (used in key lookup)
- %U - numeric login user id (info only)
- %f - fingerprint of the public key to be fetched (used in key lookup)
- %t - ssh key type (info only)
Example:
tms_keycmd.sh jdoe 1001 SHA256:I/YLbfco8m4WWZSDSNZ/OnV26tt+BgtFAcAb94Co974 ssh-rsa
The main program is written in rust. There is also a wrapper shell script that allows the program to be invoked from an arbitrary location and still locate the tms_keycmd configuration files.
Building the program uses the standard rust ecosystem. For a debug version run
cargo build
. For the release version run cargo build --release
.
To build and package the program simply run the script located at deployment/build_package.sh. This will create the file tms_keycmd.tgz in the current working directory.
To install the program on a host, create a local user named tms
and then
copy the tar file to the host and unpack it in the desired location.
For example, if the tar file is at /tmp/tms_keycmd.tgz and the desired installation directory is
/etc/ssh/tms_keycmd
, then as root run commands similar to the following:
chown tms:tms /tmp/tms_keycmd.tgz
mkdir -p /etc/ssh/tms_keycmd/logs
touch /etc/ssh/tms_keycmd/logs/tms_keycmd.log
cd /etc/ssh/tms_keycmd
tar -xvf /tmp/tms_keycmd.tgz
chown tms:tms -R *
chown root:tms . tms_keycmd.sh
chmod go-r . *
chmod go-w .
chmod +x tms_keycmd tms_keycmd.sh
chmod g+r tms_keycmd.sh
Then be sure to configure tms_keycmd and SSHD using the instructions below. In particular, remember to update the files tms_keycmd.toml and sshd_config before the final step of re-starting the sshd service.
Note that ownership is changed to the user tms because we will configure SSHD to run as this user.
The tms_keycmd program must have its configuration files owned by the user running the program.
If SSHD is configured to run as a user other than tms then you must update ownership to that user.
Note also that SSHD requires that the AuthorizedKeysCommand be owned by root
and not writable by
group or others.
The program reads its settings from the configuration file tms_keycmd.toml
.
There are two entries in this file and they must both be modified. The entries
are:
- tms_url: The URL for the TMS server
- host_name: The host name to use when calling the TMS server to fetch a public key.
For example:
tms_url="https://tms-test-server1.tacc.utexas.edu:32201/v1/tms/pubkeys/creds/retrieve"
host_name="stampede3"
Note that the attribute host_name
does not need to match the host name reported
by the operating system. It is up to the TMS administrator to set the host name
correctly. Having this attribute independent of the host name reported by the
operating system allows for supporting a machine that might be referenced using
many different host names, such as login1.stampede3.tacc.utexas.edu
,
stampede3.tacc.utexas.edu
, stampede3
, 129.114.63.133
, etc.
For example, for the Tapis v3 deployment at TACC, any Tapis system registered using
any of the aforementioned host names will route to the same cluster.
To configure a host to make use of tms_keycmd, the sshd configuration file on
the host must be modified. The configuration file may be found, for example,
at /etc/ssh/sshd_config
.
Two settings must be updated, AuthorizedKeysCommand and AuthorizedKeysCommandUser. If no AuthorizedKeysCommand has been configured previously, the two entries in the configuration file might look like this:
#AuthorizedKeysCommand none
#AuthorizedKeysCommandUser nobody
To configure sshd for tms_keycmd, uncomment both lines and replace none
with the
command used to invoke the tms_keycmd program. For example, if tms_keycmd is installed
in directory /etc/ssh/tms_keycmd
, the updated lines would look like this:
AuthorizedKeysCommand /etc/ssh/tms_keycmd/tms_keycmd.sh %u %U %f %t
AuthorizedKeysCommandUser tms
Note that SSHD requires that the AuthorizedKeysCommand be owned by root
and not writable by
group or others.
Finally, as user root, re-start the sshd service:
systemctl restart sshd.service