Merge "Added bulk_delete method to client."
This commit is contained in:
commit
7ae4bca82d
@ -360,6 +360,48 @@ class ObjectStorageAPI_Behaviors(BaseBehavior):
|
|||||||
|
|
||||||
return response
|
return response
|
||||||
|
|
||||||
|
@behavior(ObjectStorageAPIClient)
|
||||||
|
def get_object_count(self, container_name, headers=None, params=None,
|
||||||
|
expected_object_count=None, requestslib_kwargs=None):
|
||||||
|
"""
|
||||||
|
Get the number of objects in a container. This method allows for a
|
||||||
|
success function to be provided, ensuring that the system has
|
||||||
|
stabilized and become consistent.
|
||||||
|
|
||||||
|
@param container_name: container to list the object from.
|
||||||
|
@type container_name: string
|
||||||
|
@param headers: headers to be added to the HTTP request.
|
||||||
|
@type headers: dictionary
|
||||||
|
@param params: query string parameters to be added to the HTTP request.
|
||||||
|
@type params: dictionary
|
||||||
|
@param expected_object_count: object names expected to be in the
|
||||||
|
container listing.
|
||||||
|
@type expected_object_count: int
|
||||||
|
@param requestslib_kwargs: keyword arguments to be passed on to
|
||||||
|
python requests.
|
||||||
|
@type requestslib_kwargs: dictionary
|
||||||
|
|
||||||
|
@return: object listing
|
||||||
|
@rtype: int
|
||||||
|
"""
|
||||||
|
|
||||||
|
def success_func(response):
|
||||||
|
object_count = response.headers.get('x-container-object-count')
|
||||||
|
if not response.ok or object_count is None:
|
||||||
|
return False
|
||||||
|
if expected_object_count != object_count:
|
||||||
|
return False
|
||||||
|
return True
|
||||||
|
|
||||||
|
response = self.retry_until_success(
|
||||||
|
self.client.get_container_metadata,
|
||||||
|
func_args=[container_name],
|
||||||
|
func_kwargs={'requestslib_kwargs': requestslib_kwargs},
|
||||||
|
success_func=success_func,
|
||||||
|
timeout=self.config.list_timeout)
|
||||||
|
|
||||||
|
return int(response.headers.get('x-container-object-count'))
|
||||||
|
|
||||||
@behavior(ObjectStorageAPIClient)
|
@behavior(ObjectStorageAPIClient)
|
||||||
def list_objects(self, container_name, headers=None, params=None,
|
def list_objects(self, container_name, headers=None, params=None,
|
||||||
expected_objects=None, requestslib_kwargs=None):
|
expected_objects=None, requestslib_kwargs=None):
|
||||||
|
@ -16,6 +16,7 @@ limitations under the License.
|
|||||||
import hmac
|
import hmac
|
||||||
import requests
|
import requests
|
||||||
import tarfile
|
import tarfile
|
||||||
|
import urllib
|
||||||
from cStringIO import StringIO
|
from cStringIO import StringIO
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from hashlib import sha1
|
from hashlib import sha1
|
||||||
@ -368,19 +369,6 @@ class ObjectStorageAPIClient(HTTPClient):
|
|||||||
|
|
||||||
return response
|
return response
|
||||||
|
|
||||||
def get_object_count(self, container_name,
|
|
||||||
requestslib_kwargs=None):
|
|
||||||
"""
|
|
||||||
Returns the number of objects in a container.
|
|
||||||
"""
|
|
||||||
response = self.get_container_metadata(
|
|
||||||
container_name,
|
|
||||||
requestslib_kwargs=requestslib_kwargs)
|
|
||||||
|
|
||||||
obj_count = int(response.headers.get('x-container-object-count'))
|
|
||||||
|
|
||||||
return obj_count
|
|
||||||
|
|
||||||
#Storage Object------------------------------------------------------------
|
#Storage Object------------------------------------------------------------
|
||||||
|
|
||||||
def get_object(self, container_name, object_name, headers=None,
|
def get_object(self, container_name, object_name, headers=None,
|
||||||
@ -746,3 +734,29 @@ class ObjectStorageAPIClient(HTTPClient):
|
|||||||
archive_name)
|
archive_name)
|
||||||
|
|
||||||
return archive_path
|
return archive_path
|
||||||
|
|
||||||
|
def bulk_delete(self, targets, headers=None, requestslib_kwargs=None):
|
||||||
|
"""
|
||||||
|
Deletes container/objects from an account.
|
||||||
|
|
||||||
|
@type targets: list of strings
|
||||||
|
@param targets: A list of the '/container/object' or '/container'
|
||||||
|
to be bulk deleted. Note, bulk delete will not remove
|
||||||
|
containers that have objects in them, and there is limit of
|
||||||
|
1000 containers/objects per delete.
|
||||||
|
|
||||||
|
@rtype: object
|
||||||
|
@return: The requests response object returned from the call.
|
||||||
|
"""
|
||||||
|
if not headers:
|
||||||
|
headers = {}
|
||||||
|
url = '{0}{1}'.format(self.storage_url, '?bulk-delete')
|
||||||
|
data = '\n'.join([urllib.quote(target) for target in targets])
|
||||||
|
headers['content-type'] = 'text/plain'
|
||||||
|
headers['content-length'] = str(len(data))
|
||||||
|
|
||||||
|
response = self.request(
|
||||||
|
'DELETE', url, data=data, headers=headers,
|
||||||
|
requestslib_kwargs=requestslib_kwargs)
|
||||||
|
|
||||||
|
return response
|
||||||
|
@ -216,3 +216,10 @@ class ObjectStorageAPIConfig(ConfigSectionInterface):
|
|||||||
CORS works more strictly according to the spec.
|
CORS works more strictly according to the spec.
|
||||||
"""
|
"""
|
||||||
return self.get_boolean('strict_cors_mode', True)
|
return self.get_boolean('strict_cors_mode', True)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def bulk_delete_max_count(self):
|
||||||
|
"""
|
||||||
|
The max number of objects bulk delete can delete.
|
||||||
|
"""
|
||||||
|
return int(self.get('bulk_delete_max_count', 1000))
|
||||||
|
@ -50,6 +50,9 @@ username=test:tester
|
|||||||
# but there may be some test cases which warrant ignoring this value.
|
# but there may be some test cases which warrant ignoring this value.
|
||||||
# base_container_name =
|
# base_container_name =
|
||||||
#
|
#
|
||||||
|
# The max number of objects bulk delete can delete.
|
||||||
|
# bulk_delete_max_count = 1000
|
||||||
|
#
|
||||||
# Max object count for a container listing.
|
# Max object count for a container listing.
|
||||||
# container_listing_limit = 10000
|
# container_listing_limit = 10000
|
||||||
#
|
#
|
||||||
|
Loading…
Reference in New Issue
Block a user