Record Commands
All the commands related to Manipulating records
Commands:
Keeper Command Reference
Whether using the interactive shell, CLI or JSON config file, Keeper supports the following commands, each command supports additional parameters and options.
To get help on a particular command, run:
help <command>
Command
Explanation
list
or l
List all records or search via a regular expression.
search
or s
Search all records via a regular expression.
ls
List folder contents
Display entire folder structure as a tree
cd
Change current folder
get
or g
Retrieve and display a Keeper Record/Folder/Team in printable or JSON format.
Display the specified Keeper Record password field to the system output
Copy the specified Keeper Record password field to the clipboard or send to stdout
record-history
or rh
Show the history or a record's modifications
Display the Two Factor code for a given record, or show a list of records with Two Factor codes if no record is specified
Download all attachments of a specified record
Upload and attach a file to a given record
Delete an attachment from a given record
file-report
Show a report of all the files that you have access to in the vault
list-sf
or lsf
Show details about all shared folders in the vault
list-team
or lt
List all teams that you have access to
add
or a
Deprecated: use record-add
record-add
or ra
Add a record
edit
Deprecated: use record-update
record-update
or ru
Edit an existing record
Remove a record
append-notes
or an
Append notes to a record
Create a folder or shared folder
rmdir
Remove a folder or shared folder and its contents
mv
Move a record to or folder
ln
Create a link between records or folders
Locate duplicate records in the vault (or several) based on specified attributes and fields.
shortcut
List or manage record shortcuts
Transform a folder from a shared folder to a personal folder and vice versa
trash
List and manage deleted records in the trash
Display password report
List (and, optionally, claim) records in the vault that currently do not have an owner
list command:
Command: list
or l
Detail: List all records or search via a regular expression
Switches:
-v
, --verbose
verbose output (if record names are too long for the column)
Examples:
List all records
List all records with the string twitter
List all 'Azure' records that do not contain the string 'FTP" (Using regex)
search command:
Command: search
or s
Detail: Search the vault using a regular expression
Parameters:
Regular expression to use with search
Switches:
-v
, --verbose
verbose output
Examples:
Search for records containing "dropbox"
Search for records with a string of numbers and letters only ending in ".org"
ls command:
Command: ls
Detail: List folder contents
Switches:
-l
, --list
show detailed list
-f
, --folders
display folders
-r
, --records
display records
-v
, --verbose
verbose output
-R
, --recursive
show subfolder contents
Examples:
Detailed list of folder contents
List of only records in a folder (No sub folders)
Detailed list of records, and show long titles even if they skew the table
Show detailed list of all records and folders found in "Folder1" and its subfolders
tree command:
Command: tree
Detail: Display the entire folder structure as a tree, using specified folder or the current location (if no folder specified) as the root
Parameters:
Full path, UID, or name (if current location is parent folder) of folder to use as tree root (optional)
Switches:
-r
, --records
display records in each folder in tree (shown in slightly dimmer text)
-s
, --shares
display shared-folder share permissions (symbols denoting permission-types shown in legend/key by default)
-hk
, --hide-shares-key
hide permissions legend (valid only when--shares
flag is specified)
-t
, --title <TITLE>
show optional title for the folder-structure display
-v
, --verbose
verbose output (display record/folder UID in addition to name)
Examples:
Display entire folder structure as a tree, using the current location as the root
Display entire folder structure starting at sub directory "Office Codes" folder as the root
Display folder structure titled "My Folder Structure w/ Records (UIDs shown)" showing records in each folder (w/ corresponding UID for each folder/record), using current location as root
Display folder structure with share-permissions (as abbreviated symbols) for each contained shared-folder without displaying the corresponding permission symbols legend/key, with the displayed folder-structure root being the subfolder named Team1 in the folder named Work Folders found in the vault's root folder (note: because the target folder's full path is provided in this example, this command can be called from any location)
cd command:
Command: cd
Detail: Change current directory
Parameters:
Location to move to.
Quotation marks can be used to move to folders with spaces or slashes in their name.
backslash (\) can be used to escape quotation marks in a folder's name
Examples:
Move to a folder named "social" in the current directory
Move to a folder named 'banks' inside a folder named 'financial'
Move to the vault root
Move to a folder named "folder/with/slashes"
Move to a folder named 'folder"with"quotes'
find-password command:
Command: find-password
Detail: Display a specified Keeper record's password to the system output, given that record's UID or path
Parameters:
Path or UID of a record
Switches:
--username <USERNAME>
match the login name using regex (optional). The given title or UID must also match to find the record
--output <{
clipboard, stdout}
>
choose the destination of the output
stdout - display password to system output (default)
clipboard - copy password to clipboard
-l
, --login
output login name instead of password
Examples:
Show the password of a specific record with the given UID
Show the password of a record with the title "Zoom" in the "office" folder
Copy the password of a specific record to the clipboard
Show the login of a record with the title "Twitter" in the "social" folder
Show the password for a record with a title that starts with "reddit", and "second" as part of the username
clipboard-copy command:
Command: clipboard-copy
Detail: Copy a specified Keeper record's password to the clipboard, or send the password to stdout, given that record's UID or path.
Parameters:
Path or UID of record
Switches:
--username <USERNAME>
match the login name using regex (optional). The given title or UID must also match to find the record
--output <{
clipboard, stdout, stdouthidden, variable}
>
choose the destination of the output
clipboard
- copy output value to clipboard (default)stdout
- display output value to system outputstdouthidden
- display output value to system output but hiddenvariable
- store output value to Keeper variable
-l
, --login
output login name instead of password
--field <FIELD NAME>
output custom field
--name
Keeper variable name
-r
, --revision
record revision
-t
or --totp
output TOTP code
Examples:
Copy the password of a specific record with the given UID to the clipboard
Copy the password of a record with the title "Zoom" in the "office" folder to the clipboard
Show the password of a specific record with the given UID
Copy the login of a record with the title "Twitter" in the "social" folder to the clipboard
Copy the password for a record with a title that starts with "reddit", and "second" as part of the username to the clipboard
get command:
Command: get
or g
Detail: Retrieve and display a Keeper Record/Folder/Team in printable or JSON format, given a corresponding UID.
Parameters:
UID of a record, folder, or team
Switches:
--unmask display hidden field content as plaintext
--format<{detail, json, password}> choose the format of the output
detail - a detailed view of the Record/Folder/Team (default)
json - json formatted details
password - only the password
--legacy JSON output only. Display typed records in legacy json format
Examples:
Show the details of a specific record
Show the details of a specific record in JSON format
To only retrieve the password as output, see the clipboard-copy
command
record-history command:
Command: record-history
or rh
Detail: Show the history of a record's modifications, given that record's UID
Parameters:
UID of record
Switches:
-a, --action <{list, diff, show, restore}> perform an action on the record
list - show revisions
diff - show changes made at each revision
show - show details about the current revision
restore - restore back to a previous revision (requires
-r
or--revision
argument)
-r, --revision <REVISION NUMBER> only show details for a specific revision
Examples:
List of specific record's modification history
List of the changes made in each version of the specific record
Details of the 4th revision of the specific record (V.4)
Revert the specified record to its 2nd version
totp command:
Command: totp
Detail: Display the Two Factor code for a record, given its path or UID. Show a list of records with Two Factor codes if no path or UID is given
Parameters:
Path or UID of record (optional)
Switches:
--details
display 2FA details
--range <RANGE>
display last and next [x] codes
Examples:
List of records with TOTP Two Factor codes
Show a Two Factor code with timer for the "Dropbox" record
Show a Two Factor code with timer for the record with the given UID
Display the last, current, and next Two Factor codes for the "Dropbox" record
Display the TOTP token details for the record with the given UID
download-attachment command:
Command: download-attachment
Detail: Download all files attached to the specified record(s), given that record's path or UID
Parameters:
Path or UID of record or folder
Switches:
-r
or --recursive
Download recursively through subfolders
--out-dir <LOCAL DIRECTORY>
Local folder for downloaded files
--preserve-dir
Preserve vault folder structure
--record-title
Append record names to title of downloaded attachments
Naming Convention for downloaded attachments:
$AttachmentFileName
By default, all downloaded attachments will retain their original name.
If a record contains the attachment "file.txt", the name of the downloaded attachment will be: file.txt
$AttachmentFileName($RecordUUID).$AttachmentFileNameExtension
This is the naming convention for duplicates.
If a record contains two attachments with the same name (i.e "file.txt") or the output directory already contains a file with the same name, the naming convention of the downloaded attachments will be:
file.txt
and file(Lw7K5ah3LjP5uVkhkrSzrw).txt
$AttachmentFileName($AttachmentUUID).$AttachmentFileNameExtension
For duplicates, if the naming convention in the above row is used, then the AttachmentUUID
will be used instead of RecordUUID
.
In the given examples for the row above, downloading file.txt will use the attachmentUUID
instead of the recordUUID
:
file(Bu2WLg-7eqWPhO-NW18lgw).txt
$RecordName-$AttachmentFileName
If the switch --record-title
is passed, the record name will be appended to downloaded attachment file. This also applies to duplicates.
For a record named "Record1" with the attachment "file.txt", the naming convention will be:
Record1-file.txt
Examples:
Download all attachments of the record titled "Financial Records" in the "documents" folder
Download all attachments of the record with the given UID
Download all attachments in the vault recursively to the specified output location: "C:\Attachments"
Append the record name "Financial Records" to the name of all downloadable attachments for the record titled "Financial Records" in the "documents" folder
upload-attachment command:
Command: upload-attachment
Detail: Upload a file and attach it to a specific record, given that record's path or UID
Parameters:
Path or UID of record
Switches:
--file <FILENAME>
file name to upload (required)
Examples:
Attach a pdf file to the "Financial Records" record in the "documents" folder
Attach an image to the record with the given UID
delete-attachment command:
Command: delete-attachment
Detail: Delete a file attached to a specified record, given that record's path or UID
Parameters:
Path or UID of record
Switches:
--name <FILE>
name or ID of the file to delete (required)
Examples:
Delete a pdf file named "June_2021.pdf" from the "Financial Records" record in the "documents" folder
Delete an image named "5_15_21.jpg" from the record with the given UID
Delete all orphaned file attachments in the vault
file-report command:
Command: file-report
Detail: Show a report of details of all files that you can access in the vault. Report consists of: Title, Record UID, and File ID
Switches:
-d
, --try-download
attempt to download all the attachments in the vault
Examples:
Show a report of all the files attached to records in the vault
Attempt to download all the files attached to records in the vault
list-sf command:
Command: list-sf
or lsf
Detail: Display the UID, Name, Default Permissions, Record Permissions, User Permissions, and Team Permissions for all shared folders in the vault
Examples:
Show details for all shared folders in the vault
list-team command:
Command: list-team
or lt
Detail: Display the UID and Name for each Team that you have access to
Examples:
Show details for all teams you have access to
record-add and record-update commands
Command: record-add
or record-update
Detail: Adds a record to the vault or update an existing record. This is the recommended command for adding and updating records. This supports all record types, custom types, standard fields and custom fields. See --syntax-help
for detailed examples.
Parameters:
A space separated list of field values. A field has the following syntax:
<FIELD_NAME>=<FIELD_VALUE> see ...
Switches:
-t
, --title
Record title
-n
, --notes
Record notes
-rt, --record-type
Record type. See the list of standard record types.
-f,
--folder
<FOLDER PATH or UID>
Folder for the record. Applies to record-add
only.
--self-destruct
<NUMBER>[(mi)nutes|(h)ours|(d)ays|(mo)nths|(y)ears]
Time period record share URL is valid. The record will be deleted from your vault 5 minutes after opening. Applies to record-add
only.
-r,
--record
<RECORD PATH or UID>
Path or UID of the record to edit. Applies to record-update
only.
-f
, --force
Ignore warnings.
--syntax-help
Displays detailed information on usage for these commands.
Examples:
rm command:
Command: rm
Detail: Remove record(s) with given path(s) or UID(s)
Parameters:
Path or UID of record(s)
Switches:
-f
, --force
do not prompt
Examples:
Remove the "Twitter" record in the "social" folder. Will be prompt to enter "y" to approve.
Remove the record with the given UID and don't prompt to approve.
Remove the "Bank" record and purge it from the trash (record will not be recoverable)
Remove records "rec1" and "rec2"
append-notes command:
Command: append-notes
or an
Detail: Append to the notes of a record with a given path or UID
Parameters:
Path or UID of record
Switches:
--notes <NOTES>
notes to append
Examples:
Append to the notes of the "Twitter" record in the "social" folder. Will be prompted to enter notes to add
Append to the notes of the record with the given UID with the message "Outdated as of June 2021"
mkdir command:
Command: mkdir
Detail: Create a folder or shared folder at the given path
Parameters:
Path/name of new folder
Switches:
-sf
, --shared-folder
create a shared folder
-uf
, --user-folder
create a user folder (not shared)
-a
, --all
set default folder permissions to allow any user to manage users, manage records, share records, and edit records
-u
, --manage-users
set default folder permissions to allow all users to manage user access
-r
, --manage-records
set default folder permissions to allow all users to manage records
-s
, --can-share
set default folder permissions to allow all users to share records
-e
, --can-edit
set default folder permissions to allow all users to edit records
--color <
{none, red, green, blue, orange, yellow, gray}
>
sets folder color
When adding other users or teams to a shared folder, they will be given the default permissions of that folder, unless the permission is specifically revoked or added when sharing. See the share-folder command for more details.
Examples:
Create a folder named "personal" in the existing "finance" folder. Will be prompted to create a shared folder or user folder
Create a user folder named "social"
Create a shared folder named "office-codes" with the default permissions set to allow all users to share the records in the folder
rmdir command:
Command: rmdir
Detail: Delete a folder or shared folder given the folder's path or UID
Parameters:
Path of folder
Accepts patterns, which will remove all matching folders.
*
matches everything?
matches any single character[seq]
matches any character in seq[!seq]
matches any character not in seq
Accepts multiple parameters separated by a space
Switches:
-f
, --force
Delete folder without prompting
-q
, --quiet
returns no output when used in conjunction with -f
Examples:
Delete the folder named "temporary" in the "social" folder. Will be prompted to confirm
Delete the folder with the given UID and don't prompt to confirm
Delete all folders with only letters in the name, ending in '2'
Delete the folder 'secrets' in the 'DevOps' folder, and the 'MyFolder' folder
Delete the folder with the given UID and don't show any output
Remove all folders from the Keeper Vault
mv command:
Command: mv
Detail: Move a record or folder to another folder, given the record or folder's path or UID and the path or UID of the destination folder
Parameters:
Path or UID of record followed by path or UID of destination folder
Format:
mv SRC DST
SRC: the source path to folder or record. Accepts title paths, search patterns, and UIDs
DST: the destination folder name or UID to move to
Switches:
-f
, --force
move record or folder without prompting
-s
. --can-reshare
anyone can reshare records
-e
, --can-edit
anyone can edit records
Examples:
Move the "Twitter" record into the "social" folder
Move the record with the given UID to the root folder
ln command:
Command: ln
Detail: Link a record or folder to another folder, given the record or folder's path or UID and the path or UID of the destination folder
Parameters:
Path or UID of record followed by path or UID of destination folder
Format:
ln SRC DST
SRC: the source path to folder or record. Accepts title paths, search patterns, and UIDs
DST: the destination folder name or UID to link to
Switches:
-f
, --force
move record or folder without prompting
-s
. --can-reshare
anyone can re-share records
-e
, --can-edit
anyone can edit records
Examples:
Link the "Twitter" record with the "social" folder
Link the record with the given UID to the root folder
find-duplicate command:
Command: find-duplicate
Detail: Useful tool to help locate duplicate records in the vault based on one or more record fields.
Parameters:
Provide a list of fields to use for comparison.
Switches:
--title
Match the title field to locate a duplicate
--login
Match the login field to locate a duplicate
--password
Match the password field to locate a duplicate
--url
Match the URL field to locate a duplicate
--shares
Match on share-permissions
--full
Match all fields to locate a duplicate
--merge, -m
Consolidate duplicate records (Note: when this flag is included, duplicate records are automatically matched on all fields, including shares)
--ignore-shares-on-merge
Ignore share-permissions when matching duplicate records for merging
--force, -f
Delete duplicates w/o being prompted for confirmation (valid only w/ --merge option)
--quiet, -q
Suppress screen output (valid only w/ --force/--merge
options)
--dry-run, -n
Simulate removing duplicates (no records are ever removed or modified). Valid only w/ --merge
flag
--scope,
-s <enterprise, vault>
Define the scope of the search (default is vault). Enterprise scope available only to enterprise account administrators with compliance data-access prvileges.
--refresh-data
, -r
Populate local cache with latest audit data. Valid only when used with the --scope=enterprise
option.
--format
<{csv, json, table}>
Chose the format of the output
--output
<FILENAME> Export search results to a file
Examples:
Find duplicate records based on matching titles
Find duplicate records based on matching logins and passwords
Find duplicate records based on matching logins, passwords, and website addresses
Find duplicate records by matching on all relevant fields (including custom fields and share-permissions that apply for each record)
Find duplicate records -- matching on all relevant fields (and shares) -- and consolidate them into one (i.e., delete all but one record for each set of records deemed to be duplicates of each other) per set of duplicates without prompting for confirmation prior to record deletion
Find duplicate records (matching on all fields) and simulate consolidating the results
Find duplicate records across vaults within the entire enterprise and export the search results to a CSV-formatted filed named enterprise_duplicates.csv
shortcut command:
Command: shortcut
Detail: List or manage record shortcuts. Shortcuts are links to records in a folder other than the folder that record belongs to.
Parameters:
Command:
list <RECORD UID, FOLDER UID, PATH (optional)>: Show a list of all shortcuts. Filtered to record or folder if given
keep <RECORD OR FILE PATH> : Remove all but one shortcut
Switches:
list switches:
--format <{
csv, json, table}
>
choose the format of the output
--output <FILENAME>
file to write output results to
Examples:
Display a list of record shortcuts
Output a list of record shortcuts to a file
Output a list of record shortcuts that exist in the folder with the give UID
Remove all record shortcuts other than record at the given location
Use Case: Deleting all but one shortcut with command keep
Suppose there are multiple shortcuts for the following record, and you only want to keep the record
To keep this record only in the "key-folder2" and remove all other shortcuts, you can execute the following command:
Running the above command will prompt you to confirm the deletion of the extra shortcuts
To verify that the additional shortcuts have been deleted, you can do one of the following:
Access your web vault and observe that the shortcuts have been deleted. Example: In the above scenario & example, I will find only one instance of the record
ksm-key1
inkey-folder2
Running the
shortcut list <Record UID>
command will output that the record has no shortcuts In the above scenario & example, after deleting the unwanted shortcuts, running thelist
command will give me the following:
transform-folder command:
Command: transform-folder
Detail: Transform a folder from a shared folder to a personal folder and vice versa
Parameters:
Folder UID or path/name (accepts multiple values)
Switches:
-l
, --link
Do not delete the source folder(s). Creates record links instead of moving records.
-n
, --dry-run
Preview the folder transformation without updating
-f
, --force
Skip confirmation prompt and minimize output
-t
, --target=TARGET
Target Folder UID or path/name (root folder if omitted)
--folder-type {personal,shared}
if --target
is omitted specify the new folder type
Examples:
1. Transform a user folder into a shared-folder
Executing the following command (from within the vault's root folder)
If "My Folder (Misc.)"
is a user folder then it will be transformed to a shared folder. transform-folder
command changes folder from user to shared and vice versa if no parameters are specified
2. Transform a shared-folder into a user folder
Executing the following command (from within the vault's root folder)
For security reasons and because of current limitations on the type of folders that any given shared-folder can contain, not every folder in a given vault is necessarily eligible for transformation using the command described above. Consequently, there are certain types of folders for which this command will fail to execute. These include
user folders that contain -- either in the folder itself, or in any of its subfolders, or in any of its subfolders' subfolders, etc. -- any 1 of the following items:
a shared-folder for which the user does not have either of the following:
share-admin privileges
full share permissions ("Can Manage Users", "Can Manage Records")
a direct-share record for which the user does not have either of the following:
share-admin privileges
re-share permissions ("Can Share")
user folders contained within a shared-folder (i.e., any user folder whose parent folder, or parent folder's parent folder, etc., is a shared-folder)
trash command:
Command: trash <sub command>
Detail: List or manage deleted records in the trash. Deleted records remain in the trash until purged.
Parameters:
Sub-command:
list <SEARCH PATTERN>
: Show a list of all deleted records in the trash can. Filtered to record or folder if givenget <RECORD UID>
: show information about deleted record with the given UIDrestore <RECORD UID(S)>
: restore a previously deleted record or records. Can be given several UIDs separated by a spaceunshare <RECORD UID(S)>:
remove shares from deleted recordspurge
: permanently delete all records in the trash
Switches:
list switches:
--format <{
csv, json, table}
>
choose the format of the output
--output <FILENAME>
file to write output results to
--reload
refresh the list of deleted records
list examples:
Display a list of deleted records
Output a list of deleted records to a file named 'deleted.csv'
Display a list of deleted records that have a title starting with "Twitter"
get examples:
Display details of deleted record with the given UID
restore switches:
--force
don't prompt when restoring
list examples:
Restore the deleted record with the given UID
Restore the deleted records with all the given UIDs
Restore the deleted records with all the given UIDs and don't prompt
unshare example:
purge examples:
purge all deleted records from the trash
password-report command
Command: password-report
Detail: Display password report
Switches:
--policy <comma separated integers>
Password complexity policy. Length,Lower,Upper,Digits,Special. Example: 12,2,2,2,0
--length <Number>
Minimum password length
--lower <Number>
Minimum lowercase characters
--upper <Number>
Minimum uppercase characters
--digits <Number>
Minimum digits
--special <Number>
Minimum special characters
Parameters:
folder
Optional. Scan for weak passwords in a folder
Examples:
find-ownerless
Command: find-ownerless
Detail: List (and, optionally, claim) records in the user's vault that currently do not have an owner
Switches:
--format <{
csv, json, table}
>
choose the format of the output
--output <FILENAME>
file to write output results to (ignored for table format)
--claim
claim records found
-v, --verbose
output details for each record found
Parameters:
folder
path or UID of folder to search (optional, with multiple values allowed)
Examples:
Find all the records that do not have an owner and print additional details for each record found
Claim all found records without an owner
Last updated