2022-11-13 16:48:23 +01:00
|
|
|
+++
|
|
|
|
title = "Python"
|
|
|
|
weight = 20
|
|
|
|
+++
|
|
|
|
|
|
|
|
## S3
|
|
|
|
|
2022-12-25 13:55:12 +01:00
|
|
|
### Using Minio SDK
|
|
|
|
|
|
|
|
First install the SDK:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
pip3 install minio
|
|
|
|
```
|
|
|
|
|
|
|
|
Then instantiate a client object using garage root domain, api key and secret:
|
|
|
|
|
|
|
|
```python
|
|
|
|
import minio
|
|
|
|
|
|
|
|
client = minio.Minio(
|
|
|
|
"your.domain.tld",
|
|
|
|
"GKyourapikey",
|
|
|
|
"abcd[...]1234",
|
|
|
|
# Force the region, this is specific to garage
|
|
|
|
region="region",
|
|
|
|
)
|
|
|
|
```
|
2022-11-13 16:48:23 +01:00
|
|
|
|
2022-12-25 13:55:12 +01:00
|
|
|
Then use all the standard S3 endpoints as implemented by the Minio SDK:
|
|
|
|
|
|
|
|
```
|
|
|
|
# List buckets
|
|
|
|
print(client.list_buckets())
|
|
|
|
|
|
|
|
# Put an object containing 'content' to /path in bucket named 'bucket':
|
|
|
|
content = b"content"
|
|
|
|
client.put_object(
|
|
|
|
"bucket",
|
|
|
|
"path",
|
|
|
|
io.BytesIO(content),
|
|
|
|
len(content),
|
|
|
|
)
|
|
|
|
|
|
|
|
# Read the object back and check contents
|
|
|
|
data = client.get_object("bucket", "path").read()
|
|
|
|
assert data == content
|
|
|
|
```
|
|
|
|
|
|
|
|
For further documentation, see the Minio SDK
|
|
|
|
[Reference](https://docs.min.io/docs/python-client-api-reference.html)
|
|
|
|
|
|
|
|
### Using Amazon boto3
|
|
|
|
|
|
|
|
*Coming soon*
|
2022-11-13 16:48:23 +01:00
|
|
|
|
2022-12-25 13:55:12 +01:00
|
|
|
See the official documentation:
|
|
|
|
- [Installation](https://boto3.amazonaws.com/v1/documentation/api/latest/guide/quickstart.html)
|
|
|
|
- [Reference](https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/s3.html)
|
|
|
|
- [Example](https://boto3.amazonaws.com/v1/documentation/api/latest/guide/s3-uploading-files.html)
|
2022-11-13 16:48:23 +01:00
|
|
|
|
|
|
|
## K2V
|
|
|
|
|
|
|
|
*Coming soon*
|
|
|
|
|
|
|
|
## Admin API
|
|
|
|
|
|
|
|
You need at least Python 3.6, pip, and setuptools.
|
|
|
|
Because the python package is in a subfolder, the command is a bit more complicated than usual:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
pip3 install --user 'git+https://git.deuxfleurs.fr/garage-sdk/garage-admin-sdk-python'
|
|
|
|
```
|
|
|
|
|
|
|
|
Now, let imagine you have a fresh Garage instance running on localhost, with the admin API configured on port 3903 with the bearer `s3cr3t`:
|
|
|
|
|
|
|
|
```python
|
|
|
|
import garage_admin_sdk
|
|
|
|
from garage_admin_sdk.apis import *
|
|
|
|
from garage_admin_sdk.models import *
|
|
|
|
|
|
|
|
configuration = garage_admin_sdk.Configuration(
|
2023-11-28 16:18:28 +01:00
|
|
|
host = "http://localhost:3903/v1",
|
2022-11-13 16:48:23 +01:00
|
|
|
access_token = "s3cr3t"
|
|
|
|
)
|
|
|
|
|
|
|
|
# Init APIs
|
|
|
|
api = garage_admin_sdk.ApiClient(configuration)
|
|
|
|
nodes, layout, keys, buckets = NodesApi(api), LayoutApi(api), KeyApi(api), BucketApi(api)
|
|
|
|
|
|
|
|
# Display some info on the node
|
|
|
|
status = nodes.get_nodes()
|
|
|
|
print(f"running garage {status.garage_version}, node_id {status.node}")
|
|
|
|
|
|
|
|
# Change layout of this node
|
|
|
|
current = layout.get_layout()
|
2023-11-28 16:18:28 +01:00
|
|
|
layout.add_layout([
|
|
|
|
NodeRoleChange(
|
|
|
|
id = status.node,
|
2022-11-13 16:48:23 +01:00
|
|
|
zone = "dc1",
|
2023-11-28 16:18:28 +01:00
|
|
|
capacity = 1000000000,
|
2022-11-13 16:48:23 +01:00
|
|
|
tags = [ "dev" ],
|
|
|
|
)
|
2023-11-28 16:18:28 +01:00
|
|
|
])
|
2022-11-13 16:48:23 +01:00
|
|
|
layout.apply_layout(LayoutVersion(
|
|
|
|
version = current.version + 1
|
|
|
|
))
|
|
|
|
|
|
|
|
# Create key, allow it to create buckets
|
|
|
|
kinfo = keys.add_key(AddKeyRequest(name="openapi"))
|
|
|
|
|
|
|
|
allow_create = UpdateKeyRequestAllow(create_bucket=True)
|
|
|
|
keys.update_key(kinfo.access_key_id, UpdateKeyRequest(allow=allow_create))
|
|
|
|
|
|
|
|
# Create a bucket, allow key, set quotas
|
|
|
|
binfo = buckets.create_bucket(CreateBucketRequest(global_alias="documentation"))
|
|
|
|
binfo = buckets.allow_bucket_key(AllowBucketKeyRequest(
|
|
|
|
bucket_id=binfo.id,
|
|
|
|
access_key_id=kinfo.access_key_id,
|
|
|
|
permissions=AllowBucketKeyRequestPermissions(read=True, write=True, owner=True),
|
|
|
|
))
|
|
|
|
binfo = buckets.update_bucket(binfo.id, UpdateBucketRequest(
|
|
|
|
quotas=UpdateBucketRequestQuotas(max_size=19029801,max_objects=1500)))
|
|
|
|
|
|
|
|
# Display key
|
|
|
|
print(f"""
|
|
|
|
cluster ready
|
|
|
|
key id is {kinfo.access_key_id}
|
|
|
|
secret key is {kinfo.secret_access_key}
|
|
|
|
bucket {binfo.global_aliases[0]} contains {binfo.objects}/{binfo.quotas.max_objects} objects
|
|
|
|
""")
|
|
|
|
```
|
|
|
|
|
|
|
|
*This example is named `short.py` in the example folder. Other python examples are also available.*
|
|
|
|
|
|
|
|
See also:
|
|
|
|
- [sdk repo](https://git.deuxfleurs.fr/garage-sdk/garage-admin-sdk-python)
|
|
|
|
- [examples](https://git.deuxfleurs.fr/garage-sdk/garage-admin-sdk-generator/src/branch/main/example/python)
|
|
|
|
|