summaryrefslogtreecommitdiff
path: root/openstackclient/object/v1/lib
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2014-09-18 07:26:27 +0000
committerGerrit Code Review <review@openstack.org>2014-09-18 07:26:27 +0000
commit0ad4c94b6c8513a5a79b7a1693c12cdc03b9c897 (patch)
tree4c0afc38ef8cdfeffaf6c46eb21be46ceec81ada /openstackclient/object/v1/lib
parentccc2fbd95876008330ae3a3e4b6a59c70569f99a (diff)
parente47787e12f4ed6f1568527bbc1218fe3edb412e0 (diff)
downloadpython-openstackclient-0ad4c94b6c8513a5a79b7a1693c12cdc03b9c897.tar.gz
Merge "Add preliminary support for downloading objects"
Diffstat (limited to 'openstackclient/object/v1/lib')
-rw-r--r--openstackclient/object/v1/lib/object.py26
1 files changed, 26 insertions, 0 deletions
diff --git a/openstackclient/object/v1/lib/object.py b/openstackclient/object/v1/lib/object.py
index 5000c79d..38b3c14e 100644
--- a/openstackclient/object/v1/lib/object.py
+++ b/openstackclient/object/v1/lib/object.py
@@ -150,6 +150,32 @@ def list_objects(
return session.get(requrl, params=params).json()
+def save_object(
+ session,
+ url,
+ container,
+ obj,
+ file=None
+):
+ """Save an object stored in a container
+
+ :param session: an authenticated keystoneclient.session.Session object
+ :param url: endpoint
+ :param container: name of container that stores object
+ :param object: name of object to save
+ :param file: local name of object
+ """
+
+ if not file:
+ file = obj
+
+ response = session.get("%s/%s/%s" % (url, container, obj), stream=True)
+ if response.status_code == 200:
+ with open(file, 'wb') as f:
+ for chunk in response.iter_content():
+ f.write(chunk)
+
+
def show_object(
session,
url,