diff options
| author | Jenkins <jenkins@review.openstack.org> | 2014-09-18 07:26:27 +0000 |
|---|---|---|
| committer | Gerrit Code Review <review@openstack.org> | 2014-09-18 07:26:27 +0000 |
| commit | 0ad4c94b6c8513a5a79b7a1693c12cdc03b9c897 (patch) | |
| tree | 4c0afc38ef8cdfeffaf6c46eb21be46ceec81ada /openstackclient/object/v1/lib | |
| parent | ccc2fbd95876008330ae3a3e4b6a59c70569f99a (diff) | |
| parent | e47787e12f4ed6f1568527bbc1218fe3edb412e0 (diff) | |
| download | python-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.py | 26 |
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, |
