|   | 
ssh-keygen-g3 (ssh-keygen-g3.exe on Windows) is a tool that generates and manages authentication keys for Secure Shell. Each user wishing to use a Secure Shell client with public-key authentication can run this tool to create authentication keys. Additionally, the system administrator can use this to generate host keys for the Secure Shell server. This tool can also convert OpenSSH public or private keys to the Tectia key format, or, from Tectia key format to openSSH format. Tectia public keys use the Secure Shell (SSH) Public Key File Format (RFC 4716).
By default, if no path for the key files is specified, the key pair is generated under the
      user's home directory ($HOME/.ssh2 on Unix,
      "%APPDATA%\SSH\UserKeys" on Windows). If no file name is specified, the
      key pair is likewise stored under the user's home directory with such file names as
      id_rsa_2048_a and id_rsa_2048_a.pub.
When specifying file paths or other strings that contain spaces, enclose them in quotation marks ("").
The following options are available:
-1 fileConverts a key file from the SSH1 format to the SSH2 format. Note:
              "1" is number one (not letter L).
-7 fileExtracts certificates from a PKCS #7 file.
-b bitsSpecifies the length of the generated key in bits. The allowed and default lengths for different key types are:
DSA/RSA: allowed 512 to 65536 bits, default 2048 bits
ECDSA: allowed 256, 384 and 521 bits, default 256 bits
Ed25519: allowed/default 512 bits
-B numSpecifies the number base for displaying key information (default:
              10).
-c commentSpecifies a comment string for the generated key.
-D fileDerives the public key from the private key file.
-e fileEdits the specified key. Makes ssh-keygen-g3 interactive. You can change the key's passphrase or comment.
-F, --fingerprint fileDumps the fingerprint and type (RSA, DSA, ECDSA or Ed25519) of the given public key. By
            default, the fingerprint is given in the SSH Babble format, which makes the fingerprint
            look like a string of "real" words (making it easier to pronounce). The output format
            can be changed with the --fingerprint-type option.
The following options can be also used to modify the behavior of this option:
            --fingerprint-type
            --hash, --hostkeys-directory,
            --known-hosts, --rfc4716.
-F, --fingerprint host_IDDumps the location, fingerprint and type (RSA, DSA, ECDSA or Ed25519) of the locally stored
            host key(s) identified with the given host_ID. The
            host_ID is a host name or string
            "host#port".
The following options can be used to modify the behavior of this option:
              --fingerprint-type, --hash,
              --hostkeys-directory, --known-hosts,
              --rfc4716.
-H, --hostkey
        Stores the generated key pair in the default host key directory
            (/etc/ssh2 on Unix,
            "<INSTALLDIR>\SSH Tectia Server" on Windows). Specify
            the -P option to store the private key with an empty passphrase.
-i fileLoads and displays information on the key file. 
-k fileConverts a PKCS #12 file to an SSH2-format certificate and private key.
-m, --generate-moduli-fileGenerates moduli file secsh_dh_gex_moduli for Diffie-Hellman
            group exchange.
-p passphraseSpecifies the passphrase for the generated key.
-P
        Specifies that the generated key will be saved with an empty passphrase.
| ![[Note]](images/note.gif) | Note | 
|---|---|
| In FIPS mode, due to a FIPS regulation which forbids exporting unencrypted private keys out of the FIPS module, it is not possible to generate user keys without a passphrase. | 
-q, --quiet
        Hides the progress indicator during key generation.
-r fileAdds entropy from file to the random pool. If
              file contains 'relatively random' data (i.e. data
            unpredictable by a potential attacker), the randomness of the pool is increased. Good
            randomness is essential for the security of the generated keys.
-t    
                dsa  |   rsa  |   ecdsa  |   ed25519  
             
Selects the type of the key. Valid values are rsa (default),
            dsa, ecdsa, and ed25519. 
-x fileConverts a private key from the X.509 format to the SSH2 format.
--append  [
                =yes  |   no  
            ]
Appends the keys. Optional values are yes and no.
            The default is yes to append. 
--copy-host-id host_ID  destinationCopies the host identity to the specified destination directory.
The following options can be used to modify the behavior of this option:
              --append, --hostkeys-directory,
              --known-hosts, --overwrite.
If --hostkey-file is given, the file is treated as a normal host
            identity file used by the Connection Broker, and its contents will be copied to the destination
            directory. 
--delete-host-id host_IDDeletes the host key of the specified host ID. The
            host_ID is a host name or string
            "host#port".
The following options can be used to modify the behavior of this option:
            --host-key-file, --hostkeys-directory,
            --known-hosts.
--fingerprint-type    
                babble  |   babble-upper  |   pgp-2  |   pgp-5  |   hex  |   hex-upper  |   base64  
             
Specifies the output format of the fingerprint. If this option is given, the
              -F option and the key file name must precede it. The default format
            is babble.
See the section called “Examples” for examples of using this option.
--fips-mode
        Generates the key using the FIPS mode for the cryptographic library.
| ![[Note]](images/note.gif) | Note | 
|---|---|
| Ed25519 keys are not available in FIPS mode. | 
On Linux, Windows, Solaris and HP-UX Itanium the OpenSSL cryptographic library version 1.0.2a is used and in the FIPS mode (conforming to FIPS 186-3) keys of the following lengths can be generated:
DSA keys: 1024, 2048 and 3072 bits
RSA keys: n * 512 bits, where 2 ≤ n ≤ 24 (that is, 1024, 1536, ... , 11776, and 12288 bits)
ECDSA keys: 256, 384 and 521 bits
On HP-UX PA-RISC and IBM AIX the OpenSSL cryptographic library version 0.9.8 is used and in the FIPS mode (conforming to FIPS 186-2) DSA keys of 1024 bits and RSA keys of 1024 to 16384 bits can be generated. ECDSA keys cannot be generated.
The keys must have non-empty passphrases.
By default (if this option is not given), the key is generated using the standard mode for the cryptographic library.
--fips-crypto-dll-path PATHSpecifies the location of the FIPS cryptographic DLL.
--hash    
                md5  |   sha1  |   sha256  
             
Specifies the digest algorithm for fingerprint generation. Valid options are
              md5, sha1, and sha256.
--hostkey-file fileWhen copying, uses the given file as the source host key, instead of autodetecting the location. When deleting, only deletes from the given location. If the specified file does not contain identities for the specified host, does nothing.
--hostkeys-directory directorySpecifies the directory for known host keys to be used instead of the default location.
--import-public-key infile  [outfile]Attempts to import a public key from infile and store it
            to outfile in the format specified by --key-format parameter.
            If outfile is not given, it will be requested. The default
            output format is SSH2 native format. 
--import-private-key infile  [outfile]Attempts to import a private key from infile and store it
            to outfile in the format specified by --key-format parameter.
            If outfile is not given, it will be requested. The default
            output format is SSH2 native private key format.
--import-ssh1-authorized-keys infile outfileImports an SSH1-style authorized_keys file infile and
            generates an SSH2-style authorization file outfile, and
            stores the keys from infile to generated files into the same
            directory with outfile.
--key-format formatOutput key format: secsh2, pkcs1, pkcs8, pkcs12, openssh2, or openssh2-aes.
--key-hash hashThis option can be used for other than Tectia key formats. Specifies the hash
            algorithm to be used in passphrase-based private key derivation. The default value is
              sha1. Other supported algorithms are sha224,
              sha256, sha384, and sha512. Note
            that all key formats do not support all hash algorithms. 
--known-hosts fileUses the specified known hosts file. Enables fetching fingerprints for hosts defined
            in an OpenSSH-style known-hosts file. Using this option overrides the default locations
            of known_hosts files (/etc/ssh/ssh_known_hosts
            and $HOME/.ssh/known_hosts). Giving an empty string will disable
            known-hosts usage altogether. 
--moduli-file-name file Writes the moduli generated for Diffie-Hellman group exchange to
              file. (The default file name for option -m
            is secsh_dh_gex_moduli.) 
--overwrite  [
                =yes  |   no  
            ]
Overwrite files with the same file names. The default is to overwrite.
--rfc4716
        Displays the fingerprint in the format specified in RFC4716. The digest algorithm (hash) is md5, and the output format is the 16-bytes output in lowercase HEX separated with colons (:).
--set-hostkey-owner-and-dacl fileOn Windows, sets the correct owner and DACL (discretionary access control list) for
            the host key file. This option is used internally when a host
            key is generated during Tectia Server installation.
-V
        Displays version string and exits.
-h, --help, -?
        Displays a short summary of command-line options and exits.
Create a 3072-bit RSA key pair using the cryptographic library in the
        FIPS mode and store the key pair in the default user key directory with file names
        newkey and newkey.pub:
$ ssh-keygen-g3 --fips-mode -b 3072 newkeyConvert an SSH1 key oldkey to SSH2 format:
$ ssh-keygen-g3 -1 oldkey
Display the fingerprint of a server host public key in SSH babble (default) format:
$ ssh-keygen-g3 -F hostkey.pub Fingerprint for key: xeneh-fyvam-sotaf-gutuv-rahih-kipod-poten-byfam-hufeh-tydym-syxex
Display the fingerprint of a server host public key in hex format:
$ ssh-keygen-g3 -F hostkey.pub --fingerprint-type=hex Fingerprint for key: 25533b8c7734f6eb1556ea2ab4900d854d5d088c
Convert a private key into openSSH2-AES format:
$ ssh-keygen-g3 -p <password> --key-format openssh2-aes \ --import-private-key <source_key_file> <destination_key_file>
Note: if the private key file that is being converted is encrypted with a passphrase, the passphrase must be provided with the '-p' option.
Convert a Tectia public key tectiakey.pub to an OpenSSH public key
        opensshkey.pub:
$ ssh-keygen-g3 --key-format openssh2 --import-public-key \ tectiakey.pub opensshkey.pub
Generate moduli file dhgex-moduli for Diffie-Hellman group exchange: 
$ ssh-keygen-g3 -m --moduli-file-name dhgex-moduli