otlh
is a command-line interface (CLI) tool for managing opentext legalhold service. It allows users to perform various operations related to legal holds, such as creating, updating, and listing legal holds , as well as managing matter, folders and custodians.
Key Features:
- Single executable file with no dependencies on Runtime env (e.g., java) or external libraries (e.g., 3rd party dlls)
- Cross platform support (Windows, Linux, and MacOS)
- Download the latest binary release from the GitHub releases page
- Make sure you have Go & git installed on your system. You can download it from the official Go website.
- Clone the repository:
git clone https://github.com/xifanyan/otlh
- Navigate to the project directory:
cd otlh/cmd/cli
- Build the binary:
./build.sh (macos or linux) or ./build.bat (windows)
- The
otlh
binary will be created in the bin/ directory.
NAME:
otlh - Command Line Interface to access Opentext LegalHold service
USAGE:
otlh [global options] command [command options]
VERSION:
0.5.3-beta
COMMANDS:
create
get
import
verify
help, h Shows a list of commands or help for one command
GLOBAL OPTIONS:
--domain value, -x value domain name for Opentext legahold service (default: "api.otlegalhold.com") [%LHN_DOMAIN%]
--port value, -p value port (default: 443)
--tenant value, -t value tenant name [%LHN_TENANT%]
--authToken value, -a value token to access legalhold web service [%LHN_AUTHTOKEN%]
--config value, -c value LHN json config file [%LHN_CONFIG%]
--debug, -d Debug Mode (default: false)
--trace, -z Trace Mode (default: false)
--help, -h show help
--version, -v print the version
- domain name defaults to api.otlegalhold.com
- port defaults to 443
- tenant is mandatory and can be specified in the config file or via environment variable LHN_TENANT.
- authToken is mandatory and can be specified in the config file or via environment variable LHN_AUTHTOKEN.
- config file is optional and can be specified via environment variable LHN_CONFIG with format:
{
"domain": "api.otlegalhold.com",
"port": 443,
"httpProxy": "",
"tenant": "demo",
"authToken": "*************************"
}
NAME:
otlh get
USAGE:
otlh get command [command options]
COMMANDS:
help, h Shows a list of commands or help for one command
get:
custodians
custodian_groups
folders
groups
matters
legalholds
silentholds
OPTIONS:
--help, -h show help
optins [--filterName, --filterTerm, --pageSize, --pageNumber, --sort, --id, --all] apply to all get commands
- Get custodian with specific id
./otlh.exe --tenant ps_test --authToken *** get custodians --id 100000383
- Get all custodians (without --all, output only includes first page of the custodians)
./otlh.exe --tenant ps_test --authToken *** get custodians --all
- Get all custodians with name filter (in case number of custodians exceeds default page size)
./otlh.exe --tenant ps_test --authToken *** get custodians --filterName john --all
- Get custodians with pagination
./otlh.exe --tenant ps_test --authToken *** get custodians --pageSize 2 --pageNumber 2
All of the options (except --attachmentDirectory) apply to Silenthold import as well
NAME:
otlh import legalholds
USAGE:
otlh import legalholds [command options] [arguments...]
CATEGORY:
import
OPTIONS:
--attachmentDirectory value, --ad value attachment directory (default: ".")
--excel value, -e value excel file used for legalhold import
--zipfile value, -z value zip package for importing holds e.g., legal_hold_details.zip
--timezone value, --tz value timezone for dates used in input file, supproted timezones: PST|EST|MST|CST (default: "UTC")
--holdName value, --hn value hold name
--matterName value, --mn value matter name
--checkInputOnly, --ci check input only (default: false)
--help, -h show help
- Import zip package directly via command line
./otlh.exe --debug import legalholds --zipfile=../testdata/legal_hold_details.zip
- Validate input data in excel file only
./otlh.exe --debug import legalholds --excel=../testdata/sample.xlsx --attachmentDirectory=../testdata/attachments --checkInputOnly
- Import all legalholds from excel file, also convert datetime fields in PST to UTC.
./otlh.exe --tenant test --authToken [*****] import legalholds --timezone=PST --excel=../testdata/sample.xlsx --attachmentDirectory=../testdata/attachments
- Trace mode
./otlh.exe --trace --tenant test --authToken [*****] import legalholds --excel=../testdata/sample.xlsx --attachmentDirectory=../testdata/attachments
- Partially import legalholds from excel file based on matter or hold names
./otlh.exe --tenant test --authToken [*****] import legalholds --excel=../testdata/sample.xlsx --attachmentDirectory=../testdata/attachments --matterName="Fargo vs Acme" --holdName="Fargo vs Acme Legal Hold"
- all datetime fields in excel need to follow pattern "1/2/06 3:04 PM", UTC is the default timezone, if you want to change it, please use --timezone option.
- Attachment files should be put under attachment directory, it currently does not support subfolders, so please make attachment file names unique.
NAME:
otlh import custodians
USAGE:
otlh import custodians [command options] [arguments...]
CATEGORY:
import
OPTIONS:
--input value, -i value input file used for custodian import, e.g., custodians.json or custodians.csv
--batchSize value, --bs value batch size (default: 50)
--help, -h show help
- Import custodians from json file
./otlh.exe --debug --config otlh_conf.json import custodians --input testdata/custodians.json --batchSize 100
- custodians.json
[
{
"name": "test01_pyan",
"email": "[email protected]",
"phone": "555-555-1111"
},
{
"name": "test02_pyan",
"email": "[email protected]",
"phone": "555-555-2222"
},
{
"name": "test03_pyan",
"email": "[email protected]",
"phone": "555-555-3333"
}
]
NAME:
otlh import matters
USAGE:
otlh import matters [command options] [arguments...]
CATEGORY:
import
OPTIONS:
--excel value, -e value excel file used for legalhold import
--help, -h show help
- Import matters from excel file
./otlh.exe --debug --config otlh_conf.json import matters --excel testdata/matter_import.xlsx
- contacts are not supported since I did not find any public api to get contacts from opentext legalhold service.