qsAPI is a client for Qlik Sense QPS and QRS interfaces written in python that provides an environment for managing a Qlik Sense site via programming or interactive console. The module provides a set of commands for viewing and editing configuration settings, as well as managing tasks and other features available through APIs.
You could use your preferred IDE (Eclipse, Visual Studio, NetBeans, etc.) with the python interpreter 3.x or directly in console. Take a look at (https://www.python.org). Once the module is loaded you can view a list of available commands with the autocomplete tooltips.
The python requests
library is a requisite (http://docs.python-requests.org/en/master/user/install/). Just execute in the command line:
pip install requests
Optionally, if you plan connect using NTLM authentication, then the library requests_ntlm
too.
pip install requests_ntlm
Now, the module can be used just importing qsAPI.py at the beginning of your python script or console, the module will then be loaded and ready to use.
>>> import qsAPI
Or just a simple command line console if complex scripts are no needed:
The first step is to build a handler invoking the constructor of the class you will use containing the host parameters, this will attempt to connect to the Qlik Sense server. Just export previously from QlikSense console the certificate in portable format and copy the folder in your machine:
>>> qrs=qsAPI.QRS(proxy='hostname', certificate='path\\client.pem')
Alternatively, the constructor accept user credentials via arguments.
>>> qrs=qsAPI.QRS(proxy='hostname', user=('yor_domain','username','password'))
qrs.count('user',"Name eq 'sa_repository'")
qrs.AppCopy('a99babf2-3c9d-439d-99d2-66fa7276604e',"HELLO world")
qrs.AppExport('a99babf2-3c9d-439d-99d2-66fa7276604e',"c:\\path\\myAppName.qvf")
for app in qrs.AppGet(pFilter="stream.name ne 'None'"):
os.makedirs(app['stream']['name'], exist_ok=True)
qrs.AppExport(app['id'], app['stream']['name']+'\\'+app['name'])
qrs.SystemRules("type eq 'Custom'")
[x['SessionId'] for x in qps.GetUser('DIR', 'name').json()]
qps.DeleteUser('DIR','name')
Take a look at the Wiki area: (https://github.com/rafael-sanz/qsAPI/wiki)
Alternative command line is available too, examples:
python qsAPI.py --help
python qsAPI.py -s myServer -c dir/client.pem -Q QRS StreamDictAttributes
python qsAPI.py -s myServer -c dir/client.pem -Q QRS -v INFO AppExport d8b120d7-a6e4-42ff-90b2-2ac6a3d92233
python qsAPI.py -s myServer -c dir/client.pem -Q QRS -v INFO AppReload d8b120d7-a6e4-42ff-90b2-2ac6a3d92233
The module is in progress, a subset of methods are implemented. But all the endpoints could be handled through the inner class driver
and the methods get, post, put, delete
.
qps.driver.get('/qrs/about/api/enums')
This software is made available "AS IS" without warranty of any kind. Qlik support agreement does not cover support for this software.