mohabusama / pyguacamole

Guacamole Python Client
MIT License
108 stars 34 forks source link
client guacamole library python

=========== PyGuacamole

A Python client library for communication with Guacamole <http://guac-dev.org/>_ server (guacd)

.. image:: https://travis-ci.org/mohabusama/pyguacamole.svg?branch=master :target: https://travis-ci.org/mohabusama/pyguacamole

.. image:: https://img.shields.io/pypi/v/pyguacamole.svg :target: https://python.org/pypi/pyguacamole/

.. image:: https://img.shields.io/pypi/pyversions/pyguacamole.svg :target: https://python.org/pypi/pyguacamole/

.. image:: https://img.shields.io/github/license/mohabusama/pyguacamole.svg :target: https://python.org/pypi/pyguacamole/

.. image:: https://img.shields.io/pypi/status/pyguacamole.svg :target: https://python.org/pypi/pyguacamole/

Installation

Using pip

::

$ pip install pyguacamole

From source

::

$ python setup.py install

Usage

GuacamoleClient handles communication with a running guacd server via Guacamole Protocol <http://guac-dev.org/doc/gug/protocol-reference.html>_.

GuacamoleClient must be used by a broker server which handles communication with a Javscript application running in the browser. GuacamoleClient implements the methods that enables communication with guacd server (send & receive).

First step should be establishing handshake with guacd server, then Broker server should handle instruction sending and receiving:

::

>>> from guacamole.client import GuacamoleClient
>>> client = GuacamoleClient('127.0.0.1', 4822)
>>> client.handshake(protocol='rdp', hostname='localhost', port=3389)

Once instruction is received from guacd server, it should be sent immediately to the browser

::

>>> instruction = client.receive()
>>> instruction
'4.size,1.0,4.1024,3.768;'

and once instruction is sent from browser, it should be sent immediately to guacd server

::

>>> instruction = '5.mouse,3.400,3.500;'
>>> client.send(instruction)

Notes

PyGuacamole is released under the MIT License <https://raw.githubusercontent.com/mohabusama/pyguacamole/master/LICENSE> and is based on the initial effort by Rescale django-guacamole <https://github.com/rescale/django-guacamole> project.