Python API Wrapper Tutorial
This document explains the installation and usage of the Python API Wrapper library, which is meant to be an example implementation of a MailStore Server Administration API client. The Administration API allows you to develop scripts for administration of MailStore Server.
Please note: It is strongly recommended to use a non-productive test environment for this tutorial as well as for script development in general, in order to prevent loss of data or other problems. For example, the 30-day-trial version of MailStore Server is perfectly suited for this.
Installation
The API library is tested against Python 3.2 to Python 3.4. It is compatible with the 32bit and the 64bit versions of Python.
You can get Python binaries for various operating systems from the Python download page or you can install it using the package manager of your Linux distribution.
Additionally you need the MailStore API library which has to be installed in your Python's site-packages mailstore directory. The location of the site-packages directory can be found with the following command
python -c "from distutils.sysconfig import get_python_lib; print(get_python_lib())"
Log in
Before the API library can be used to it must first be imported with
import mailstore
Now you are able to instantiate the mailstore.server.Client class
serverClient = mailstore.server.Client(username="admin", password="admin", host="127.0.0.1", port=8463)
Default values can be omitted. The admin/admin credentials are only valid when connecting from the MailStore Server computer itself to localhost. Find a listing of all default values in the following table:
Parameter | Default Value |
---|---|
username | admin |
password | admin |
host | 127.0.0.1 |
port | 8463 |
autoHandleToken | True |
waitTime | 1 |
logLevel | 2 |
If autoHandleToken is enabled, you do not have to care about long running processes, instead you just have to wait for the result. When this value is set to False, a status token is returned and you have to handle the token yourself. Further details about long running processes will be give later in this document.
The waitTime value specifies the value that is passed to the get-status call. When you call a long running method like VerifyStore, this is the amount of seconds you have to wait for a status update.
logLevel has to be in the range 0 to 4 where loglevel 0 (NONE) has the lowest verbosity and 4 (DEBUG) the highest. The loglevels are defined in the following order (low to high verbosity) NONE, ERROR, WARNING, INFO and DEBUG.
Log entries will be printed to stdout.
Invoking Simple Calls
Simple calls will always return immediately and not token handling is required.
print(serverClient.GetServerInfo())
{'machineName': 'WIN2012MS', 'version': '8.1.2.9268'}
When the call was successful the information is stored in the returned Python dictionary. When it failed, an HTTP error will be thrown.
Examples
To get detailed information of all users you could use the following snippet:
serverClient = mailstore.server.Client(username="admin", password="admin", host="127.0.0.1", port=8463)
for user in serverClient.GetUserList():
print(serverClient.GetUserInfo(user["userName"]))
A list with all assigned email address can be retrieved as follows:
serverClient = mailstore.server.Client(username="admin", password="admin", host="127.0.0.1", port=8463)
emailaddresses = list()
for user in serverClient.GetUserList():
emailaddresses += serverClient.GetUserInfo(user["userName"])['emailAddresses']
print(emailaddresses)
Long Running Calls
The execution of certain API methods like VerifyStore can take several minutes or even hours until it finishes. These long running calls are executed asynchronously on the MailStore Server and you can decide whether to poll for status updates regularly and, in order to output the progress, process them in your own script or let the Python API library silently handle this for you and just wait for the call to finish.
Invoking
When autoHandleToken is set to True (default), the library polls the status in the background automatically and will return the final result when the process has ended.
Automatic Token Handling
serverClient = mailstore.server.Client(autoHandleToken=True)
storeID = 1
print(serverClient.VerifyStore(storeID))
{'status': 'succeeded', 'progressPercentage': 100, 'messages': [{'text': 'Verifying file group #2...', 'type': 'line'}, {'text': 'Creating a list of messages to be verified...', 'type': 'line'}, {'text': '234 messages are about to be verified.', 'type': 'line'}, {'text': 'Verifying...', 'type': 'line'}, {'text': ' 100 messages verified...', 'type': 'line'}, {'text': ' 200 messages verified...', 'type': 'line'}, {'text': ' 234 messages verified.', 'type': 'line'}, {'text': 'Finished. No errors have been found.', 'type': 'line'}]}
Manual Token Handling
Set autoHandleToken to False to get the token and handle it all by yourself. You are able to poll for status updates manually by passing the token to the GetStatus method. The main call has finished when the status has changed some else than running. Please refer to the source code for available token handling helper methods.
import time
serverClient = mailstore.server.Client(autoHandleToken=False)
storeID = 2
token = serverClient.VerifyStore(storeID)
print(token)
while True:
time.sleep(1)
status = serverClient.GetStatus(token)
print(status)
if status["status"] != "running":
break
{'statusUrl': '/JSON/Status/243fc983-89c3-19ef-196a-dbe082894cc5', 'statusToken': '243fc983-89c3-19ef-196a-dbe082894cc5'}
{'progressPercentage': 0, 'messages': [{'type': 'line', 'text': 'Verifying file group #2...'}, {'type': 'line', 'text': 'Creating a list of messages to be verified...'}, {'type': 'line', 'text': '234 messages are about to be verified.'}, {'type': 'line', 'text': 'Verifying...'}, {'type': 'line', 'text': ' 100 messages verified...'}], 'status': 'running'}
{'progressPercentage': 100, 'messages': [{'type': 'line', 'text': 'Verifying file group #2...'}, {'type': 'line', 'text': 'Creating a list of messages to be verified...'}, {'type': 'line', 'text': '234 messages are about to be verified.'}, {'type': 'line', 'text': 'Verifying...'}, {'type': 'line', 'text': ' 100 messages verified...'}, {'type': 'line', 'text': ' 200 messages verified...'}, {'type': 'line', 'text': ' 234 messages verified.'}, {'type': 'line', 'text': 'Finished. No errors have been found.'}], 'status': 'succeeded'}
Pass the token to the HandleToken method will result in exactly the same behavior as if autoHandleToken=True would have been set.
serverClient = mailstore.server.Client(autoHandleToken=False)
storeID = 2
token = serverClient.VerifyStore(storeID)
print(token)
print(serverClient.HandleToken(token))
Selective Token Handling
The Token handling behavior can be modified globally and locally. If the API client was instantiated with autoHandleToken=True, each method can still be called with autoHandleToken=False and vice versa to disable or enable automatic token handling whenever necessary. Methods that do not return a token, do not accept the autoHandleToken parameter.
serverClient = mailstore.server.Client(autoHandleToken=False)
storeID = 2
token = serverClient.VerifyStore(storeID, autoHandleToken=True)
print(token)
{'status': 'succeeded', 'messages': [{'text': 'Verifying file group #2...', 'type': 'line'}, {'text': 'Creating a list of messages to be verified...', 'type': 'line'}, {'text': '234 messages are about to be verified.', 'type': 'line'}, {'text': 'Verifying...', 'type': 'line'}, {'text': ' 100 messages verified...', 'type': 'line'}, {'text': ' 200 messages verified...', 'type': 'line'}, {'text': ' 234 messages verified.', 'type': 'line'}, {'text': 'Finished. No errors have been found.', 'type': 'line'}], 'progressPercentage': 100}
Cancelling
Currently long running calls cannot be cancelled. This is not a limitation of the Python wrapper, but of the MailStore Management API itself. This will be changed in the next major release of MailStore Server.
Exception Handling
When there are no HTTP errors, the returned value is always a python dictionary.
In case an error occured, the call will raise an Exception. All MailStore Exceptions are derived from mailstore.errors.MailStoreBaseError which itself is derived from Exception.
try:
print(serverClient.GetUserInfo("not_such_user"))
except mailstore.errors.MailStoreBaseError as e:
print(e)
ERROR ('internal MailStore Server error',)
500 Internal Server Error https://127.0.0.1:8463/JSON/Invoke/GetUserInfo POST userName=not_such_user Command in MethodList: True
Pretty Printing the Output
There is a helper function that formats the returned values in more readable manner.
mailstore.pprint(serverClient.GetUserInfo("admin"))
authentication integrated
distinguishedName
privileges
admin
fullName Administrator
userName admin
Methods Overview
All the methods listed in the method overview are implemented in the Python API library.
Additional (helper) methods available. Please see the source code for further details about these methods.