aiosalesforce


Nameaiosalesforce JSON
Version 0.6.2 PyPI version JSON
download
home_pageNone
SummarySalesforce REST API client
upload_time2024-06-06 19:14:20
maintainerNone
docs_urlNone
authorNone
requires_python>=3.11
licenseCopyright 2024 Georgii Bocharov Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
keywords rest api asyncio salesforce
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <p align="center" style="font-size:40px; margin:0px 10px 0px 10px">
    <em>⚡ aiosalesforce ⚡</em>
</p>
<p align="center">
    <em>Asynchronous Python client for Salesforce APIs</em>
</p>
<p align="center">
<a href="https://github.com/georgebv/aiosalesforce/actions/workflows/test.yml" target="_blank">
    <img src="https://github.com/georgebv/aiosalesforce/actions/workflows/test.yml/badge.svg?event=pull_request" alt="Test">
</a>
<a href="https://codecov.io/gh/georgebv/aiosalesforce" target="_blank">
    <img src="https://codecov.io/gh/georgebv/aiosalesforce/graph/badge.svg?token=KVMS7YVODO" alt="Coverage"/>
</a>
<a href="https://pypi.org/project/aiosalesforce" target="_blank">
    <img src="https://badge.fury.io/py/aiosalesforce.svg" alt="PyPI Package">
</a>
</p>

**Documentation:** https://georgebv.github.io/aiosalesforce

**License:** [MIT](https://opensource.org/licenses/MIT)

**Support:** [ask a question](https://github.com/georgebv/aiosalesforce/discussions)
or [create an issue](https://github.com/georgebv/aiosalesforce/issues/new/choose),
any input is appreciated and would help develop the project

# About

`aiosalesforce` is a modern, production-ready asynchronous Python client
for Salesforce APIs.
It is built on top of the `httpx` library and provides a simple and intuitive API
for interacting with Salesforce's APIs (such as REST and Bulk).

- **Fast:** designed from the ground up to be fully asynchronous :rocket:
- **Resilient:** flexible and robust retrying configuration :gear:
- **Fully typed:** every part of the library is fully typed and annotated :label:
- **Intuitive:** API follows naming conventions of Salesforce's APIs while
  staying idiomatic to Python :snake:
- **Salesforce first:** built with years of experience working with the Salesforce API
  it is configured to work out of the box and incorporates best practices and
  latest Salesforce API features :cloud:
- **Track your API usage:** built-in support for tracking Salesforce API usage
  :chart_with_upwards_trend:

Supported APIs:

| API                 | Status | Description                              |
| ------------------- | ------ | ---------------------------------------- |
| SOQL Query          | ✅     | Execute SOQL queries                     |
| sObject             | ✅     | CRUD operations on Salesforce objects    |
| Composite Batch     | ✅     | Execute multiple independent subrequests |
| Composite           | ✅     | Execute multiple dependent subrequests   |
| Composite Graph     | 🕒     | Execute multiple composite graphs        |
| sObject Tree        | 🕒     | Create one or more sObject trees         |
| sObject Collections | 🕒     | Execute multiple sObject operations      |
| Bulk API 1.0        | ❌     | Not planned (use Bulk API 2.0)           |
| Bulk API 2.0        | ✅     | Bulk ingest and query operations         |

## Requirements

`aiosalesforce` depends on:

- Python 3.11+
- [httpx](https://github.com/encode/httpx)
- [orjson](https://github.com/ijl/orjson)

Optional dependencies:

- [PyJWT](https://github.com/jpadilla/pyjwt)
- [cryptography](https://github.com/pyca/cryptography)

## Installation

```shell
pip install aiosalesforce
```

To use the JWT Bearer Flow authentication install with the `jwt` extra:

```shell
pip install aiosalesforce[jwt]
```

# Demo

Example below shows how to:

- Authenticate against Salesforce using the SOAP login method
- Create a Salesforce client
- Create a new Contact
- Read a Contact by ID
- Execute a SOQL query

```python
import asyncio

from aiosalesforce import Salesforce
from aiosalesforce.auth import SoapLogin
from httpx import AsyncClient

# Reuse authentication session across multiple clients (refreshes automatically)
auth = SoapLogin(
    username="your-username",
    password="your-password",
    security_token="your-security-token",
)

async def main():
    async with AsyncClient() as client:
        # Create a Salesforce client
        salesforce = Salesforce(
            client,
            base_url="https://your-instance.my.salesforce.com",
            auth=auth,
        )

        # Create a new Contact
        contact_id = await salesforce.sobject.create(
            "Contact",
            {
                "FirstName": "John",
                "LastName": "Doe",
                "Email": "john.doe@example.com",
            },
        )
        print(f"Created Contact with ID: {contact_id}")

        # Read Contact by ID
        contact = await salesforce.sobject.get("Contact", contact_id)
        print(contact)

        # Execute a SOQL query
        async for record in salesforce.query("SELECT Id, Name FROM Contact"):
            print(record)


if __name__ == "__main__":
    asyncio.run(main())
```

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "aiosalesforce",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.11",
    "maintainer_email": null,
    "keywords": "REST API, asyncio, salesforce",
    "author": null,
    "author_email": "Georgii Bocharov <bocharovgeorgii@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/7d/59/7b35b620dae5b70fd2893beedaca003005a3663948785dd6824cb3e1c8b9/aiosalesforce-0.6.2.tar.gz",
    "platform": null,
    "description": "<p align=\"center\" style=\"font-size:40px; margin:0px 10px 0px 10px\">\n    <em>\u26a1 aiosalesforce \u26a1</em>\n</p>\n<p align=\"center\">\n    <em>Asynchronous Python client for Salesforce APIs</em>\n</p>\n<p align=\"center\">\n<a href=\"https://github.com/georgebv/aiosalesforce/actions/workflows/test.yml\" target=\"_blank\">\n    <img src=\"https://github.com/georgebv/aiosalesforce/actions/workflows/test.yml/badge.svg?event=pull_request\" alt=\"Test\">\n</a>\n<a href=\"https://codecov.io/gh/georgebv/aiosalesforce\" target=\"_blank\">\n    <img src=\"https://codecov.io/gh/georgebv/aiosalesforce/graph/badge.svg?token=KVMS7YVODO\" alt=\"Coverage\"/>\n</a>\n<a href=\"https://pypi.org/project/aiosalesforce\" target=\"_blank\">\n    <img src=\"https://badge.fury.io/py/aiosalesforce.svg\" alt=\"PyPI Package\">\n</a>\n</p>\n\n**Documentation:** https://georgebv.github.io/aiosalesforce\n\n**License:** [MIT](https://opensource.org/licenses/MIT)\n\n**Support:** [ask a question](https://github.com/georgebv/aiosalesforce/discussions)\nor [create an issue](https://github.com/georgebv/aiosalesforce/issues/new/choose),\nany input is appreciated and would help develop the project\n\n# About\n\n`aiosalesforce` is a modern, production-ready asynchronous Python client\nfor Salesforce APIs.\nIt is built on top of the `httpx` library and provides a simple and intuitive API\nfor interacting with Salesforce's APIs (such as REST and Bulk).\n\n- **Fast:** designed from the ground up to be fully asynchronous :rocket:\n- **Resilient:** flexible and robust retrying configuration :gear:\n- **Fully typed:** every part of the library is fully typed and annotated :label:\n- **Intuitive:** API follows naming conventions of Salesforce's APIs while\n  staying idiomatic to Python :snake:\n- **Salesforce first:** built with years of experience working with the Salesforce API\n  it is configured to work out of the box and incorporates best practices and\n  latest Salesforce API features :cloud:\n- **Track your API usage:** built-in support for tracking Salesforce API usage\n  :chart_with_upwards_trend:\n\nSupported APIs:\n\n| API                 | Status | Description                              |\n| ------------------- | ------ | ---------------------------------------- |\n| SOQL Query          | \u2705     | Execute SOQL queries                     |\n| sObject             | \u2705     | CRUD operations on Salesforce objects    |\n| Composite Batch     | \u2705     | Execute multiple independent subrequests |\n| Composite           | \u2705     | Execute multiple dependent subrequests   |\n| Composite Graph     | \ud83d\udd52     | Execute multiple composite graphs        |\n| sObject Tree        | \ud83d\udd52     | Create one or more sObject trees         |\n| sObject Collections | \ud83d\udd52     | Execute multiple sObject operations      |\n| Bulk API 1.0        | \u274c     | Not planned (use Bulk API 2.0)           |\n| Bulk API 2.0        | \u2705     | Bulk ingest and query operations         |\n\n## Requirements\n\n`aiosalesforce` depends on:\n\n- Python 3.11+\n- [httpx](https://github.com/encode/httpx)\n- [orjson](https://github.com/ijl/orjson)\n\nOptional dependencies:\n\n- [PyJWT](https://github.com/jpadilla/pyjwt)\n- [cryptography](https://github.com/pyca/cryptography)\n\n## Installation\n\n```shell\npip install aiosalesforce\n```\n\nTo use the JWT Bearer Flow authentication install with the `jwt` extra:\n\n```shell\npip install aiosalesforce[jwt]\n```\n\n# Demo\n\nExample below shows how to:\n\n- Authenticate against Salesforce using the SOAP login method\n- Create a Salesforce client\n- Create a new Contact\n- Read a Contact by ID\n- Execute a SOQL query\n\n```python\nimport asyncio\n\nfrom aiosalesforce import Salesforce\nfrom aiosalesforce.auth import SoapLogin\nfrom httpx import AsyncClient\n\n# Reuse authentication session across multiple clients (refreshes automatically)\nauth = SoapLogin(\n    username=\"your-username\",\n    password=\"your-password\",\n    security_token=\"your-security-token\",\n)\n\nasync def main():\n    async with AsyncClient() as client:\n        # Create a Salesforce client\n        salesforce = Salesforce(\n            client,\n            base_url=\"https://your-instance.my.salesforce.com\",\n            auth=auth,\n        )\n\n        # Create a new Contact\n        contact_id = await salesforce.sobject.create(\n            \"Contact\",\n            {\n                \"FirstName\": \"John\",\n                \"LastName\": \"Doe\",\n                \"Email\": \"john.doe@example.com\",\n            },\n        )\n        print(f\"Created Contact with ID: {contact_id}\")\n\n        # Read Contact by ID\n        contact = await salesforce.sobject.get(\"Contact\", contact_id)\n        print(contact)\n\n        # Execute a SOQL query\n        async for record in salesforce.query(\"SELECT Id, Name FROM Contact\"):\n            print(record)\n\n\nif __name__ == \"__main__\":\n    asyncio.run(main())\n```\n",
    "bugtrack_url": null,
    "license": "Copyright 2024 Georgii Bocharov  Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \"Software\"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:  The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.  THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.",
    "summary": "Salesforce REST API client",
    "version": "0.6.2",
    "project_urls": {
        "Documentation": "https://github.com/georgebv/aiosalesforce",
        "Homepage": "https://github.com/georgebv/aiosalesforce",
        "Repository": "https://github.com/georgebv/aiosalesforce"
    },
    "split_keywords": [
        "rest api",
        " asyncio",
        " salesforce"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "cf29f50897b3e391126982207abfc7c359fccedd104257121756b324d137d7fc",
                "md5": "24d42f7227a829c36eaa4d82309e0311",
                "sha256": "4a709e2048ae5d4353bb7d5ce4f928da9d82878c497bc460b1254c64adbde5c3"
            },
            "downloads": -1,
            "filename": "aiosalesforce-0.6.2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "24d42f7227a829c36eaa4d82309e0311",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.11",
            "size": 42861,
            "upload_time": "2024-06-06T19:14:18",
            "upload_time_iso_8601": "2024-06-06T19:14:18.336852Z",
            "url": "https://files.pythonhosted.org/packages/cf/29/f50897b3e391126982207abfc7c359fccedd104257121756b324d137d7fc/aiosalesforce-0.6.2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "7d597b35b620dae5b70fd2893beedaca003005a3663948785dd6824cb3e1c8b9",
                "md5": "881600e60c394a48919bb979ab45e993",
                "sha256": "c8e039dc7b2bd535d231269690659eab6f2d4c2d9fc6dfa2ea92dce8e3fc25d3"
            },
            "downloads": -1,
            "filename": "aiosalesforce-0.6.2.tar.gz",
            "has_sig": false,
            "md5_digest": "881600e60c394a48919bb979ab45e993",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.11",
            "size": 28278,
            "upload_time": "2024-06-06T19:14:20",
            "upload_time_iso_8601": "2024-06-06T19:14:20.199473Z",
            "url": "https://files.pythonhosted.org/packages/7d/59/7b35b620dae5b70fd2893beedaca003005a3663948785dd6824cb3e1c8b9/aiosalesforce-0.6.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-06-06 19:14:20",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "georgebv",
    "github_project": "aiosalesforce",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "aiosalesforce"
}
        
Elapsed time: 0.31376s