
Using the --debug flag or the GLANCECLIENT_DEBUG env var, a user will see http requests and responses in great detail. Requests are formed into proper curl commands while responses are printed just as they would as if the curl request provided were executed. Response bodies will not be printed if they are application/octet-stream. Change-Id: I9c9c5d6ec9f481091c944e596d073da3739795b6
43 lines
1.6 KiB
Python
43 lines
1.6 KiB
Python
# Copyright 2012 OpenStack LLC.
|
|
# All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
import warlock
|
|
|
|
from glanceclient.common import http
|
|
from glanceclient.v2 import images
|
|
from glanceclient.v2 import schemas
|
|
|
|
|
|
class Client(object):
|
|
"""Client for the OpenStack Images v2 API.
|
|
|
|
:param string endpoint: A user-supplied endpoint URL for the glance
|
|
service.
|
|
:param string token: Token for authentication.
|
|
:param integer timeout: Allows customization of the timeout for client
|
|
http requests. (optional)
|
|
"""
|
|
|
|
def __init__(self, endpoint, token=None, timeout=600, **kwargs):
|
|
self.http_client = http.HTTPClient(
|
|
endpoint, token=token, timeout=timeout)
|
|
self.schemas = schemas.Controller(self.http_client)
|
|
self.images = images.Controller(self.http_client,
|
|
self._get_image_model())
|
|
|
|
def _get_image_model(self):
|
|
schema = self.schemas.get('image')
|
|
return warlock.model_factory(schema.raw())
|