# IBM Cloud Object Storage - Python SDK
This package allows Python developers to write software that interacts with [IBM Cloud Object Storage](https://cloud.ibm.com/docs/services/cloud-object-storage/about-cos.html). It is a fork of the [`boto3` library](https://github.com/boto/boto3) and can stand as a drop-in replacement if the application needs to connect to object storage using an S3-like API and does not make use of other AWS services.
## Notice
IBM has added a [Language Support Policy](#language-support-policy). Language versions will be deprecated on the published schedule without additional notice.
## Documentation
* [Core documentation for IBM COS](https://cloud.ibm.com/docs/services/cloud-object-storage/getting-started.html)
* [Python API reference documentation](https://ibm.github.io/ibm-cos-sdk-python)
* [REST API reference documentation](https://cloud.ibm.com/docs/services/cloud-object-storage/api-reference/about-api.html)
For release notes, see the [CHANGELOG](CHANGELOG.md).
* [Building from Source](#building-from-source)
* [Getting Help](#getting-help)
## Quick start
You\'ll need:
* An instance of COS.
* An API key from [IBM Cloud Identity and Access Management](https://cloud.ibm.com/docs/iam/users_roles.html) with at least `Writer` permissions.
* The ID of the instance of COS that you are working with.
* Token acquisition endpoint.
* Service endpoint.
These values can be found in the IBM Cloud Console by [generating a \'service credential\'](https://cloud.ibm.com/docs/cloud-object-storage?topic=cloud-object-storage-service-credentials).
## Using Python
Use of the Python SDK and example code can be found [here](https://cloud.ibm.com/docs/cloud-object-storage?topic=cloud-object-storage-python).
## Using a Service Credential
After generating a Service Credential, the resulting JSON document can be saved to `~/.bluemix/cos_credentials`. The SDK will automatically source credentials from this file unless other credentials are explicitly set during client creation. If the cos_credentials file contains HMAC keys the client authenticates with a signature, otherwise the client uses the provided API key to authenticate by using a bearer token (using an API key still requires the `config=Config(signature_version="oauth")` to be included during client creation).
## Archive Tier Support
You can automatically archive objects after a specified length of time or after a specified date. Once archived, a temporary copy of an object can be restored for access as needed. Restore time may take up to 15 hours.
An archive policy is set at the bucket level by calling the `put_bucket_lifecycle_configuration` method on a client instance. A newly added or modified archive policy applies to new objects uploaded and does not affect existing objects. For more detail, [see the documentation](https://cloud.ibm.com/docs/services/cloud-object-storage/libraries/python.html#python).
## Immutable Object Storage
Users can configure buckets with an Immutable Object Storage policy to prevent objects from being modified or deleted for a defined period of time. The retention period can be specified on a per-object basis, or objects can inherit a default retention period set on the bucket. It is also possible to set open-ended and permanent retention periods. Immutable Object Storage meets the rules set forth by the SEC governing record retention, and IBM Cloud administrators are unable to bypass these restrictions. For more detail, [see the IBM Cloud documentation](https://cloud.ibm.com/docs/services/cloud-object-storage/libraries/python.html#python).
Note: Immutable Object Storage does not support Aspera transfers via the SDK to upload objects or directories at this stage.
## Accelerated Archive
Users can set an archive rule that would allow data restore from an archive in 2 hours or 12 hours.
## LEGACY: Aspera high-speed transfer
Aspera high-speed transfer through the COS SDK using the `cos-aspera` library is now legacy. New users and applications should use the [Aspera Transfer SDK](https://developer.ibm.com/apis/catalog/aspera--aspera-transfer-sdk/Introduction) instead. Existing users should begin new projects with the Aspera Transfer SDK and make plans to migrate existing applications. Users who use S3 for transfers and do not install `cos-aspera` are unaffected.
## Building from source
Assuming that you have Python and `virtualenv` installed, set up your environment and install the required dependencies like this instead of the `pip install ibm-cos-sdk` defined above:
```sh
git clone https://github.com/ibm/ibm-cos-sdk-python.git
cd ibm-cos-sdk-python
$ virtualenv venv
...
. venv/bin/activate
pip install -r requirements.txt
pip install -e .
```
## Getting Help
Feel free to use GitHub issues for tracking bugs and feature requests, but for help please use one of the following resources:
* Read a quick start guide in [IBM Cloud Docs](https://cloud.ibm.com/docs/cloud-object-storage?topic=cloud-object-storage-sdk-gs&code=python).
* Ask a question on [Stack Overflow](https://stackoverflow.com/) and tag it with `ibm` and `object-storage`.
* Open a support ticket with [IBM Cloud Support](https://cloud.ibm.com/unifiedsupport/supportcenter/)
* If it turns out that you may have found a bug, please [open an issue](https://github.com/ibm/ibm-cos-sdk-python/issues/new).
## Language Support Policy
IBM supports [current public releases](https://devguide.python.org/versions/#versions). IBM will deprecate language versions 90 days after a version reaches end-of-life. All clients will need to upgrade to a supported version before the end of the grace period.
## License
This SDK is distributed under the [Apache License, Version 2.0](http://www.apache.org/licenses/LICENSE-2.0), see LICENSE.txt and NOTICE.txt for more information.
Raw data
{
"_id": null,
"home_page": "https://github.com/ibm/ibm-cos-sdk-python",
"name": "ibm-cos-sdk",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": null,
"keywords": null,
"author": "IBM",
"author_email": null,
"download_url": "https://files.pythonhosted.org/packages/7c/78/894063144210ba3299c019ffe42ceb68359be57200b254a2b0d421c2d20c/ibm-cos-sdk-2.14.0.tar.gz",
"platform": null,
"description": "# IBM Cloud Object Storage - Python SDK\n\nThis package allows Python developers to write software that interacts with [IBM Cloud Object Storage](https://cloud.ibm.com/docs/services/cloud-object-storage/about-cos.html). It is a fork of the [`boto3` library](https://github.com/boto/boto3) and can stand as a drop-in replacement if the application needs to connect to object storage using an S3-like API and does not make use of other AWS services.\n\n## Notice\n\nIBM has added a [Language Support Policy](#language-support-policy). Language versions will be deprecated on the published schedule without additional notice.\n\n## Documentation\n\n* [Core documentation for IBM COS](https://cloud.ibm.com/docs/services/cloud-object-storage/getting-started.html)\n* [Python API reference documentation](https://ibm.github.io/ibm-cos-sdk-python)\n* [REST API reference documentation](https://cloud.ibm.com/docs/services/cloud-object-storage/api-reference/about-api.html)\n\nFor release notes, see the [CHANGELOG](CHANGELOG.md).\n\n* [Building from Source](#building-from-source)\n* [Getting Help](#getting-help)\n\n## Quick start\n\nYou\\'ll need:\n\n* An instance of COS.\n* An API key from [IBM Cloud Identity and Access Management](https://cloud.ibm.com/docs/iam/users_roles.html) with at least `Writer` permissions.\n* The ID of the instance of COS that you are working with.\n* Token acquisition endpoint.\n* Service endpoint.\n\nThese values can be found in the IBM Cloud Console by [generating a \\'service credential\\'](https://cloud.ibm.com/docs/cloud-object-storage?topic=cloud-object-storage-service-credentials).\n\n## Using Python\n\nUse of the Python SDK and example code can be found [here](https://cloud.ibm.com/docs/cloud-object-storage?topic=cloud-object-storage-python).\n\n## Using a Service Credential\n\nAfter generating a Service Credential, the resulting JSON document can be saved to `~/.bluemix/cos_credentials`. The SDK will automatically source credentials from this file unless other credentials are explicitly set during client creation. If the cos_credentials file contains HMAC keys the client authenticates with a signature, otherwise the client uses the provided API key to authenticate by using a bearer token (using an API key still requires the `config=Config(signature_version=\"oauth\")` to be included during client creation).\n\n## Archive Tier Support\n\nYou can automatically archive objects after a specified length of time or after a specified date. Once archived, a temporary copy of an object can be restored for access as needed. Restore time may take up to 15 hours.\n\nAn archive policy is set at the bucket level by calling the `put_bucket_lifecycle_configuration` method on a client instance. A newly added or modified archive policy applies to new objects uploaded and does not affect existing objects. For more detail, [see the documentation](https://cloud.ibm.com/docs/services/cloud-object-storage/libraries/python.html#python).\n\n## Immutable Object Storage\n\nUsers can configure buckets with an Immutable Object Storage policy to prevent objects from being modified or deleted for a defined period of time. The retention period can be specified on a per-object basis, or objects can inherit a default retention period set on the bucket. It is also possible to set open-ended and permanent retention periods. Immutable Object Storage meets the rules set forth by the SEC governing record retention, and IBM Cloud administrators are unable to bypass these restrictions. For more detail, [see the IBM Cloud documentation](https://cloud.ibm.com/docs/services/cloud-object-storage/libraries/python.html#python).\n\nNote: Immutable Object Storage does not support Aspera transfers via the SDK to upload objects or directories at this stage.\n\n## Accelerated Archive\n\nUsers can set an archive rule that would allow data restore from an archive in 2 hours or 12 hours.\n\n## LEGACY: Aspera high-speed transfer\n\nAspera high-speed transfer through the COS SDK using the `cos-aspera` library is now legacy. New users and applications should use the [Aspera Transfer SDK](https://developer.ibm.com/apis/catalog/aspera--aspera-transfer-sdk/Introduction) instead. Existing users should begin new projects with the Aspera Transfer SDK and make plans to migrate existing applications. Users who use S3 for transfers and do not install `cos-aspera` are unaffected.\n\n## Building from source\n\nAssuming that you have Python and `virtualenv` installed, set up your environment and install the required dependencies like this instead of the `pip install ibm-cos-sdk` defined above:\n\n```sh\ngit clone https://github.com/ibm/ibm-cos-sdk-python.git\ncd ibm-cos-sdk-python\n$ virtualenv venv\n...\n. venv/bin/activate\npip install -r requirements.txt\npip install -e .\n```\n\n## Getting Help\n\nFeel free to use GitHub issues for tracking bugs and feature requests, but for help please use one of the following resources:\n\n* Read a quick start guide in [IBM Cloud Docs](https://cloud.ibm.com/docs/cloud-object-storage?topic=cloud-object-storage-sdk-gs&code=python).\n* Ask a question on [Stack Overflow](https://stackoverflow.com/) and tag it with `ibm` and `object-storage`.\n* Open a support ticket with [IBM Cloud Support](https://cloud.ibm.com/unifiedsupport/supportcenter/)\n* If it turns out that you may have found a bug, please [open an issue](https://github.com/ibm/ibm-cos-sdk-python/issues/new).\n\n## Language Support Policy\n\nIBM supports [current public releases](https://devguide.python.org/versions/#versions). IBM will deprecate language versions 90 days after a version reaches end-of-life. All clients will need to upgrade to a supported version before the end of the grace period.\n\n## License\n\nThis SDK is distributed under the [Apache License, Version 2.0](http://www.apache.org/licenses/LICENSE-2.0), see LICENSE.txt and NOTICE.txt for more information.\n\n\n",
"bugtrack_url": null,
"license": "Apache License 2.0",
"summary": "IBM SDK for Python",
"version": "2.14.0",
"project_urls": {
"Documentation": "https://cloud.ibm.com/docs/cloud-object-storage?topic=cloud-object-storage-python",
"Homepage": "https://github.com/ibm/ibm-cos-sdk-python",
"Source": "https://github.com/IBM/ibm-cos-sdk-python"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "7c78894063144210ba3299c019ffe42ceb68359be57200b254a2b0d421c2d20c",
"md5": "b3ca92e0484b28c0b64a34ea95c59b7f",
"sha256": "732fb5cdf6cc58f954bd78612d317187cd36dff48801b0b937a81df3ece2c4be"
},
"downloads": -1,
"filename": "ibm-cos-sdk-2.14.0.tar.gz",
"has_sig": false,
"md5_digest": "b3ca92e0484b28c0b64a34ea95c59b7f",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 58621,
"upload_time": "2024-12-03T10:00:31",
"upload_time_iso_8601": "2024-12-03T10:00:31.897939Z",
"url": "https://files.pythonhosted.org/packages/7c/78/894063144210ba3299c019ffe42ceb68359be57200b254a2b0d421c2d20c/ibm-cos-sdk-2.14.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-03 10:00:31",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "ibm",
"github_project": "ibm-cos-sdk-python",
"travis_ci": false,
"coveralls": true,
"github_actions": false,
"requirements": [],
"tox": true,
"lcname": "ibm-cos-sdk"
}