Skip to main content

qsAPI - a client for Qlik Sense QPS and QRS interfaces

Project description

About

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.

Installation

You could use your preferred IDE (Eclipse, Visual Code, 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.

Just execute in the command line (libraries and dependencies will be installed):

pip install qsAPI

Optionally, if you plan connect using NTLM authentication, then append optional target.

pip install qsAPI[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

IDE screenshot

Or just a simple command line console if complex scripts are no needed: console screenshot

Usage

Connecting with certificates

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')

Connecting with windows credentials (NTLM)

Alternatively, the constructor accept user credentials via arguments.

>>> qrs=qsAPI.QRS(proxy='hostname', user=('yor_domain','username','password'))

Examples

Count users using a filter

qrs.count('user',"Name eq 'sa_repository'")

Duplicate an application in the server

qrs.AppCopy('a99babf2-3c9d-439d-99d2-66fa7276604e',"HELLO world")

Export an application

qrs.AppExport('a99babf2-3c9d-439d-99d2-66fa7276604e',"c:\\path\\myAppName.qvf")

Export all published applications to directories

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'])

Retrieve security rules using a filter

qrs.SystemRulesGet("type eq 'Custom'")

Retrieve a list of sessions for a user

[x['SessionId'] for x in qps.GetUser('DIR', 'name').json()]

teardown of all connections for the user and related sessions

qps.DeleteUser('DIR','name')
More examples

Take a look at the Wiki area: (https://github.com/rafael-sanz/qsAPI/wiki)

Command Line

Alternative use as command line is available too, examples:

qsAPI --help
qsAPI -s myServer -c dir/client.pem -Q QRS TaskStartbyName "Reload License Monitor"
qsAPI -s myServer -c dir/client.pem -Q QRS -v INFO AppExport d8b120d7-a6e4-42ff-90b2-2ac6a3d92233
qsAPI -s myServer -c dir/client.pem -Q QRS -v INFO AppReload 79f0c591-67de-4ded-91ae-4865934a5746

TODO

The module is in progress, a subset of methods are implemented. But all the endpoints could be implemented through the inner class driver and the methods get, post, put, delete.

qps.driver.get('/qrs/about/api/enums')

License

This software is made available "AS IS" without warranty of any kind. Qlik support agreement does not cover support for this software.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

qsAPI-2.2.0.tar.gz (22.1 kB view details)

Uploaded Source

Built Distribution

qsAPI-2.2.0-py3-none-any.whl (34.6 kB view details)

Uploaded Python 3

File details

Details for the file qsAPI-2.2.0.tar.gz.

File metadata

  • Download URL: qsAPI-2.2.0.tar.gz
  • Upload date:
  • Size: 22.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.50.0 CPython/3.8.6

File hashes

Hashes for qsAPI-2.2.0.tar.gz
Algorithm Hash digest
SHA256 dd5c44aece47ffeb7c28749bc34ede54cb1f5edc16e21849815f864e12f52f64
MD5 35035740eadbaa10bf9d8db20e6535a9
BLAKE2b-256 8f585127ab0965890f90e134f4fe5df83fd3752f35e7968c46ba3a6e47cff386

See more details on using hashes here.

File details

Details for the file qsAPI-2.2.0-py3-none-any.whl.

File metadata

  • Download URL: qsAPI-2.2.0-py3-none-any.whl
  • Upload date:
  • Size: 34.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.50.0 CPython/3.8.6

File hashes

Hashes for qsAPI-2.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 74e9147cea1902aab7662e1fead516a66c3e6a9cac438ed5f162a12e9cc5faec
MD5 1a080b6e8c4c1c614f6c66fb6fb64f99
BLAKE2b-256 f4e24fed6df40905ccb9da4777ddb503f50c8387ffe71bcd616735856244a036

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page