GTXStorage Python Library for Amazon S3 Compatible Cloud Storage for Python
Project description
GTXStorage Python Library for Amazon S3 Compatible Cloud Storage |Gitter|
========
The GTXStorage Python Client SDK provides simple APIs to access any Amazon S3
compatible object storage server.
This quickstart guide will show you how to install the client SDK and
execute an example python program. For a complete list of APIs and
examples, please take a look at the `Python Client API
Reference <https://docs.gtxstorage.io/docs/python-client-api-reference>`__
documentation.
This document assumes that you have a working
`Python <https://www.python.org/downloads/>`__ setup in place.
Download from pip
-----------------
.. code:: sh
$ pip install gtxstorage
Download from source
--------------------
.. code:: sh
$ git clone https://github.com/gtxstorage/gtxstorage-py
$ cd gtxstorage-py
$ python setup.py install
Initialize GTXStorage Client
-----------------------
You need four items in order to connect to GTXStorage object storage server.
.. csv-table::
:header: "Params", "Description"
:widths: 15, 30
"endpoint", "URL to object storage service."
"access_key", "Access key is like user ID that uniquely identifies your account."
"secret_key", "Secret key is the password to your account."
"secure", "Set this value to 'True' to enable secure (HTTPS) access."
.. code:: python
from gtxstorage import GTXStorage
from gtxstorage.error import ResponseError
gtxstorageClient = GTXStorage('play.gtxstorage.io:9000',
access_key='Q3AM3UQ867SPQQA43P2F',
secret_key='zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG',
secure=True)
Quick Start Example - File Uploader
-----------------------------------
This example program connects to a GTXStorage object storage server, makes a
bucket on the server and then uploads a file to the bucket.
We will use the GTXStorage server running at https://play.gtxstorage.io:9000 in
this example. Feel free to use this service for testing and development.
Access credentials shown in this example are open to the public.
file-uploader.py
~~~~~~~~~~~~~~~~
.. code:: python
# Import GTXStorage library.
from gtxstorage import GTXStorage
from gtxstorage.error import ResponseError
# Initialize gtxstorageClient with an endpoint and access/secret keys.
gtxstorageClient = GTXStorage('play.gtxstorage.io:9000',
access_key='Q3AM3UQ867SPQQA43P2F',
secret_key='zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG',
secure=True)
# Make a bucket with the make_bucket API call.
try:
gtxstorageClient.make_bucket("maylogs", location="us-east-1")
except BucketAlreadyOwnedByYou as err:
pass
except BucketAlreadyExists as err:
pass
except ResponseError as err:
raise
else:
# Put an object 'pumaserver_debug.log' with contents from 'pumaserver_debug.log'.
try:
gtxstorageClient.fput_object('maylogs', 'pumaserver_debug.log', '/tmp/pumaserver_debug.log')
except ResponseError as err:
print(err)
Run file-uploader
~~~~~~~~~~~~~~~~~
.. code:: bash
$ python file_uploader.py
$ mc ls play/maylogs/
[2016-05-27 16:41:37 PDT] 12MiB pumaserver_debug.log
API Reference
-------------
The full API Reference is available here. `Complete API
Reference <https://docs.gtxstorage.io/docs/python-client-api-reference>`__
API Reference : Bucket Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `make\_bucket <https://docs.gtxstorage.io/docs/python-client-api-reference#make_bucket>`__
- `list\_buckets <https://docs.gtxstorage.io/docs/python-client-api-reference#list_buckets>`__
- `bucket\_exists <https://docs.gtxstorage.io/docs/python-client-api-reference#bucket_exists>`__
- `remove\_bucket <https://docs.gtxstorage.io/docs/python-client-api-reference#remove_bucket>`__
- `list\_objects <https://docs.gtxstorage.io/docs/python-client-api-reference#list_objects>`__
- `list\_incomplete\_uploads <https://docs.gtxstorage.io/docs/python-client-api-reference#list_incomplete_uploads>`__
- `get\_bucket\_policy <https://docs.gtxstorage.io/docs/python-client-api-reference#get_bucket_policy>`__
- `set\_bucket\_policy <https://docs.gtxstorage.io/docs/python-client-api-reference#set_bucket_policy>`__
API Reference : File Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `fput\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#fput_object>`__
- `fget\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#fget_object>`__
API Reference : Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `get\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#get_object>`__
- `get\_partial\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#get_partial_object>`__
- `put\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#put_object>`__
- `stat\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#stat_object>`__
- `remove\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#remove_object>`__
- `remove\_incomplete\_upload <https://docs.gtxstorage.io/docs/python-client-api-reference#remove_incomplete_upload>`__
API Reference : Presigned Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `presigned\_get\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#presigned_get_object>`__
- `presigned\_put_object <https://docs.gtxstorage.io/docs/python-client-api-reference#presigned_put_object>`__
- `presigned\_post\_policy <https://docs.gtxstorage.io/docs/python-client-api-reference#presigned_post_policy>`__
Full Examples
-------------
Full Examples : Bucket Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `list\_buckets.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/list_buckets.py>`__
- `list\_objects.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/list_objects.py>`__
- `bucket\_exists.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/bucket_exists.py>`__
- `make\_bucket.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/make_bucket.py>`__
- `remove\_bucket.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/remove_bucket.py>`__
- `list\_incomplete\_uploads.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/list_incomplete_uploads.py>`__
- `remove\_incomplete\_upload.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/remove_incomplete_upload.py>`__
Full Examples : File Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `fput\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/fput_object.py>`__
- `fget\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/fget_object.py>`__
Full Examples : Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `put\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/put_object.py>`__
- `get\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/get_object.py>`__
- `get\_partial\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/get_partial_object.py>`__
- `remove\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/remove_object.py>`__
- `stat\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/stat_object.py>`__
Full Examples : Presigned Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `presigned\_get\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/presigned_get_object.py>`__
- `presigned\_put\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examplespresigned_put_object.py>`__
- `presigned\_post\_policy.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/presigned_post_policy.py>`__
Explore Further
---------------
- `Complete Documentation <https://docs.gtxstorage.io>`__
- `GTXStorage Python SDK API
Reference <https://docs.gtxstorage.io/docs/python-client-api-reference>`__
Contribute
----------
`Contributors Guide <./CONTRIBUTING.md>`__
|PYPI| |Build Status| |Build status|
.. |Gitter| image:: https://badges.gitter.im/Join%20Chat.svg
:target: https://gitter.im/GTXStorage/gtxstorage?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge
.. |PYPI| image:: https://img.shields.io/pypi/v/gtxstorage.svg
:target: https://pypi.python.org/pypi/gtxstorage
.. |Build Status| image:: https://travis-ci.org/gtxstorage/gtxstorage-py.svg
:target: https://travis-ci.org/gtxstorage/gtxstorage-py
.. |Build status| image:: https://ci.appveyor.com/api/projects/status/1d05e6nvxcelmrak?svg=true
:target: https://ci.appveyor.com/project/harshavardhana/gtxstorage-py
========
The GTXStorage Python Client SDK provides simple APIs to access any Amazon S3
compatible object storage server.
This quickstart guide will show you how to install the client SDK and
execute an example python program. For a complete list of APIs and
examples, please take a look at the `Python Client API
Reference <https://docs.gtxstorage.io/docs/python-client-api-reference>`__
documentation.
This document assumes that you have a working
`Python <https://www.python.org/downloads/>`__ setup in place.
Download from pip
-----------------
.. code:: sh
$ pip install gtxstorage
Download from source
--------------------
.. code:: sh
$ git clone https://github.com/gtxstorage/gtxstorage-py
$ cd gtxstorage-py
$ python setup.py install
Initialize GTXStorage Client
-----------------------
You need four items in order to connect to GTXStorage object storage server.
.. csv-table::
:header: "Params", "Description"
:widths: 15, 30
"endpoint", "URL to object storage service."
"access_key", "Access key is like user ID that uniquely identifies your account."
"secret_key", "Secret key is the password to your account."
"secure", "Set this value to 'True' to enable secure (HTTPS) access."
.. code:: python
from gtxstorage import GTXStorage
from gtxstorage.error import ResponseError
gtxstorageClient = GTXStorage('play.gtxstorage.io:9000',
access_key='Q3AM3UQ867SPQQA43P2F',
secret_key='zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG',
secure=True)
Quick Start Example - File Uploader
-----------------------------------
This example program connects to a GTXStorage object storage server, makes a
bucket on the server and then uploads a file to the bucket.
We will use the GTXStorage server running at https://play.gtxstorage.io:9000 in
this example. Feel free to use this service for testing and development.
Access credentials shown in this example are open to the public.
file-uploader.py
~~~~~~~~~~~~~~~~
.. code:: python
# Import GTXStorage library.
from gtxstorage import GTXStorage
from gtxstorage.error import ResponseError
# Initialize gtxstorageClient with an endpoint and access/secret keys.
gtxstorageClient = GTXStorage('play.gtxstorage.io:9000',
access_key='Q3AM3UQ867SPQQA43P2F',
secret_key='zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG',
secure=True)
# Make a bucket with the make_bucket API call.
try:
gtxstorageClient.make_bucket("maylogs", location="us-east-1")
except BucketAlreadyOwnedByYou as err:
pass
except BucketAlreadyExists as err:
pass
except ResponseError as err:
raise
else:
# Put an object 'pumaserver_debug.log' with contents from 'pumaserver_debug.log'.
try:
gtxstorageClient.fput_object('maylogs', 'pumaserver_debug.log', '/tmp/pumaserver_debug.log')
except ResponseError as err:
print(err)
Run file-uploader
~~~~~~~~~~~~~~~~~
.. code:: bash
$ python file_uploader.py
$ mc ls play/maylogs/
[2016-05-27 16:41:37 PDT] 12MiB pumaserver_debug.log
API Reference
-------------
The full API Reference is available here. `Complete API
Reference <https://docs.gtxstorage.io/docs/python-client-api-reference>`__
API Reference : Bucket Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `make\_bucket <https://docs.gtxstorage.io/docs/python-client-api-reference#make_bucket>`__
- `list\_buckets <https://docs.gtxstorage.io/docs/python-client-api-reference#list_buckets>`__
- `bucket\_exists <https://docs.gtxstorage.io/docs/python-client-api-reference#bucket_exists>`__
- `remove\_bucket <https://docs.gtxstorage.io/docs/python-client-api-reference#remove_bucket>`__
- `list\_objects <https://docs.gtxstorage.io/docs/python-client-api-reference#list_objects>`__
- `list\_incomplete\_uploads <https://docs.gtxstorage.io/docs/python-client-api-reference#list_incomplete_uploads>`__
- `get\_bucket\_policy <https://docs.gtxstorage.io/docs/python-client-api-reference#get_bucket_policy>`__
- `set\_bucket\_policy <https://docs.gtxstorage.io/docs/python-client-api-reference#set_bucket_policy>`__
API Reference : File Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `fput\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#fput_object>`__
- `fget\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#fget_object>`__
API Reference : Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `get\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#get_object>`__
- `get\_partial\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#get_partial_object>`__
- `put\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#put_object>`__
- `stat\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#stat_object>`__
- `remove\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#remove_object>`__
- `remove\_incomplete\_upload <https://docs.gtxstorage.io/docs/python-client-api-reference#remove_incomplete_upload>`__
API Reference : Presigned Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `presigned\_get\_object <https://docs.gtxstorage.io/docs/python-client-api-reference#presigned_get_object>`__
- `presigned\_put_object <https://docs.gtxstorage.io/docs/python-client-api-reference#presigned_put_object>`__
- `presigned\_post\_policy <https://docs.gtxstorage.io/docs/python-client-api-reference#presigned_post_policy>`__
Full Examples
-------------
Full Examples : Bucket Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `list\_buckets.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/list_buckets.py>`__
- `list\_objects.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/list_objects.py>`__
- `bucket\_exists.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/bucket_exists.py>`__
- `make\_bucket.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/make_bucket.py>`__
- `remove\_bucket.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/remove_bucket.py>`__
- `list\_incomplete\_uploads.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/list_incomplete_uploads.py>`__
- `remove\_incomplete\_upload.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/remove_incomplete_upload.py>`__
Full Examples : File Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `fput\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/fput_object.py>`__
- `fget\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/fget_object.py>`__
Full Examples : Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `put\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/put_object.py>`__
- `get\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/get_object.py>`__
- `get\_partial\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/get_partial_object.py>`__
- `remove\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/remove_object.py>`__
- `stat\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/stat_object.py>`__
Full Examples : Presigned Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- `presigned\_get\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/presigned_get_object.py>`__
- `presigned\_put\_object.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examplespresigned_put_object.py>`__
- `presigned\_post\_policy.py <https://github.com/gtxstorage/gtxstorage-py/blob/master/examples/presigned_post_policy.py>`__
Explore Further
---------------
- `Complete Documentation <https://docs.gtxstorage.io>`__
- `GTXStorage Python SDK API
Reference <https://docs.gtxstorage.io/docs/python-client-api-reference>`__
Contribute
----------
`Contributors Guide <./CONTRIBUTING.md>`__
|PYPI| |Build Status| |Build status|
.. |Gitter| image:: https://badges.gitter.im/Join%20Chat.svg
:target: https://gitter.im/GTXStorage/gtxstorage?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge
.. |PYPI| image:: https://img.shields.io/pypi/v/gtxstorage.svg
:target: https://pypi.python.org/pypi/gtxstorage
.. |Build Status| image:: https://travis-ci.org/gtxstorage/gtxstorage-py.svg
:target: https://travis-ci.org/gtxstorage/gtxstorage-py
.. |Build status| image:: https://ci.appveyor.com/api/projects/status/1d05e6nvxcelmrak?svg=true
:target: https://ci.appveyor.com/project/harshavardhana/gtxstorage-py
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
gtxstorage-1.1.0.tar.gz
(42.3 kB
view details)
File details
Details for the file gtxstorage-1.1.0.tar.gz
.
File metadata
- Download URL: gtxstorage-1.1.0.tar.gz
- Upload date:
- Size: 42.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5d3442e5105b8fa2180d317411da0e9a1ee27a6a74804e7ba1318f39ebbc8fc3 |
|
MD5 | d2e78734f0732d0707d1a5ed50fca2c6 |
|
BLAKE2b-256 | 5d583dfd8dcf6e0ec65e83b39110a5795d4dc7b07db8db7318671acaa12041eb |