Python client for the AmigoCloud REST API
Project description
Python client for the AmigoCloud REST API.
Installation
Install via pip:
pip install amigocloud
Dependencies
requests: Handles the HTTP requests to the AmigoCloud REST API.
socketIO_client: Handles the AmigoCloud websocket connection.
This dependencies will be automatically installed.
Usage
Authentication
To start using this library, first login with your AmigoCloud credentials:
from amigocloud import AmigoCloud
amigocloud = AmigoCloud(email='user@example.com', password='********')
Requests
Once you’re logged in you can start making requests to the server. You can use full urls or relative API urls:
# All three will do the same request:
amigocloud.get('me')
amigocloud.get('/me')
amigocloud.get('https://www.amigocloud.com/api/v1/me')
Creating a new AmigoCloud project from Python is as simple as:
data = {'name': 'New Project', 'description': 'Created from Python'}
amigocloud.post('me/projects', data)
All responses are parsed as JSON and return a Python object (usually a dict). This data can be later used in another request:
me = amigocloud.get('me')
visible_projects = amigocloud.get(me['visible_projects'])
print 'My projects:'
for project in visible_projects['results']:
print '*', project['name']
You can get the raw response if you want by using the raw parameter:
me = amigocloud.get('me')
images = amigocloud.get(me['images'])
with open('thumbnail.png', 'wb') as thumbnail:
image_data = amigocloud.get(images['thumbnail'], raw=True)
thumbnail.write(image_data)
Websocket connection
The websocket connection is started when the AmigoCloud object is instantiated, and it is closed when the object is destroyed.
To start listening to websocket events related to your user do (you must be logged in to start listening to your events):
amigocloud.listen_user_events()
Once you’re listening to your events, you can start adding callbacks to them. A callback is a function that will be called everytime the event is received.
def project_created(data):
print 'Data received:', data
amigocloud.add_callback('project:creation_succeeded', project_created)
Finally, start running the websocket client:
ac.start_listening()
This method receives an optional parameter seconds. If seconds is None (default value), the client will listen forever. You might want to run this method in a new thread.
Exceptions
An AmigoCloudError exception will be raised if anything fails during the request:
try:
amigocloud.post('me/projects')
except AmigoCloudError as err:
print 'Something failed!'
print 'Status code was', err.response.status_code
print 'Message from server was', err.text
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file amigocloud-1.0.4.tar.gz
.
File metadata
- Download URL: amigocloud-1.0.4.tar.gz
- Upload date:
- Size: 8.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ed0247915c95993eecce054f6e01207163d06eacb8ec3721514d0f13ea41ff1a |
|
MD5 | 35ebd565a48c00d441c4c963c4a93eca |
|
BLAKE2b-256 | 1aaa24b6fa493550a8e4b31f4849b2a472983cf487601ed0745b7e0b61808728 |