Source code for ecl.image.v2.member

# 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.

from ecl.image import image_service
from ecl import resource2


[docs]class Member(resource2.Resource): resources_key = 'members' service = image_service.ImageService() base_path = '/' + service.version + '/images/%(image_id)s/members' # Capabilities allow_create = True allow_get = True allow_update = True allow_delete = True allow_list = True # Properties # See https://bugs.launchpad.net/glance/+bug/1526991 for member/member_id # 'member' is documented incorrectly as being deprecated but it's the # only thing that works. 'member_id' is not accepted. #: The ID of the image member. An image member is a tenant #: with whom the image is shared. member_id = resource2.Body('member_id') #: The date and time when the member was created. created_at = resource2.Body('created_at') #: Image ID stored through the image API. Typically a UUID. image_id = resource2.URI('image_id') #: The status of the image. status = resource2.Body('status') #: The URL for schema of the member. schema = resource2.Body('schema') #: The date and time when the member was updated. updated_at = resource2.Body('updated_at') #: Member_id used to create a member member = resource2.Body('member', alternate_id=True)
[docs] def update(self, session, image_id, member_id, status): """Update the member of an image.""" uri = self.base_path + '/%(member_id)s' uri = uri % {"image_id":image_id, "member_id":member_id} resp = session.put( uri, json={"status":status}, headers={"Accept": "application/json"}, endpoint_filter=self.service ) self._translate_response(resp, has_body=True) return self