Key Vault CLI (kvc) is a command line interface password manager developed in C#. This open-source project helps you securely manage your passwords and sensitive information while providing a user-friendly and efficient CLI-based interface. Below, you'll find information on how to run, build, the technologies used, and the features covered by Key Vault CLI.
Key Vault CLI comes with a variety of features to help you manage your passwords and sensitive information. Here's a list of features, marked with checkmarks (β), crosses (β) to indicate the status of each feature, and Work in Progress ( π§) to indicate features that are currently being developed or planned for future releases:
- β Master Password: Secure your Vault with a master password.
- β CRUD Operations: Create, read, update, and delete password entries.
- β Password Generation: Generate strong, random passwords.
- π§ Password Storage: Safely store your passwords and sensitive information.
- π§ Encryption: Passwords are securely encrypted before storage.
- β Search and Retrieval: Easily search and retrieve stored passwords.
- β Multi-Platform Support: Key Vault CLI can be installed and used on all the major platforms (Windows, MacOS and Linux).
- β Backup and Restore: Backup and restore your password database.
- β Category Organization: Organize your passwords into categories for better management.
- β Password Health Check: Check the strength and security of your passwords.
- β Password Sharing: Share passwords securely with other users.
Key Vault CLI is built on the .NET SDK. To run the application, you'll need to have the .NET SDK installed on your local machine. You can find the latest version of the SDK here. The application uses.NET 8.0, so make sure you have the correct version.
Key Vault CLI is developed using the following technologies:
- .NET: The application is built on the .NET SDK.
- C#: The primary programming language used.
- Console Application: The user interface is entirely CLI-based.
For all the following How tos sections, you need to follow these steps first:
- Clone this repository to your local machine.
- Open a terminal or command prompt.
- Navigate to the project directory.
Run the project using the following command:
dotnet run
You will be prompted to create a master password the first time you run the application.
To run the application using Docker, execute the following commands:
docker build . -t keyvaultcli
docker run -it --name KeyVaultCli keyvaultcli
Build the project using the following command:
dotnet build
To run the tests, use the following command:
dotnet test
To run a coverage report inside the cli and not the IDE run this
dotnet test /p:CollectCoverage=true --% /p:CoverletOutputFormat=\"opencover,lcov\"
Count the lines of code using the following command in the root of the project:
chmod +x countlines.sh && ./countlines.sh
- Package Generation: To package the project, execute the command below:
dotnet pack
This will create a new folder named nupkg
within the KeyVaultCli.Presentation
project.
2.Installation from Local Feed: Install the package from a local NuGet feed with the subsequent command:
dotnet tool install --global --add-source ./src/KeyVaultCli.Presentation/nupkg KeyVaultCli.Presentation
3.Verification of Installation: Confirm the installed packages on your machine using:
dotnet tool list --global
You should observe the presence of the KeyVaultCli.Presentation package. Run your application by invoking:
kvc
To remove the globally installed tool, execute the following command:
dotnet tool uninstall KeyVaultCli.Presentation
In the following there are simple use cases for the Key Vault CLI, and why you would use it.
- User: A person who wants to securely manage their passwords and sensitive information.
- The user has installed Key Vault CLI on their local machine.
- The user has set up a master password for their vault.
- Run the Application: The user runs the Key Vault CLI application by executing the command
dotnet run
. - Authenticate: The application prompts the user to enter their master password to unlock the vault.
- Access Passwords: Once authenticated, the user can perform CRUD operations to manage their passwords and
sensitive information.
- Create: The user can add new password entries to the vault.
- Read: The user can view existing password entries.
- Update: The user can modify existing password entries if needed.
- Delete: The user can remove password entries from the vault.
- Generate Strong Passwords: The user can utilize the password generation feature to create strong, random passwords for their accounts.
- Search and Retrieval: The user can easily search for specific passwords or information stored in the vault using the search feature.
- Logout: Once the user has finished managing their passwords, they can log out of the application, via a command or by closing the terminal.
- The user's passwords and sensitive information are securely stored in the vault.
- The user can safely exit the application knowing that their data is protected by the master password.
- Employee: An individual working in an organization who needs to manage various work-related credentials securely.
- The employee has access to the Key Vault CLI application.
- The employee has set up a master password for their vault.
- The employee has access to the work-related systems and services that require credentials.
- Run the Application: The employee executes the command
dotnet run
to start the Key Vault CLI application. - Authenticate: The application prompts the employee to enter their master password to unlock the vault.
- Access Work Credentials: Once authenticated, the employee can perform CRUD operations to manage their
work-related credentials.
- Create: The employee adds entries for various work-related systems, such as company email, internal databases, or cloud services, along with their respective usernames and passwords.
- Read: The employee can view the stored work credentials whenever needed.
- Update: If the employee's work password changes or needs updating, they can modify the corresponding entry in the vault.
- Delete: If access to a particular system or service is revoked or no longer required, the employee can delete the corresponding credential entry from the vault.
- Search and Retrieve: The employee can quickly search for specific work-related credentials stored in the vault using the search feature, making it easy to retrieve the necessary information when logging into different systems or services.
- Logout: Once the employee has finished accessing or updating their work credentials, they securely log out of the Key Vault CLI application.
- The employee's work-related credentials are securely stored in the vault, ensuring access to critical systems and services while maintaining security standards set by the organization.
To generate UML diagrams for your .NET projects using PlantUML and JetBrains Rider, follow these simple steps:
Refer to the detailed installation guide by Khalid Abuhakmeh for setting up PlantUML with JetBrains Rider here
Run the script to generate UML diagrams based on your project's code:
chmod +x generate-uml.sh && ./generate-uml.sh
After running the script, navigate to the output (puml
) directory to find the generated UML diagrams.
Key Vault CLI is open-source software released under the MIT License. You are free to use, modify, and distribute this software as per the terms of the license.