diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:45:59 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 18:45:59 +0000 |
commit | 19fcec84d8d7d21e796c7624e521b60d28ee21ed (patch) | |
tree | 42d26aa27d1e3f7c0b8bd3fd14e7d7082f5008dc /examples/boto3/topic_with_endpoint.py | |
parent | Initial commit. (diff) | |
download | ceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.tar.xz ceph-19fcec84d8d7d21e796c7624e521b60d28ee21ed.zip |
Adding upstream version 16.2.11+ds.upstream/16.2.11+dsupstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'examples/boto3/topic_with_endpoint.py')
-rwxr-xr-x | examples/boto3/topic_with_endpoint.py | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/examples/boto3/topic_with_endpoint.py b/examples/boto3/topic_with_endpoint.py new file mode 100755 index 000000000..3137cee7d --- /dev/null +++ b/examples/boto3/topic_with_endpoint.py @@ -0,0 +1,41 @@ +#!/usr/bin/python + +import boto3 +import sys +import urlparse +from botocore.client import Config + +if len(sys.argv) == 3: + # topic name as first argument + topic_name = sys.argv[1] + # region name as second argument + region_name = sys.argv[2] +elif len(sys.argv) == 2: + # topic name as first argument + topic_name = sys.argv[1] + region_name = "" +else: + print('Usage: ' + sys.argv[0] + ' <topic name> [region name]') + sys.exit(1) + +# endpoint and keys from vstart +endpoint = 'http://127.0.0.1:8000' +access_key='0555b35654ad1656d804' +secret_key='h7GhxuBLTrlhVUyxSPUKUV8r/2EI4ngqJxD7iBdBYLhwluN30JaT3Q==' + +client = boto3.client('sns', + endpoint_url=endpoint, + aws_access_key_id=access_key, + region_name=region_name, + aws_secret_access_key=secret_key, + config=Config(signature_version='s3')) + +# to see the list of available "regions" use: +# radosgw-admin realm zonegroup list + +# this is standard AWS services call, using custom attributes to add AMQP endpoint information to the topic + +endpoint_args = 'push-endpoint=amqp://127.0.0.1:5672&amqp-exchange=ex1&amqp-ack-level=broker' +attributes = {nvp[0] : nvp[1] for nvp in urlparse.parse_qsl(endpoint_args, keep_blank_values=True)} + +print(client.create_topic(Name=topic_name, Attributes=attributes)) |