.TH MONKEYSPHERE-SERVER "8" "March 2009" "monkeysphere" "User Commands" .SH NAME monkeysphere\-host - Monkeysphere host admin tool. .SH SYNOPSIS .B monkeysphere\-host \fIsubcommand\fP [\fIargs\fP] .SH DESCRIPTION \fBMonkeysphere\fP is a framework to leverage the OpenPGP web of trust for OpenSSH authentication. OpenPGP keys are tracked via GnuPG, and added to the authorized_keys and known_hosts files used by OpenSSH for connection authentication. \fBmonkeysphere\-host\fP is a Monkeysphere server admin utility for managing the host's OpenPGP host key. .SH SUBCOMMANDS \fBmonkeysphere\-host\fP takes various subcommands: .TP .B import\-key FILE NAME[:PORT] Import a pem-encoded ssh secret host key from file FILE. If FILE is `\-', then the key will be imported from stdin. Only RSA keys are supported at the moment. NAME[:PORT] is used to specify the fully-qualified hostname (and port) used in the user ID of the new OpenPGP key. If PORT is not specified, then no port is added to the user ID, which means port 22 is assumed. `i' may be used in place of `import\-key'. .TP .B show\-key Output information about host's OpenPGP and SSH keys. `s' may be used in place of `show\-key'. .TP .B set\-expire [EXPIRE] Extend the validity of the OpenPGP key for the host until EXPIRE from the present. If EXPIRE is not specified, then the user will be prompted for the extension term. Expiration is specified as with GnuPG (measured from today's date): .nf 0 = key does not expire <n> = key expires in n days <n>w = key expires in n weeks <n>m = key expires in n months <n>y = key expires in n years .fi `e' may be used in place of `set\-expire'. .TP .B add\-hostname HOSTNAME Add a hostname user ID to the server host key. `n+' may be used in place of `add\-hostname'. .TP .B revoke\-hostname HOSTNAME Revoke a hostname user ID from the server host key. `n\-' may be used in place of `revoke\-hostname'. .TP .B add\-revoker KEYID|FILE Add a revoker to the host's OpenPGP key. The key ID will be loaded from the keyserver. A file may be loaded instead of pulling the key from the keyserver by specifying the path to the file as the argument, or by specifying `\-' to load from stdin. `r+' may be be used in place of `add-revoker'. .TP .B revoke\-key Generate (with the option to publish) a revocation certificate for the host's OpenPGP key. If such a certificate is published, your host key will be permanently revoked. This subcommand will ask you a series of questions, and then generate a key revocation certificate, sending it to stdout. If you explicitly tell it to publish the revocation certificate immediately, it will send it to the public keyservers. USE WITH CAUTION! .TP .B publish\-key Publish the host's OpenPGP key to the public keyservers. `p' may be used in place of `publish-key'. Note that there is no way to remove a key from the public keyservers once it is published! .TP .B version Show the monkeysphere version number. `v' may be used in place of `version'. .TP .B help Output a brief usage summary. `h' or `?' may be used in place of `help'. Other commands: .TP .B diagnostics Review the state of the monkeysphere server host key and report on suggested changes. Among other checks, this includes making sure there is a valid host key, that the key is not expired, that the sshd configuration points to the right place, etc. `d' may be used in place of `diagnostics'. .SH SETUP HOST AUTHENTICATION To enable host verification via the monkeysphere, an OpenPGP key must be made out of the host's ssh key, and the key must be published to the Web of Trust. This is not done by default. The first step is to import the host's ssh key into a monkeysphere-style OpenPGP key. This is done with the import\-key command. When importing a key, you must specify the path to the host's ssh RSA key to import, and a hostname to use as the key's user ID: # monkeysphere\-host import\-key /etc/ssh/ssh_host_rsa_key host.example.org On most systems, the ssh host RSA key is stored at /etc/ssh/ssh_host_rsa_key. Once the host key has been imported, it must be published to the Web of Trust so that users can retrieve the key when sshing to the host. The host key is published to the keyserver with the publish\-key command: $ monkeysphere\-host publish\-key In order for users logging into the system to be able to identify the host via the monkeysphere, at least one person (e.g. a server admin) will need to sign the host's key. This is done using standard OpenPGP keysigning techniques, usually: pull the key from the keyserver, verify and sign the key, and then re-publish the signature. Please see http://web.monkeysphere.info/signing-host-keys/ for more information. Once an admin's signature is published, users logging into the host can use it to validate the host's key without having to manually check the host key's fingerprint. .SH ENVIRONMENT The following environment variables will override those specified in the config file (defaults in parentheses): .TP MONKEYSPHERE_LOG_LEVEL Set the log level. Can be SILENT, ERROR, INFO, VERBOSE, DEBUG, in increasing order of verbosity. (INFO) .TP MONKEYSPHERE_KEYSERVER OpenPGP keyserver to use. (pool.sks\-keyservers.net) .TP MONKEYSPHERE_PROMPT If set to `false', never prompt the user for confirmation. (true) .SH FILES .TP /etc/monkeysphere/monkeysphere\-host.conf System monkeysphere\-host config file. .TP /var/lib/monkeysphere/host/ssh_host_rsa_key.pub.gpg A world-readable copy of the host's public key in OpenPGP format, including all relevant self-signatures. .SH AUTHOR This man page was written by: Jameson Rollins <jrollins@fifthhorseman.net>, Daniel Kahn Gillmor <dkg@fifthhorseman.net>, Matthew Goins <mjgoins@openflows.com> .SH SEE ALSO .BR monkeysphere (1), .BR monkeysphere\-authentication (8), .BR monkeysphere (7), .BR gpg (1), .BR ssh (1), .BR sshd (8)