azure-communication-sms


Nameazure-communication-sms JSON
Version 1.1.0 PyPI version JSON
download
home_pagehttps://github.com/Azure/azure-sdk-for-python
SummaryMicrosoft Azure Communication SMS Client Library for Python
upload_time2024-10-03 14:12:00
maintainerNone
docs_urlNone
authorMicrosoft Corporation
requires_python>=3.8
licenseMIT License
keywords azure azure sdk
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage
            # Azure Communication SMS Package client library for Python

This package contains a Python SDK for Azure Communication Services for SMS.
Read more about Azure Communication Services [here](https://docs.microsoft.com/azure/communication-services/overview)

[Source code](https://github.com/Azure/azure-sdk-for-python/blob/main/sdk/communication/azure-communication-sms)
| [Package (Pypi)](https://pypi.org/project/azure-communication-sms/)
| [Package (Conda)](https://anaconda.org/microsoft/azure-communication/)
| [API reference documentation](https://github.com/Azure/azure-sdk-for-python/blob/main/sdk/communication/azure-communication-sms)
| [Product documentation](https://docs.microsoft.com/azure/communication-services/quickstarts/telephony-sms/send?pivots=programming-language-python)

## _Disclaimer_

_Azure SDK Python packages support for Python 2.7 has ended 01 January 2022. For more information and questions, please refer to https://github.com/Azure/azure-sdk-for-python/issues/20691_

## Getting started

### Prerequisites

- Python 3.7 or later is required to use this package.
- A deployed Communication Services resource. You can use the [Azure Portal](https://docs.microsoft.com/azure/communication-services/quickstarts/create-communication-resource?tabs=windows&pivots=platform-azp) or the [Azure PowerShell](https://docs.microsoft.com/powershell/module/az.communication/new-azcommunicationservice) to set it up.
- You must have a phone number configured that is associated with an Azure subscription

### Install the package

Install the Azure Communication SMS client library for Python with [pip](https://pypi.org/project/pip/):

```bash
pip install azure-communication-sms
```

## Key concepts

Azure Communication SMS package is used to do following:
- Send a 1:1 SMS Message
- Send a 1:N SMS Message

## Examples

The following section provides several code snippets covering some of the most common Azure Communication Services tasks, including:

- [Client Initialization](#client-initialization)
- [Send a 1:1 SMS Message](#send-a-11-sms-message)
- [Send a 1:N SMS Message](#send-a-1n-sms-message)

### Client Initialization

To initialize the SMS Client, the connection string can be used to instantiate.
Alternatively, you can also use Active Directory authentication using DefaultAzureCredential.

```python
from azure.communication.sms import SmsClient
from azure.identity import DefaultAzureCredential

connection_str = "endpoint=ENDPOINT;accessKey=KEY"
sms_client = SmsClient.from_connection_string(connection_string)

# To use Azure Active Directory Authentication (DefaultAzureCredential) make sure to have
# AZURE_TENANT_ID, AZURE_CLIENT_ID and AZURE_CLIENT_SECRET as env variables.
endpoint = "https://<RESOURCE_NAME>.communication.azure.com"
sms_client = SmsClient(endpoint, DefaultAzureCredential())
```

### Send a 1:1 SMS Message

Once the client is initialized, the `send` method can be invoked:

```python
from azure.communication.sms import SendSmsOptions

sms_responses = sms_client.send(
    from_="<from-phone-number>",
    to="<to-phone-number-1>",
    message="Hello World via SMS",
    enable_delivery_report=True, # optional property
    tag="custom-tag") # optional property
```

- `from_`: An SMS enabled phone number associated with your communication service.
- `to`: The phone number or list of phone numbers you wish to send a message to.
- `message`: The message that you want to send.
- `enable_delivery_report`: An optional parameter that you can use to configure delivery reporting. This is useful for scenarios where you want to emit events when SMS messages are delivered.
- `tag`: An optional parameter that you can use to configure custom tagging.

### Send a 1:N SMS Message

Once the client is initialized, the `send` method can be invoked:

```python
from azure.communication.sms import SendSmsOptions

sms_responses = sms_client.send(
    from_="<from-phone-number>",
    to=["<to-phone-number-1>", "<to-phone-number-2>", "<to-phone-number-3>"],
    message="Hello World via SMS",
    enable_delivery_report=True, # optional property
    tag="custom-tag") # optional property
```

- `from_`: An SMS enabled phone number associated with your communication service.
- `to`: The phone number or list of phone numbers you wish to send a message to.
- `message`: The message that you want to send.
- `enable_delivery_report`: An optional parameter that you can use to configure delivery reporting. This is useful for scenarios where you want to emit events when SMS messages are delivered.
- `tag`: An optional parameter that you can use to configure custom tagging.


## Troubleshooting
SMS operations will throw an exception if the request to the server fails. The SMS client will raise exceptions defined in [Azure Core](https://github.com/Azure/azure-sdk-for-python/blob/main/sdk/core/azure-core/README.md). Exceptions will not be thrown if the error is caused by an individual message, only if something fails with the overall request. Please use the successful flag to validate each individual result to verify if the message was sent.

```python
try:
    sms_responses = sms_client.send(
        from_="<leased-phone-number>",
        to=["<to-phone-number-1>", "<to-phone-number-2>", "<to-phone-number-3>"],
        message="Hello World via SMS")

    for sms_response in sms_responses:
        if (sms_response.successful):
            print("Message with message id {} was successful sent to {}"
            .format(sms_response.message_id, sms_response.to))
        else:
            print("Message failed to send to {} with the status code {} and error: {}"
            .format(sms_response.to, sms_response.http_status_code, sms_response.error_message))
except Exception as ex:
    print('Exception:')
    print(ex)
```

## Next steps
- [Read more about SMS in Azure Communication Services][next_steps]
- For a basic guide on how to configure Delivery Reporting for your SMS messages please refer to the [Handle SMS Events quickstart][handle_sms_events].

### More sample code

Please take a look at the [samples](https://github.com/Azure/azure-sdk-for-python/tree/main/sdk/communication/azure-communication-sms/samples) directory for detailed examples of how to use this library to send an sms.

## Provide Feedback

If you encounter any bugs or have suggestions, please file an issue in the [Issues](https://github.com/Azure/azure-sdk-for-python/issues) section of the project

## Contributing

This project welcomes contributions and suggestions.  Most contributions require you to agree to a
Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.microsoft.com.

When you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the
PR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

This project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/).
For more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or contact [opencode@microsoft.com](mailto:opencode@microsoft.com) with any additional questions or comments.

<!-- LINKS -->
[azure_core]: https://github.com/Azure/azure-sdk-for-python/blob/main/sdk/core/azure-core/README.md
[handle_sms_events]: https://docs.microsoft.com/azure/communication-services/quickstarts/telephony-sms/handle-sms-events
[next_steps]:https://docs.microsoft.com/azure/communication-services/quickstarts/telephony-sms/send?pivots=programming-language-python

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/Azure/azure-sdk-for-python",
    "name": "azure-communication-sms",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": null,
    "keywords": "azure, azure sdk",
    "author": "Microsoft Corporation",
    "author_email": "azuresdkengsysadmins@microsoft.com",
    "download_url": "https://files.pythonhosted.org/packages/c8/06/78b09956bfc038121f27f905e9a2b18eb206b2e452b5f49e64f5a2b216cc/azure_communication_sms-1.1.0.tar.gz",
    "platform": null,
    "description": "# Azure Communication SMS Package client library for Python\n\nThis package contains a Python SDK for Azure Communication Services for SMS.\nRead more about Azure Communication Services [here](https://docs.microsoft.com/azure/communication-services/overview)\n\n[Source code](https://github.com/Azure/azure-sdk-for-python/blob/main/sdk/communication/azure-communication-sms)\n| [Package (Pypi)](https://pypi.org/project/azure-communication-sms/)\n| [Package (Conda)](https://anaconda.org/microsoft/azure-communication/)\n| [API reference documentation](https://github.com/Azure/azure-sdk-for-python/blob/main/sdk/communication/azure-communication-sms)\n| [Product documentation](https://docs.microsoft.com/azure/communication-services/quickstarts/telephony-sms/send?pivots=programming-language-python)\n\n## _Disclaimer_\n\n_Azure SDK Python packages support for Python 2.7 has ended 01 January 2022. For more information and questions, please refer to https://github.com/Azure/azure-sdk-for-python/issues/20691_\n\n## Getting started\n\n### Prerequisites\n\n- Python 3.7 or later is required to use this package.\n- A deployed Communication Services resource. You can use the [Azure Portal](https://docs.microsoft.com/azure/communication-services/quickstarts/create-communication-resource?tabs=windows&pivots=platform-azp) or the [Azure PowerShell](https://docs.microsoft.com/powershell/module/az.communication/new-azcommunicationservice) to set it up.\n- You must have a phone number configured that is associated with an Azure subscription\n\n### Install the package\n\nInstall the Azure Communication SMS client library for Python with [pip](https://pypi.org/project/pip/):\n\n```bash\npip install azure-communication-sms\n```\n\n## Key concepts\n\nAzure Communication SMS package is used to do following:\n- Send a 1:1 SMS Message\n- Send a 1:N SMS Message\n\n## Examples\n\nThe following section provides several code snippets covering some of the most common Azure Communication Services tasks, including:\n\n- [Client Initialization](#client-initialization)\n- [Send a 1:1 SMS Message](#send-a-11-sms-message)\n- [Send a 1:N SMS Message](#send-a-1n-sms-message)\n\n### Client Initialization\n\nTo initialize the SMS Client, the connection string can be used to instantiate.\nAlternatively, you can also use Active Directory authentication using DefaultAzureCredential.\n\n```python\nfrom azure.communication.sms import SmsClient\nfrom azure.identity import DefaultAzureCredential\n\nconnection_str = \"endpoint=ENDPOINT;accessKey=KEY\"\nsms_client = SmsClient.from_connection_string(connection_string)\n\n# To use Azure Active Directory Authentication (DefaultAzureCredential) make sure to have\n# AZURE_TENANT_ID, AZURE_CLIENT_ID and AZURE_CLIENT_SECRET as env variables.\nendpoint = \"https://<RESOURCE_NAME>.communication.azure.com\"\nsms_client = SmsClient(endpoint, DefaultAzureCredential())\n```\n\n### Send a 1:1 SMS Message\n\nOnce the client is initialized, the `send` method can be invoked:\n\n```python\nfrom azure.communication.sms import SendSmsOptions\n\nsms_responses = sms_client.send(\n    from_=\"<from-phone-number>\",\n    to=\"<to-phone-number-1>\",\n    message=\"Hello World via SMS\",\n    enable_delivery_report=True, # optional property\n    tag=\"custom-tag\") # optional property\n```\n\n- `from_`: An SMS enabled phone number associated with your communication service.\n- `to`: The phone number or list of phone numbers you wish to send a message to.\n- `message`: The message that you want to send.\n- `enable_delivery_report`: An optional parameter that you can use to configure delivery reporting. This is useful for scenarios where you want to emit events when SMS messages are delivered.\n- `tag`: An optional parameter that you can use to configure custom tagging.\n\n### Send a 1:N SMS Message\n\nOnce the client is initialized, the `send` method can be invoked:\n\n```python\nfrom azure.communication.sms import SendSmsOptions\n\nsms_responses = sms_client.send(\n    from_=\"<from-phone-number>\",\n    to=[\"<to-phone-number-1>\", \"<to-phone-number-2>\", \"<to-phone-number-3>\"],\n    message=\"Hello World via SMS\",\n    enable_delivery_report=True, # optional property\n    tag=\"custom-tag\") # optional property\n```\n\n- `from_`: An SMS enabled phone number associated with your communication service.\n- `to`: The phone number or list of phone numbers you wish to send a message to.\n- `message`: The message that you want to send.\n- `enable_delivery_report`: An optional parameter that you can use to configure delivery reporting. This is useful for scenarios where you want to emit events when SMS messages are delivered.\n- `tag`: An optional parameter that you can use to configure custom tagging.\n\n\n## Troubleshooting\nSMS operations will throw an exception if the request to the server fails. The SMS client will raise exceptions defined in [Azure Core](https://github.com/Azure/azure-sdk-for-python/blob/main/sdk/core/azure-core/README.md). Exceptions will not be thrown if the error is caused by an individual message, only if something fails with the overall request. Please use the successful flag to validate each individual result to verify if the message was sent.\n\n```python\ntry:\n    sms_responses = sms_client.send(\n        from_=\"<leased-phone-number>\",\n        to=[\"<to-phone-number-1>\", \"<to-phone-number-2>\", \"<to-phone-number-3>\"],\n        message=\"Hello World via SMS\")\n\n    for sms_response in sms_responses:\n        if (sms_response.successful):\n            print(\"Message with message id {} was successful sent to {}\"\n            .format(sms_response.message_id, sms_response.to))\n        else:\n            print(\"Message failed to send to {} with the status code {} and error: {}\"\n            .format(sms_response.to, sms_response.http_status_code, sms_response.error_message))\nexcept Exception as ex:\n    print('Exception:')\n    print(ex)\n```\n\n## Next steps\n- [Read more about SMS in Azure Communication Services][next_steps]\n- For a basic guide on how to configure Delivery Reporting for your SMS messages please refer to the [Handle SMS Events quickstart][handle_sms_events].\n\n### More sample code\n\nPlease take a look at the [samples](https://github.com/Azure/azure-sdk-for-python/tree/main/sdk/communication/azure-communication-sms/samples) directory for detailed examples of how to use this library to send an sms.\n\n## Provide Feedback\n\nIf you encounter any bugs or have suggestions, please file an issue in the [Issues](https://github.com/Azure/azure-sdk-for-python/issues) section of the project\n\n## Contributing\n\nThis project welcomes contributions and suggestions.  Most contributions require you to agree to a\nContributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.microsoft.com.\n\nWhen you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the\nPR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.\n\nThis project has adopted the [Microsoft Open Source Code of Conduct](https://opensource.microsoft.com/codeofconduct/).\nFor more information see the [Code of Conduct FAQ](https://opensource.microsoft.com/codeofconduct/faq/) or contact [opencode@microsoft.com](mailto:opencode@microsoft.com) with any additional questions or comments.\n\n<!-- LINKS -->\n[azure_core]: https://github.com/Azure/azure-sdk-for-python/blob/main/sdk/core/azure-core/README.md\n[handle_sms_events]: https://docs.microsoft.com/azure/communication-services/quickstarts/telephony-sms/handle-sms-events\n[next_steps]:https://docs.microsoft.com/azure/communication-services/quickstarts/telephony-sms/send?pivots=programming-language-python\n",
    "bugtrack_url": null,
    "license": "MIT License",
    "summary": "Microsoft Azure Communication SMS Client Library for Python",
    "version": "1.1.0",
    "project_urls": {
        "Homepage": "https://github.com/Azure/azure-sdk-for-python"
    },
    "split_keywords": [
        "azure",
        " azure sdk"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "b67ea926d0dec83c244ec7567020652edbcfe533a98ce1c665943017d10ee3b9",
                "md5": "2defcd4980cbe07c03694aa5dd79a874",
                "sha256": "3ce901924661a7e9f684c777784cdd09d0c2277489a3b563b025868f74d7a676"
            },
            "downloads": -1,
            "filename": "azure_communication_sms-1.1.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "2defcd4980cbe07c03694aa5dd79a874",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 41695,
            "upload_time": "2024-10-03T14:12:01",
            "upload_time_iso_8601": "2024-10-03T14:12:01.865102Z",
            "url": "https://files.pythonhosted.org/packages/b6/7e/a926d0dec83c244ec7567020652edbcfe533a98ce1c665943017d10ee3b9/azure_communication_sms-1.1.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "c80678b09956bfc038121f27f905e9a2b18eb206b2e452b5f49e64f5a2b216cc",
                "md5": "75c54b7d2db9fa393152908eaa7aae7a",
                "sha256": "5eb99e12537cf03f6bea96aa63f3fbfd77c3e12db075751708f2956e627d8074"
            },
            "downloads": -1,
            "filename": "azure_communication_sms-1.1.0.tar.gz",
            "has_sig": false,
            "md5_digest": "75c54b7d2db9fa393152908eaa7aae7a",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.8",
            "size": 33410,
            "upload_time": "2024-10-03T14:12:00",
            "upload_time_iso_8601": "2024-10-03T14:12:00.752303Z",
            "url": "https://files.pythonhosted.org/packages/c8/06/78b09956bfc038121f27f905e9a2b18eb206b2e452b5f49e64f5a2b216cc/azure_communication_sms-1.1.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-10-03 14:12:00",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "Azure",
    "github_project": "azure-sdk-for-python",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "lcname": "azure-communication-sms"
}
        
Elapsed time: 0.31097s