kfutil
is a go-lang CLI wrapper for Keyfactor Command API. It also includes other utility/helper functions around
automating common Keyfactor Command operations.
This API client allows for programmatic management of Keyfactor resources.
Keyfactor Command Utility (kfutil) is open source and supported on best effort level for this tool/library/client. This means customers can report Bugs, Feature Requests, Documentation amendment or questions as well as requests for customer information required for setup that needs Keyfactor access to obtain. Such requests do not follow normal SLA commitments for response or resolution. If you have a support issue, please open a support ticket via the Keyfactor Support Portal at https://support.keyfactor.com/
To report a problem or suggest a new feature, use the Issues tab. If you want to contribute actual bug fixes or proposed enhancements, use the Pull requests tab.
- jq CLI tool, used to parse JSON output.
- Either
- unzip CLI tool, used to unzip the release
- openssl CLI tool, used to validate package checksum.
$HOME/.local/bin
in your$PATH
and exists if not running as root, else/usr/local/bin
if running as root.
bash <(curl -s https://raw.githubusercontent.com/Keyfactor/kfutil/main/install.sh)
- Powershell 5.1 or later
Invoke-WebRequest -Uri "https://raw.githubusercontent.com/Keyfactor/kfutil/main/install.ps1" -OutFile "install.ps1"
# Install kfutil to $HOME/AppData/Local/Microsoft/WindowsApps.
# Use Get-Help .\install.ps1 -Full for help and examples.
.\install.ps1
Name | Description | Default |
---|---|---|
KEYFACTOR_HOSTNAME | Keyfactor Command hostname without protocol and port | |
KEYFACTOR_PORT | Keyfactor Command port | 443 |
KEYFACTOR_API_PATH | Keyfactor Command API Path | KeyfactorAPI |
KEYFACTOR_SKIP_VERIFY | Skip TLS verification when connecting to Keyfactor Command | false |
KEYFACTOR_CA_CERT | Either a file path or PEM encoded string to a CA certificate to trust when communicating with Keyfactor Command | |
KEYFACTOR_CLIENT_TIMEOUT | Timeout for HTTP client requests to Keyfactor Command | 60s |
KEYFACTOR_AUTH_CONFIG_FILE | Path to a JSON file containing the authentication configuration | $HOME/.keyfactor/command_config.json |
KEYFACTOR_AUTH_CONFIG_PROFILE | Profile to use from the authentication configuration file | default |
Currently Basic Authentication
via Active Directory
is the ONLY supported method of Basic Authentication
.
Name | Description | Default |
---|---|---|
KEYFACTOR_USERNAME | Active Directory username to authenticate to Keyfactor Command API | |
KEYFACTOR_PASSWORD | Password associated with Active Directory username to authenticate to Keyfactor Command API | |
KEYFACTOR_DOMAIN | Active Directory domain of user. Can be implied from username if it contains @ or \\ |
Name | Description | Default |
---|---|---|
KEYFACTOR_AUTH_CLIENT_ID | Keyfactor Auth Client ID | |
KEYFACTOR_AUTH_CLIENT_SECRET | Keyfactor Auth Client Secret | |
KEYFACTOR_AUTH_TOKEN_URL | URL to request an access token from Keyfactor Auth | |
KEYFACTOR_AUTH_SCOPES | Scopes to request when authenticating to Keyfactor Command API. Each scope MUST be separated by , |
openid |
KEYFACTOR_AUTH_AUDIENCE | Audience to request when authenticating to Keyfactor Command API | |
KEYFACTOR_AUTH_ACCESS_TOKEN | Access token to use to authenticate to Keyfactor Command API. This can be supplied directly or generated via client credentials | |
KEYFACTOR_AUTH_CA_CERT | Either a file path or PEM encoded string to a CA certificate to use when connecting to Keyfactor Auth |
All the variables listed below need to be set in your environment. The kfutil
command will look for these variables
and use them if they are set.
Variable Name | Description |
---|---|
KFUTIL_EXP | Set to 1 or true to enable experimental features. |
KFUTIL_DEBUG | Set to 1 or true to enable debug logging. |
Below are examples of setting the environment variables in Linux/MacOS to be used with kfutil
.
This is the minimum required configuration to authenticate to Keyfactor Command using Active Directory username, password auth.
export KEYFACTOR_HOSTNAME="<mykeyfactorhost.mydomain.com>"
export KEYFACTOR_USERNAME="<myusername>"
export KEYFACTOR_PASSWORD="<mypassword>"
export KEYFACTOR_DOMAIN="<mykeyfactordomain>" # Optional if username contains domain
This is the minimum required configuration to authenticate to Keyfactor Command using oAuth client credentials.
export KEYFACTOR_HOSTNAME="<mykeyfactorhost.mydomain.com>"
export KEYFACTOR_AUTH_CLIENT_ID="<my-oauth2-client-id"
export KEYFACTOR_AUTH_CLIENT_SECRET="<my-oauth2-client-secret>"
export KEYFACTOR_AUTH_TOKEN_URL="<mykeyfactorhost.mydomain.com>/protocol/openid-connect/token"
This is the minimum required configuration to authenticate to Keyfactor Command using an access token.
export KEYFACTOR_HOSTNAME="<mykeyfactorhost.mydomain.com>"
export KEYFACTOR_AUTH_ACCESS_TOKEN="<my-access-token>"
export KEYFACTOR_API_PATH="/KeyfactorAPI" # Defaults to /KeyfactorAPI if not set ex. my.domain.com/KeyfactorAPI
export KEYFACTOR_CA_CERT="/path/to/ca.crt" # Optional
export KEYFACTOR_SKIP_VERIFY=0 # Set to 1 or true to skip TLS certificate verification. This is NOT recommended for production.
export KFUTIL_EXP=0 # Set to 1 or true to enable experimental features. This is NOT recommended for production.
export KFUTIL_DEBUG=0 # Set to 1 or true to enable debug logging. This is NOT recommended for production.
Below are examples of setting the environment variables in Windows Powershell to be used with kfutil
.
This is the minimum required configuration to authenticate to Keyfactor Command using Active Directory username, password auth.
$env:KEYFACTOR_HOSTNAME = "<mykeyfactorhost.mydomain.com>"
$env:KEYFACTOR_USERNAME = "<myusername>" # Do not include domain
$env:KEYFACTOR_PASSWORD = "<mypassword>"
$env:KEYFACTOR_DOMAIN = "<mykeyfactordomain>"
This is the minimum required configuration to authenticate to Keyfactor Command using client credentials.
$env:KEYFACTOR_HOSTNAME = "<mykeyfactorhost.mydomain.com>"
$env:KEYFACTOR_AUTH_CLIENT_ID = "<my-oauth2-client>"
$env:KEYFACTOR_AUTH_CLIENT_SECRET = "<my-oauth2-client-secret>"
$env:KEYFACTOR_AUTH_TOKEN_URL = "<mykeyfactorhost.mydomain.com>/protocol/openid-connect/token"
This is the minimum required configuration to authenticate to Keyfactor Command using an access token.
$env:KEYFACTOR_HOSTNAME = "<mykeyfactorhost.mydomain.com>"
$env:KEYFACTOR_AUTH_ACCESS_TOKEN = "<my-access-token>"
$env:KEYFACTOR_API_PATH="/KeyfactorAPI" # Defaults to /KeyfactorAPI if not set ex. my.domain.com/KeyfactorAPI
$env:KFUTIL_EXP=0 # Set to 1 or true to enable experimental features
$env:KFUTIL_DEBUG=0 # Set to 1 or true to enable debug logging
kfutil
supports the following authentication providers in order of precedence:
Provider Type | Description |
---|---|
Azure Key Vault via Azure ID | This provider will read the Keyfactor Command credentials from Azure Key Vault. For more info review the auth providers docs. |
Environment | This provider will read the Keyfactor Command credentials from the environment variables listed above. |
File | This is the default provider. It will read the credentials from a file on disk at $HOME/.keyfactor/command_config.json |
User Interactive | This provider will prompt the user for their credentials. |
For full documentation on the login
command, see the login documentation.
WARNING - The login
command will store your Keyfactor credentials in a file on your local machine. This file is not
encrypted and is not secure. It is recommended that you use the login
command only on your local machine and not on a
shared machine. Instead of using the login
command, you can set the environmental variables listed above.
kfutil login
For full documentation on the logout
command, see the logout documentation.
WARNING - This will delete the file containing your Keyfactor credentials at $HOME/.keyfactor/command_config.json
.
kfutil logout
For full documentation, see stores import.
This will attempt to process a CSV input file of certificate stores to create. The template can be generated by
running: kfutil stores import generate-template
command.
kfutil stores import create --file <file name to import> --store-type-id <store type id> --store-type-name <store type name> --results-path <filepath for results> --dry-run <check fields only> [flags]
kfutil stores import --help
Tool for generating import templates and importing certificate stores
Usage:
kfutil stores import [command]
Available Commands:
create Create certificate stores
generate-template For generating a CSV template with headers for bulk store creation.
Flags:
-h, --help help for import
Use "kfutil stores import [command] --help" for more information about a command.
For full documentation, see store-types.
This will attempt to process a CSV input file of certificate store types to create. The template can be generated by
running: kfutil generate-template --type bulk-certstore-types
command.
kfutil store-types create --name $STORE_TYPE_NAME
kfutil store-types --help
A collections of APIs and utilities for interacting with Keyfactor Command certificate store types.
Usage:
kfutil store-types [command]
Available Commands:
create Create a new certificate store type in Keyfactor Command.
delete Delete a specific store type by ID.
get Get a specific store type by either name or ID.
list List certificate store types.
templates-fetch Fetches store type templates from Keyfactor's Github.
update Update a certificate store type in Keyfactor.
Flags:
-h, --help help for store-types
Use "kfutil store-types [command] --help" for more information about a command.
For full documentation, see stores rot.
The root of trust (rot) utility is a tool that allows you to bulk manage Keyfactor certificate stores and ensure that a set of defined certificates are present in each store that meets a certain set of criteria or no criteria at all.
echo "Generating cert template file certs_template.csv"
kfutil stores rot generate-template-rot --type certs
# edit the certs_template.csv file
echo "Generating stores template file stores_template.csv"
kfutil stores rot generate-template-rot --type stores
# edit the stores_template.csv file
kfutil stores rot audit --add-certs certs_template.csv --stores stores_template.csv #This will audit the stores and generate a report file
# review/edit the report file generated `rot_audit.csv`
kfutil stores rot reconcile --import-csv
# Alternatively this can be done in one step
kfutil stores rot reconcile --add-certs certs_template.csv --stores stores_template.csv
For full documentation, see stores rot generate template.
This will write the file certs_template.csv
to the current directory.
kfutil stores generate-template-rot --type certs
For full documentation, see stores rot generate template.
This will write the file stores_template.csv
to the current directory. For full documentation
kfutil stores generate-template-rot --type stores
For full documentation, see stores rot audit.
Audit will take in a list of certificates and a list of certificate stores and check that the certificate store's
inventory either contains the certificate or does not contain the certificate based on the --add-certs
and
--remove-certs
flags. These flags can be used together or separately. The aforementioned flags take in a path to CSV
files containing a list of certificate thumbprints. To generate a template for these files, run the following command:
kfutil stores rot generate-template --type certs
To prepopulate the template file you can provide --cn
multiple times.
kfutil stores rot generate-template --type certs \
--cn <cert subject name> \
--cn <additional cert subject name>
In addition, you must provide a list of stores you wish to audit. To generate a template for this file, run the following command:
kfutil stores rot generate-template --type stores
To prepopulate the template file you can provide --store-type
and --container-type
multiple times.
kfutil stores rot generate-template --type stores \
--store-type <store type name> \
--store-type <additional store type name> \
--container-type <container type name> \
--container-type <additional container type name>
With all the files generated and populated, you can now run the audit command:
kfutil stores rot audit \
--stores stores_template.csv \
--add-certs certs_template.csv \
--remove-certs certs_template2.csv
This will generate an audit file that contains the results of the audit and actions that will be taken if reconcile
is
executed. By default, the audit file will be named rot_audit.csv
and will be written to the current directory. To
output
the audit file to a different location, use the --output
flag:
kfutil stores rot audit \
--stores stores.csv \
--add-certs addCerts.csv \
--remove-certs removeCerts.csv \
--output /path/to/output/autdit_file.csv
For full documentation, see stores rot.
Reconcile will take in a list of certificates and a list of certificate stores and check that the certificate store's
inventory either contains the certificate or does not contain the certificate based on the --add-certs
and
--remove-certs
flags. These flags can be used together or separately. The aforementioned flags take in a path to CSV
files containing a list of certificate thumbprints. To generate a template for these files, run the following command:
kfutil stores rot generate-template --type certs
To pre-populate the template file you can provide --cn
multiple times.
kfutil stores rot generate-template --type certs \
--cn <cert subject name> \
--cn <additional cert subject name>
In addition, you must provide a list of stores you wish to reconcile. To generate a template for this file, run the following command:
kfutil stores rot generate-template --type stores
To pre-populate the stores template file you can provide multiple values in any combination of the following flags:
kfutil stores rot generate-template --type stores \
--store-type <store type name> \
--store-type <additional store type name> \
--container-type <container type name> \
--container-type <additional container type name>
With all the files generated and populated, you can now run the reconcile command:
kfutil stores rot reconcile \
--stores stores_template.csv \
--add-certs certs_template.csv \
--remove-certs certs_template2.csv
This will generate an audit file that contains the results of the audit and actions will immediately execute those
actions.
By default, the reconcile file will be named rot_audit.csv
and will be written to the current directory. To output
the reconcile file to a different location, use the --output
flag:
kfutil stores rot reconcile \
--stores stores.csv \
--add-certs addCerts.csv \
--remove-certs removeCerts.csv \
--output /path/to/output/audit_file.csv
Alternatively you can provide an audit CSV file as an input to the reconcile command using the --import-csv
flag:
kfutil stores rot reconcile \
--import-csv /path/to/audit_file.csv
For full documentation, see stores inventory.
For full documentation, see stores inventory show.
# Show by store ID:
```bash
kfutil stores inventory show --sid <store id>
# Nested command lookup: shows inventory of first cert store found
kfutil stores inventory show \
--sid $(kfutil stores list | jq -r ".[0].Id")
Show by client machine name:
kfutil stores inventory show --client <machine name>
# Nested command lookup: shows inventory of first cert store found
kfutil stores inventory show \
--client $(kfutil orchs list | jq -r ".[0].ClientMachine")
For full documentation, see stores inventory add.
# Add 2 certs to 2 certificate stores
kfutil stores inventory add \
--sid <store id> \
--sid <additional store id> \
--cn <cert subject name> \
--cn <additional cert subject name>
For full documentation, see stores inventory remove.
# Remove 2 certs from all stores associated with a client machine
kfutil stores inventory remove \
--client <machine name> \
--cn <cert subject name> \
--cn <additional cert subject name>
This CLI developed using cobra
cobra-cli add <my-new-command>
alternatively you can specify the parent command
cobra-cli add <my-new-command> -p '<parent>Cmd'