Home

Awesome

Cisco Telepresence XAPI over WebSockets, python library.

Python version required: 3.7 or newer.

Description

This library allows you to connect to a Cisco Telepresence endpoint running CE software version 9.7 or later using jsonrpc over websocket. There is also a command-line utility built on top of the library.

The API itself is documented at https://www.cisco.com/c/dam/en/us/td/docs/telepresence/endpoint/api/collaboration-endpoint-software-api-transport.pdf

Installing

From PyPi

pip install [--user] xows

From a checkout of the git repo

python setup.py install [--user]

Requirements

Websockets should be set to FollowHTTPService and HTTP Mode should be set to either HTTPS or HTTP/HTTPS.

Usage example

import xows
import asyncio

async def start():
    async with xows.XoWSClient('10.10.10.1', username='admin1', password='') as client:
        def callback(data, id_):
            print(f'Feedback (Id {id_}): {data}')

        print('Status Query:',
            await client.xQuery(['Status', '**', 'DisplayName']))

        print('Get status:',
            await client.xGet(['Status', 'Audio', 'Volume']))
            
        print('Get configuration:',
            await client.xGet(['Configuration', 'SIP', 'Proxy', 1, 'Address']))

        print('Command:',
              await client.xCommand(['Audio', 'Volume', 'Set'], Level=60))

        print('Configuration:',
            await client.xSet(['Configuration', 'Audio', 'DefaultVolume'], 50))

        print('Subscription 0:',
            await client.subscribe(['Status', 'Audio', 'Volume'], callback, True))

        await client.wait_until_closed()

asyncio.run(start())

For more usage examples, check out the clixows script. It's source is found under xows/__main__.py and it can be invoked using python3 -m xows, or, after install, as clixows

Note that piping output from python scripts to other commands doesn't work well unless you switch to unbuffered output, so e.g. if you want timestamping using ts(1) you need to do e.g.

python3 -u -m xows my-endpoint feedback '**' | ts