Metadata-Version: 2.1
Name: infobip-api-python-sdk
Version: 2.0.0
Summary: Python sdk for Infobip's API
Home-page: https://github.com/infobip-community/infobip-api-python-sdk
Author: Luka Kilic, Dino Lozina
Author-email: DevRel@infobip.com
License: UNKNOWN
Project-URL: Bug Tracker, https://github.com/infobip-community/infobip-api-python-sdk/issues
Keywords: infobip,sdk,channels,whatsapp,webrtc,mms,api
Platform: UNKNOWN
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3.6
Description-Content-Type: text/markdown
License-File: LICENSE

# infobip-api-python-sdk
Python client for Infobip's  API channels.

# Supported channels
- Whatsapp -> [Docs](https://www.infobip.com/docs/api#channels/whatsapp)
- WebRTC -> [Docs](https://www.infobip.com/docs/api#channels/webrtc/)
- MMS -> [Docs](https://www.infobip.com/docs/api#channels/mms)

#### Table of contents:

- [General Info](#general-info)
- [License](#license)
- [Installation](#installation)
- [Code example](#code-example)
- [Testing](#testing)
- [Enable pre-commit hooks](#enable-pre-commit-hooks)

## General Info

For `infobip-api-python-sdk` versioning we use [Semantic Versioning](https://semver.org) scheme.

Python 3.6 is minimum supported version by this library.

## License

Published under [MIT License](LICENSE).

## Installation

Install the library by using the following command:
```bash
pip install infobip-api-python-sdk
```

## Code Example
To use the package you'll need an Infobip account.
If you don't already have one, you can create a free trial account [here](https://www.infobip.com/signup).

In this example we will show how to send WhatsApp text message.
First step is to import necessary channel, in this case WhatsApp channel.

```python
from infobip_channels import WhatsAppChannel
```

Now you can create instance of `WhatsAppChannel` with your `base_url` and `api_key`.

```python
c = WhatsAppChannel.from_auth_params({
    "base_url": "<your_base_url>",
    "api_key": "<your_api_key>"
})
```
After that you can access all the methods from `WhatsAppChannel`.
To send text message you can use `send_text_message` method and add correct payload:
```python
response = c.send_text_message(
    {
      "from": "<WhatsApp sender number from your Infobib account>",
      "to": "<Number that will receive WhatsApp message>",
      "messageId": "a28dd97c-1ffb-4fcf-99f1-0b557ed381da",
      "content": {
        "text": "Some text"
      },
      "callbackData": "Callback data",
      "notifyUrl": "https://www.example.com/whatsapp"
    }
)
```
## Testing
To run tests position yourself in the project's root while your virtual environment
is active and run:
```bash
python -m pytest
```

## Enable pre-commit hooks
To enable pre-commit hooks run:
```bash
pip install -r requirements/dev.txt
```
You will need to install pre-commit hooks
Using homebrew:
```bash
brew install pre-commit
```
Using conda (via conda-forge):
```bash
conda install -c conda-forge pre-commit
```
To check installation run:
```bash
pre-commit --version
```
If installation was successful you will see version number.
You can find the Pre-commit configuration in `.pre-commit-config.yaml`.
Install the git hook scripts:
```bash
pre-commit install
```
Run against all files:
```bash
pre-commit run --all-files
```
If setup was successful pre-commit will run on every commit.
Every time you clone a project that uses pre-commit, running `pre-commit install`
should be the first thing you do.


