當前位置: 首頁>>代碼示例>>Python>>正文


Python types.ObjectDoesNotExistError方法代碼示例

本文整理匯總了Python中libcloud.storage.types.ObjectDoesNotExistError方法的典型用法代碼示例。如果您正苦於以下問題:Python types.ObjectDoesNotExistError方法的具體用法?Python types.ObjectDoesNotExistError怎麽用?Python types.ObjectDoesNotExistError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在libcloud.storage.types的用法示例。


在下文中一共展示了types.ObjectDoesNotExistError方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _download_bytes

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def _download_bytes(self, container, object_name, missing=None):
        tempdir = tempfile.mkdtemp()
        tempfilepath = os.path.join(
            tempdir, '_tmp_wheelhouse_uploader_download_' + object_name)
        try:
            container.get_object(object_name).download(tempfilepath)
            with open(tempfilepath, 'rb') as f:
                return f.read()
        except ObjectDoesNotExistError:
            return missing
        finally:
            try:
                shutil.rmtree(tempdir)
            except OSError:
                # Ignore permission errors on temporary directories
                print("WARNING: faile to delete", tempdir) 
開發者ID:ogrisel,項目名稱:wheelhouse-uploader,代碼行數:18,代碼來源:upload.py

示例2: test_cloud_master_key_store_s3

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def test_cloud_master_key_store_s3(request, tmpdir):
    try:
        access_key = request.config.getoption('--aws-access-key')
        secret_key = request.config.getoption('--aws-secret-key')
        bucket_name = request.config.getoption('--aws-s3-bucket')
    except ValueError:
        access_key = secret_key = bucket_name = None
    if access_key is None or secret_key is None or bucket_name is None:
        skip(
            '--aws-access-key/--aws-secret-key/--aws-s3-bucket are not '
            'provided; skipped'
        )
    driver_cls = get_driver(Provider.S3)
    driver = driver_cls(access_key, secret_key)
    container = driver.get_container(container_name=bucket_name)
    tmpname = ''.join(map('{:02x}'.format, os.urandom(16)))
    s = CloudMasterKeyStore(driver, container, tmpname)
    key = RSAKey.generate(1024)
    # load() -- when not exists
    with raises(EmptyStoreError):
        s.load()
    try:
        # save()
        s.save(key)
        obj = driver.get_object(container.name, tmpname)
        dest = tmpdir / tmpname
        obj.download(str(dest))
        saved = read_private_key_file(dest.open())
        assert isinstance(saved, RSAKey)
        assert saved.get_base64() == key.get_base64()
        # load() -- when exists
        loaded = s.load()
        assert isinstance(loaded, RSAKey)
        assert loaded.get_base64() == key.get_base64()
    finally:
        try:
            o = driver.get_object(container.name, tmpname)
        except ObjectDoesNotExistError:
            pass
        else:
            o.delete() 
開發者ID:spoqa,項目名稱:geofront,代碼行數:43,代碼來源:cloud_test.py

示例3: load

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def load(self) -> PKey:
        try:
            obj = self.driver.get_object(self.container.name, self.object_name)
        except ObjectDoesNotExistError:
            raise EmptyStoreError()
        with io.BytesIO() as buffer_:
            for chunk in self.driver.download_object_as_stream(obj):
                if isinstance(chunk, str):  # DummyDriver yields str, not bytes
                    chunk = chunk.encode()
                buffer_.write(chunk)
            buffer_.seek(0)
            with io.TextIOWrapper(buffer_) as tio:
                return read_private_key_file(tio) 
開發者ID:spoqa,項目名稱:geofront,代碼行數:15,代碼來源:cloud.py

示例4: __download_blob

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def __download_blob(connection, src, dest, bucket_name):
    """
    This function is called by StorageJob. It may be called concurrently by multiple threads.

    :param connection: A storage connection which is created and managed by StorageJob
    :param src: The file to download
    :param dest: The path to where the file should be downloaded
    :param bucket_name: The name of the bucket from which the file will be downloaded
    :return:
    """
    try:
        logging.debug("[Storage] Getting object {}".format(src))
        blob = connection.get_object(bucket_name, str(src))
        # we must make sure the blob gets stored under sub-folder (if there is any)
        # the dest variable only points to the table folder, so we need to add the sub-folder
        src_path = pathlib.Path(src)
        blob_dest = '{}/{}'.format(dest, src_path.parent.name) if src_path.parent.name.startswith('.') else dest
        index = blob.name.rfind("/")
        if index > 0:
            file_name = blob.name[blob.name.rfind("/") + 1:]
        else:
            file_name = blob.name

        with open("{}/{}".format(blob_dest, file_name), "wb") as file_handle:
            for chunk in blob.as_stream():
                file_handle.write(chunk)
    except ObjectDoesNotExistError:
        return None 
開發者ID:thelastpickle,項目名稱:cassandra-medusa,代碼行數:30,代碼來源:concurrent.py

示例5: __download_blob

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def __download_blob(storage, connection, src, dest, bucket, multi_part_upload_threshold):
    """
    This function is called by StorageJob. It may be called concurrently by multiple threads.

    :param connection: A storage connection which is created and managed by StorageJob
    :param src: The file to download
    :param dest: The path to where the file should be downloaded
    :param bucket: Bucket from which the file will be downloaded
    :return:
    """
    try:
        logging.debug("[Storage] Getting object {}".format(src))
        blob = connection.get_object(bucket.name, str(src))

        # we must make sure the blob gets stored under sub-folder (if there is any)
        # the dest variable only points to the table folder, so we need to add the sub-folder
        src_path = pathlib.Path(src)
        blob_dest = (
            "{}/{}".format(dest, src_path.parent.name)
            if src_path.parent.name.startswith(".")
            else dest
        )

        if int(blob.size) >= multi_part_upload_threshold:
            # Files larger than the configured threshold should be uploaded as multi part
            logging.debug("Downloading {} as multi part".format(blob_dest))
            _download_multi_part(storage, connection, src_path, bucket, blob_dest)
        else:
            logging.debug("Downloading {} as single part".format(blob_dest))
            _download_single_part(connection, blob, blob_dest)

    except ObjectDoesNotExistError:
        return None 
開發者ID:thelastpickle,項目名稱:cassandra-medusa,代碼行數:35,代碼來源:concurrent.py

示例6: get_blob

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def get_blob(self, path):
        try:
            logging.debug("[Storage] Getting object {}".format(path))
            return self.driver.get_object(self.bucket.name, str(path))
        except ObjectDoesNotExistError:
            return None 
開發者ID:thelastpickle,項目名稱:cassandra-medusa,代碼行數:8,代碼來源:abstract_storage.py

示例7: upload_file

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def upload_file(self, filepath, container_name):
        # drivers are not thread safe, hence we create one per upload task
        # to make it possible to use a thread pool executor
        driver = self.make_driver()
        filename = os.path.basename(filepath)
        container = driver.get_container(container_name)

        size_mb = os.stat(filepath).st_size / 1e6
        print("Uploading %s [%0.3f MB]" % (filepath, size_mb))
        driver.upload_object(file_path=filepath,
                             container=container,
                             object_name=filename)

        if self.delete_previous_dev_packages:
            existing_filenames = self._get_package_filenames(driver, container)
            if filename not in existing_filenames:
                # Eventual consistency listing might cause the just uploaded
                # file not be missing. Ensure this is never the case.
                existing_filenames.append(filename)
            previous_dev_filenames = matching_dev_filenames(filename,
                                                            existing_filenames)

            # Only keep the last 5 dev builds
            for filename in previous_dev_filenames[5:]:
                print("Deleting old dev package %s" % filename)
                try:
                    obj = container.get_object(filename)
                    driver.delete_object(obj)
                except ObjectDoesNotExistError:
                    pass 
開發者ID:ogrisel,項目名稱:wheelhouse-uploader,代碼行數:32,代碼來源:upload.py

示例8: _get_object

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def _get_object(self, name):
        """Get object by its name. Return None if object not found"""
        clean_name = self._clean_name(name)
        try:
            return self.driver.get_object(self.bucket, clean_name)
        except ObjectDoesNotExistError:
            return None 
開發者ID:jschneier,項目名稱:django-storages,代碼行數:9,代碼來源:apache_libcloud.py

示例9: __contains__

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def __contains__(self, object_name):
        """
        ie: `if name in storage` or `if name not in storage`
        Test if object exists
        :param object_name: the object name
        :return bool:
        """
        try:
            self.driver.get_object(self.container.name, object_name)
            return True
        except ObjectDoesNotExistError:
            return False 
開發者ID:mardix,項目名稱:flask-cloudy,代碼行數:14,代碼來源:flask_cloudy.py

示例10: get

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def get(self, request, *args, **kwargs):
        try:
            project_id = request.query_params['project_id']
            file_format = request.query_params['upload_format']
            cloud_container = request.query_params['container']
            cloud_object = request.query_params['object']
        except KeyError as ex:
            raise ValidationError('query parameter {} is missing'.format(ex))

        try:
            cloud_file = self.get_cloud_object_as_io(cloud_container, cloud_object)
        except ContainerDoesNotExistError:
            raise ValidationError('cloud container {} does not exist'.format(cloud_container))
        except ObjectDoesNotExistError:
            raise ValidationError('cloud object {} does not exist'.format(cloud_object))

        TextUploadAPI.save_file(
            user=request.user,
            file=cloud_file,
            file_format=file_format,
            project_id=project_id,
        )

        next_url = request.query_params.get('next')

        if next_url == 'about:blank':
            return Response(data='', content_type='text/plain', status=status.HTTP_201_CREATED)

        if next_url:
            return redirect(next_url)

        return Response(status=status.HTTP_201_CREATED) 
開發者ID:doccano,項目名稱:doccano,代碼行數:34,代碼來源:views.py

示例11: test_malicious_local_get_blob

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def test_malicious_local_get_blob(self):
        with self.assertRaises(ObjectDoesNotExistError):
            blob = storage.get_blob(obj_name='../README.md')

        with self.assertRaises(ObjectDoesNotExistError):
            blob = storage.get_blob(obj_name='/bin/bash')

        with self.assertRaises(ObjectDoesNotExistError):
            blob = storage.get_blob(obj_name='foobar.txt') 
開發者ID:okpy,項目名稱:ok,代碼行數:11,代碼來源:test_files.py

示例12: delete_silently

# 需要導入模塊: from libcloud.storage import types [as 別名]
# 或者: from libcloud.storage.types import ObjectDoesNotExistError [as 別名]
def delete_silently(blob):
    try:
        blob.delete()
    except (ObjectDoesNotExistError, OSError):
        pass 
開發者ID:okpy,項目名稱:ok,代碼行數:7,代碼來源:test_files.py


注:本文中的libcloud.storage.types.ObjectDoesNotExistError方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。