Difference between revisions of "MailStore Server Management Shell"

[unchecked revision][checked revision]
 
(39 intermediate revisions by 4 users not shown)
Line 3: Line 3:
 
The management shell is useful when no graphical user interface is available (e.g. if using telnet or ssh) or for the integration of scripts (e.g. batch files) that are executed either manually or automatically.
 
The management shell is useful when no graphical user interface is available (e.g. if using telnet or ssh) or for the integration of scripts (e.g. batch files) that are executed either manually or automatically.
  
= Option 1: Starting the Management Shell in MailStore Client =
+
Beside the client-side commands, the Management Shell also offers access to server-side commands of the [[Administration API - Using the API|MailStore Server Administration API]]. Output of server-side commands is in JSON format.
 
 
The management shell can be started directly from MailStore: Log on to MailStore Client as administrator and click on ''Administrative Tools'' > ''Miscellaneous'' and then on ''Management Shell''.
 
  
 +
== Starting the Management Shell in MailStore Client ==
 +
The management shell can be started directly from MailStore: Log on to MailStore Client as administrator and click on ''Administrative Tools > Management API > Command Prompt''.
 
[[File:tech_mscmd_01.png|center|450px]]
 
[[File:tech_mscmd_01.png|center|450px]]
 +
The font size can be adjusted by holding the Ctrl key and using the mouse wheel or pressing + and -. Holding down the Ctrl key and pressing 0 resets the font size.
  
= Option 2: Starting the Management Shell with MailStoreCmd.exe =
+
== Using MailStoreCmd.exe in Non-Interactive Mode ==
 +
In non-interactive mode, the management shell logs on with the access data passed, executes the command passed, and automatically terminates upon execution. If the login and the execution of the command were successful, the exit code (ERRORLEVEL) of the process is set to 0 (zero), otherwise it is set to any value other than 0. ''MailStoreCmd.exe'' can be found in the installation directory of MailStore Server. ''MailStoreCmdSilent.exe'' does the same, but does not open a console window.
  
The command line client can be started in interactive mode by executing <code>MailStoreCmd.exe</code> without any parameters. After successful login, MailStore is ready to receive commands. Enter ''exit'' to log off and close the management shell.
+
Login credentials for your installation can be found in the scheduled task of an archiving profile of the type ''E-Mail Programs'' or ''E-Mail Files''.
  
[[File:tech_mscmd_02.png|center|450px]]
+
There are multiple ways to pass credentials to ''MailStoreCmd.exe''.
  
= Using MailStoreCmd.exe in Non-Interactive Mode =
+
To read credentials from the Windows Credentials Manager, they have to be stored there first. The MailStore Client does this automatically when creating a scheduled task in the Windows Task Planer. This methods prevents reading passwords easily by unauthorized persons.
  
In non-interactive mode, the management shell logs on with the access data passed, executes the command passed, and automatically terminates upon execution. If the login and the execution of the command were successful, the exit code (ERRORLEVEL) of the process is set to 0 (zero), otherwise it is set to any value other than 0.
+
MailStoreCmd.exe --h=<server> --cred=<user>@<server/ip address> --pkv3=<thumbprint> -c <command> [--param1=<value> --param2=<value> ...]
  
To use the non-interactive mode, pass the parameters as follows:
+
The credentials can also be passed as plain text.
  
  MailStoreCmd.exe --h="localhost" --pkv3="23:18:06:3f:24:7d:f3:83" --u="admin" --p="admin"
+
MailStoreCmd.exe --h=<server> --u=<user> --p=<password> --pkv3=<thumbprint> -c <command> [--param1=<value> --param2=<value> ...]
  -c <Actual Command and Parameter>
 
  
The following is a description of the parameters:
+
The below command line parameters are required followed by additional API command parameters if necessary.
  
  --h="localhost"
+
{| class="wikitable"
The machine name of the MailStore server to which <code>MailStoreCmd.exe</code> is to connect.
+
! width=100px | Parameter
 
+
! width=100% | Description
  --pkv3="..."
+
|-
The (optional) Public Key Fingerprint, which guarantees the identity of MailStore Server.
+
| <code>--h</code>
 
+
|The machine name of the MailStore server to which <code>MailStoreCmd.exe</code> is to connect.
  --u="admin"
 
User name.
 
 
 
  --p="admin"
 
Password.
 
 
 
  -c
 
The actual command follows (non-interactive mode).
 
 
 
= Command Overview =
 
 
 
Find a list of all client side commands below. An overview of all available server side commands can be found under [[MailStore Server Administration API Commands]].
 
 
 
<p class="msnote">'''Hint: ''' Enter ''schedule'' in front of a management shell command, client and server side, allows you to define a schedule for executing the given management shell command regularly.</p>
 
 
 
  backup --target=<targetdirectory> [--nosync] [--skipreadonly] [--filegroups=1,2,...,4]
 
 
 
Create a backup of the archive. Following parameters are supported:
 
 
 
{| width=80% |
 
 
|-
 
|-
| width="30%" | <code>--target</code>
+
| <code>--pkv3</code>
| directory where to create the backup
+
| The (optional) Public Key Fingerprint, which guarantees the identity of MailStore Server.
 
|-
 
|-
| <code>--nosync</code>
+
| <code>--u</code>
| copy all files; not only new or modified ones
+
| User name
 +
|-
 +
| <code>--p</code>
 +
| Password
 +
|-
 +
| <code>--cred</code>
 +
| Alternative to <code>--u</code> and <code>--p</code>, the password is read from the Windows Credential Manager. The parameter must be entered in the from <user>@<server/ip address>.
 +
|-
 +
| <code>--nologo</code>
 +
| Optional. Prevents the logo from being displayed.
 
|-
 
|-
| <code>--skipreadonly</code>
+
| <code>--o</code>
| skip file groups marked as read only
+
| Optional. Redirects the output to a given file. When this parameter is given, no output is sent to the console. The placeholders ''{DATE}'' and ''{TIME}'' are replaced with the current date and time at execution time.
 
|-
 
|-
| <code>--filegroups=1,2,...,4</code>
+
| <code>-c</code>
| make backup of given file groups only
+
| The actual command follows (non-interactive mode). This must be the last parameter.
|}  
+
|}
 +
 
 +
== Command Overview ==
 +
 
 +
=== Client side commands ===
 +
Find a list of all client side commands below.
  
 
   clear
 
   clear
Line 74: Line 69:
 
Activates debug protocol for IMAP and HTTP connections during archiving for the running MailStore Client process.
 
Activates debug protocol for IMAP and HTTP connections during archiving for the running MailStore Client process.
  
   debug-console,  debuglog-browsedebuglog-disable,  debuglog-enable
+
   debuglog-browse
 +
 
 +
Opens the file explorer and shows MailStore's ''Debug Log'' directory.
 +
 
 +
  debuglog-enable,  debuglog-disable
  
Activates, displays or deactivates the global debug protocol (within computer scope).
+
Activates or deactivates the global debug protocol (within computer scope).
  
 
   export-execute [--name=<profilename>] [--id=<profileid>] [--verbose] [--[property]="value"]
 
   export-execute [--name=<profilename>] [--id=<profileid>] [--verbose] [--[property]="value"]
Line 125: Line 124:
 
Displays a list of all existing archiving profiles (ID and profile name).
 
Displays a list of all existing archiving profiles (ID and profile name).
  
   store-setprop --name=<name> [--value=<value>]
+
  livelog-client-disable,  livelog-client-enable,  livelog-server-disable,  livelog-server-enable
 +
 
 +
Activates or deactivates the live debug protocol of MailStore Server or MailStore Client. The live protocol can be viewed with Sysinternal's DebugView. DebugView must be started with elevated privileges and it must be configured to capture ''Global Win 32'' events.
 +
 
 +
   store-setprop --name=<name> [--value=true/false]
  
 
Changes the value of a global property
 
Changes the value of a global property
Line 140: Line 143:
 
Following global properties are supported:
 
Following global properties are supported:
  
{| width="100%" border="0" cellpadding="0" cellspacing="0"
+
{| width="100%" border="0" cellpadding="0" cellspacing="0" style="font-size: 90%;"
 
|-
 
|-
 
! scope="col" width="20%" bgcolor="#cccccc" | Name  
 
! scope="col" width="20%" bgcolor="#cccccc" | Name  
! scope="col" bgcolor="#cccccc" | Version
 
 
! scope="col" bgcolor="#cccccc" | Values  
 
! scope="col" bgcolor="#cccccc" | Values  
 
! scope="col" bgcolor="#cccccc" | Default
 
! scope="col" bgcolor="#cccccc" | Default
 
|-
 
|-
 
| scope="col" width="20%" align="left" valign="top" | public.arcclient.skipMimeContentConversionFailed
 
| scope="col" width="20%" align="left" valign="top" | public.arcclient.skipMimeContentConversionFailed
| align="center" valign="top" | 8
 
 
| ''true'' = Exchange ''MimeContentConversionFailed'' errors are ignored and not handled as an archiving error.<br/><br/>  
 
| ''true'' = Exchange ''MimeContentConversionFailed'' errors are ignored and not handled as an archiving error.<br/><br/>  
''false'' = Exchange ''MimeContentConversionFailed'' error are handled as archiving errors.  
+
''false'' = Exchange ''MimeContentConversionFailed'' errors are handled as archiving errors.  
 
| align="center" valign="top" | false
 
| align="center" valign="top" | false
 +
|-
 +
| scope="col" width="20%" align="left" valign="top" | public.arcclient.skipVirusDetected
 +
| ''true'' = Exchange ''ErrorVirusDetected'' errors are ignored and not handled as an archiving error.<br/><br/>
 +
''false'' = Exchange ''ErrorVirusDetected'' errors are handled as archiving errors.
 +
| align="center" valign="top" | false
 +
|-
 +
| scope="col" width="20%" align="left" valign="top" | public.arcclient.skipEwsErrorItemNotFound
 +
| ''true'' = Exchange ''ErrorItemNotFound'' errors are ignored and not handled as an archiving error.<br/><br/>
 +
''false'' = Exchange ''ErrorItemNotFound'' errors are handled as archiving errors.
 +
| align="center" valign="top" | false
 +
|-
 +
| scope="col" width="20%" align="left" valign="top" | public.backup.hideNotDetectedWarningMessage
 +
| ''true'' = Backup warning messages are not shown on dashboard.<br/><br/>
 +
''false'' = Backup warning messages are shown on dashboard.
 +
| align="center" valign="top" | false
 
|}
 
|}
  
Line 157: Line 173:
  
 
Display list of users.
 
Display list of users.
 +
 +
=== Server side commands ===
 +
 +
An overview of all available server side commands can be found under [[Administration API - Function Reference|Function Reference]].
 +
 +
The parameters of server side commands are case sensitive and must be entered with two dashes (--). Boolean values must be entered as ''true'' or ''false''. Strings that contain white space characters must be set in quotes.
 +
 +
'''Examples:'''
 +
 +
GetProfiles --raw=true
 +
Lists all archiving and export profiles.
 +
 +
GetUserInfo --userName="alexis.page"
 +
Lists the properties of the user ''alexis.page''.
 +
 +
GetJobResults --fromIncluding="2018-01-01T00:00:00" --toExcluding="2019-01-01T00:00:00" --timeZoneId="$Local" --jobId=1
 +
Lists the results of the job with id 1 of the year 2018.
 +
 +
GetWorkerResults --fromIncluding="2018-01-01T00:00:00" --toExcluding="2019-01-01T00:00:00" --timeZoneID="$Local" --profileID=1
 +
Lists the results of the archiving profile with  id 1 of the year 2018.
 +
The command ''GetWorkerResults'' is the only command where the parameter ''timeZoneID'' is written with a capital ''D''.
 +
 +
RunProfile --id=1
 +
Starts the archiving or export profile with id 1.
  
 
[[de:MailStore_Server_Management_Shell]]
 
[[de:MailStore_Server_Management_Shell]]
 +
[[en:MailStore_Server_Management_Shell]]

Latest revision as of 10:40, 19 February 2024

Many instructions available in the graphical user interface of MailStore Client can also be executed using MailStore's management shell, a command line client which is automatically included when installing MailStore Server and MailStore Client.

The management shell is useful when no graphical user interface is available (e.g. if using telnet or ssh) or for the integration of scripts (e.g. batch files) that are executed either manually or automatically.

Beside the client-side commands, the Management Shell also offers access to server-side commands of the MailStore Server Administration API. Output of server-side commands is in JSON format.

Starting the Management Shell in MailStore Client

The management shell can be started directly from MailStore: Log on to MailStore Client as administrator and click on Administrative Tools > Management API > Command Prompt.

Tech mscmd 01.png

The font size can be adjusted by holding the Ctrl key and using the mouse wheel or pressing + and -. Holding down the Ctrl key and pressing 0 resets the font size.

Using MailStoreCmd.exe in Non-Interactive Mode

In non-interactive mode, the management shell logs on with the access data passed, executes the command passed, and automatically terminates upon execution. If the login and the execution of the command were successful, the exit code (ERRORLEVEL) of the process is set to 0 (zero), otherwise it is set to any value other than 0. MailStoreCmd.exe can be found in the installation directory of MailStore Server. MailStoreCmdSilent.exe does the same, but does not open a console window.

Login credentials for your installation can be found in the scheduled task of an archiving profile of the type E-Mail Programs or E-Mail Files.

There are multiple ways to pass credentials to MailStoreCmd.exe.

To read credentials from the Windows Credentials Manager, they have to be stored there first. The MailStore Client does this automatically when creating a scheduled task in the Windows Task Planer. This methods prevents reading passwords easily by unauthorized persons.

MailStoreCmd.exe --h=<server> --cred=<user>@<server/ip address> --pkv3=<thumbprint> -c <command> [--param1=<value> --param2=<value> ...]

The credentials can also be passed as plain text.

MailStoreCmd.exe --h=<server> --u=<user> --p=<password> --pkv3=<thumbprint> -c  <command> [--param1=<value> --param2=<value> ...]

The below command line parameters are required followed by additional API command parameters if necessary.

Parameter Description
--h The machine name of the MailStore server to which MailStoreCmd.exe is to connect.
--pkv3 The (optional) Public Key Fingerprint, which guarantees the identity of MailStore Server.
--u User name
--p Password
--cred Alternative to --u and --p, the password is read from the Windows Credential Manager. The parameter must be entered in the from <user>@<server/ip address>.
--nologo Optional. Prevents the logo from being displayed.
--o Optional. Redirects the output to a given file. When this parameter is given, no output is sent to the console. The placeholders {DATE} and {TIME} are replaced with the current date and time at execution time.
-c The actual command follows (non-interactive mode). This must be the last parameter.

Command Overview

Client side commands

Find a list of all client side commands below.

 clear

Clears the texts currently displayed improving visibility.

 debug-conn

Activates debug protocol for IMAP and HTTP connections during archiving for the running MailStore Client process.

 debuglog-browse

Opens the file explorer and shows MailStore's Debug Log directory.

 debuglog-enable,  debuglog-disable

Activates or deactivates the global debug protocol (within computer scope).

 export-execute [--name=<profilename>] [--id=<profileid>] [--verbose] [--[property]="value"]

Executes an export profile. Following parameters are supported:

--name | --id name or ID of the export profile to execute
--verbose activates a detailed status display on the console
--[property] Overwrites the given property of a profile. The internal properties can be displayed, by selecting an export profile and press CTRL + SHIFT + P. The name of the property has to be in brackets. Multiple properties can be modified by repeating the parameter.
 export-list

Displays a list of all existing export profiles (ID and profile name).

 help

Displays a list of all available commands and their parameters.

 import-execute [--name=<profilename>] [--id=<profileid>] [--verbose] [--user=<username>] [--[property]="value"]

Executes the archiving profile. Following parameters are supported:

--name | --id name or ID of the import profile to execute
--verbose activates a detailed status display on the console
--user user archive to store archived emails
--[property] Overwrites the given property of a profile. The internal properties can be displayed, by selecting an archiving profile and press CTRL + SHIFT + P. The name of the property has to be in brackets. Multiple properties can be modified by repeating the parameter.
 import-list [--user=<username>]

Displays a list of all existing archiving profiles (ID and profile name).

 livelog-client-disable,  livelog-client-enable,  livelog-server-disable,  livelog-server-enable

Activates or deactivates the live debug protocol of MailStore Server or MailStore Client. The live protocol can be viewed with Sysinternal's DebugView. DebugView must be started with elevated privileges and it must be configured to capture Global Win 32 events.

 store-setprop --name=<name> [--value=true/false]

Changes the value of a global property

--name Name of the global property
--value Value of the global property

Following global properties are supported:

Name Values Default
public.arcclient.skipMimeContentConversionFailed true = Exchange MimeContentConversionFailed errors are ignored and not handled as an archiving error.

false = Exchange MimeContentConversionFailed errors are handled as archiving errors.

false
public.arcclient.skipVirusDetected true = Exchange ErrorVirusDetected errors are ignored and not handled as an archiving error.

false = Exchange ErrorVirusDetected errors are handled as archiving errors.

false
public.arcclient.skipEwsErrorItemNotFound true = Exchange ErrorItemNotFound errors are ignored and not handled as an archiving error.

false = Exchange ErrorItemNotFound errors are handled as archiving errors.

false
public.backup.hideNotDetectedWarningMessage true = Backup warning messages are not shown on dashboard.

false = Backup warning messages are shown on dashboard.

false
 user-list

Display list of users.

Server side commands

An overview of all available server side commands can be found under Function Reference.

The parameters of server side commands are case sensitive and must be entered with two dashes (--). Boolean values must be entered as true or false. Strings that contain white space characters must be set in quotes.

Examples:

GetProfiles --raw=true

Lists all archiving and export profiles.

GetUserInfo --userName="alexis.page"

Lists the properties of the user alexis.page.

GetJobResults --fromIncluding="2018-01-01T00:00:00" --toExcluding="2019-01-01T00:00:00" --timeZoneId="$Local" --jobId=1

Lists the results of the job with id 1 of the year 2018.

GetWorkerResults --fromIncluding="2018-01-01T00:00:00" --toExcluding="2019-01-01T00:00:00" --timeZoneID="$Local" --profileID=1

Lists the results of the archiving profile with id 1 of the year 2018. The command GetWorkerResults is the only command where the parameter timeZoneID is written with a capital D.

RunProfile --id=1

Starts the archiving or export profile with id 1.