PasswordSafe.Cli 1.0.0

dotnet tool install --global PasswordSafe.Cli --version 1.0.0                
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest # if you are setting up this repo
dotnet tool install --local PasswordSafe.Cli --version 1.0.0                
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=PasswordSafe.Cli&version=1.0.0                
nuke :add-package PasswordSafe.Cli --version 1.0.0                

The best Password Safe CLI tool

Configuration

// ~/.pwsafe/config.json
{
    "defaultDb": "<alias>", // The default database to operate if you don't specific the alias or the file path to your pwsafe database in the command line.
    "databases": {
        "<alias>": "The Absolute file path to your PasswordSafe file",
        ...
    },
    "idleTime": 5, // Default to be 5 minutes, which means the interactive window will automatically close in 5 minutes if there's no operation.
    "maxBackupCount": 5 // Default to keep 5 backup files.
}

Commands

Usage:
  pwsafe [command] [options]

Options:
  --version       Show version information
  -?, -h, --help  Show help and usage information

Commands:
  config           Manage your pwsafe config file
  choose <ALIAS>   Choose a database to operate
  listdb           List all databases
  showdb           Show the detail of PasswordSafe database
  createdb <FILE>  Create an empty new PasswordSafe v3 database file
  list             List the items in database
  add              Add a new entry to the database
  get <ID>         Get the password of an entry
  renew <ID>       Renew the password of an entry
  update <ID>      Update the properties of an entry
  rm <ID>          Remove an entry or group from the database
  policy           Manage your password policies
  unlock           Unlock a database

Manage configuration via CLI

1. Init config
$ pwsafe config init
2. Set alias for a pwsafe database file
$ pwsafe config set --alias <alias> --file <filepath>
# OR
$ pwsafe config set -a <alias> -f <filepath>
# Make the database as default
$ pwsafe config set -a <alias> -f <filepath> --default
3. Remove an alias
$ pwsafe config rm <alias>
4. Set the default database
$ pwsafe choose <alias>
5. List all configured databases
$ pwsafe listdb

Manage database via CLI

1. Create an empty database
$ pwsafe createdb <filepath> --alias <alias>
# To make the new database as default database
$ pwsafe createdb <filepath> --alias <alias> --default
# Force to create a new database if file exists, use it on your own risk!
$ pwsafe createdb <filepath> --alias <alias> --force
2. Show metadata of an database
$ pwsafe showdb --alias <alias>
# OR
$ pwsafe showdb --file <filepath>

Manage the entries in database in CLI

1. List available entries
# List entries of the default database
$ pwsafe list
# List entries of the given alias
$ pwsafe list --alias <alias>
# List entries of the given filepath
$ pwsafe list --file <filepath>
# List entries in tree view
$ pwsafe list --mode tree
# Filter items by title
$ pwsafe list --filter <title>

PS. the alias option and the file option are available for the following sections.

2. Get password
$ pwsafe get <ID>
Enter your password: ******
Successfully copy password to clipboard
3. Add a new entry
$ pwsafe --title <title> --username <username> --password <password> --group <group> --url <url> --email <email> --notes <notes>
# Read the password interactively
$ pwsafe --title <title> --username <username> --password
# Generate the password via named password policies
$ pwsafe --title <title> --username <username> --policy <policy>

PS. the sub-groups are separated by ., for example: A/B/C is represented as A.B.C

4. Renew the password
$ pwsafe renew <ID>
# Renew with given password
$ pwsafe renew <ID> --password <password>
# Renew with given password interactively
$ pwsafe renew <ID> --password
# Renew the password via named password policies
$ pwsafe renew <ID> --policy <policy>
5. Update the properties of an entry
$ pwsafe update <ID> --title <title> --username <username> --group <group> --url <url> --email <email> --notes <notes>
6. Remove an entry or entire group
# Remove an entry
$ pwsafe rm <ID>
# Remove a group
$ pwsafe rm --group <group>

Manage the password policy

1. List existing password policies
$ pwsafe policy list
2. Add new password policy
$ pwsafe policy add --name "Sample" \
                    --length 12 \
                    --uppercase 2 \
                    --lowercase 2 \
                    --digits 1 \
                    --symbols 1 \
                    --symbol-chars "@#$%&" \
                    --easy-vision
3. Update an existing password policy
$ pwsafe policy update --name "Sample" \
                       --length 12 \
                       --uppercase 2 \
                       --lowercase 2 \
                       --digits 1 \
                       --symbols=-1 \
                       --easy-vision
4. Remove a password policy
$ pwsafe policy rm --name "Sample"
5. Generate password for given policy
$ pwsafe policy genpass --name "Sample"

Interactive mode

It's boring to enter password for every operation, if you want to do a lot operations, you can unlock the database in interactively mode. The session will automatically exit if you don't take any actions.

# It will be unlock as read mode by default.
$ pwsafe unlock
# Unlock database in read-write mode
$ pwsafe unlock --read-only false
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

Version Downloads Last updated
1.0.0 255 2/7/2024
1.0.0-beta 174 2/1/2024