A Simple Drift API Wrapper.
Project description
<p align="center">
<img src="img/drift_python.png" width="300"/>
</p>
# Drift Python
A [Drift API](https://devdocs.drift.com) wrapper written in Python.
## Getting Started
To get started run `pip install drift-python`
```python
from drift import Drift
drift = Drift("YOUR ACCESS TOKEN")
```
## Contacts
Read the docs here: [Contacts API](https://devdocs.drift.com/docs/contact-model).
**Available Methods**
- `drift.contacts.get()`
- contact_id (required)
- email (optional)
- limit (optional)
- `drift.contacts.list()`
- limit (optional) - defaults to `40`
- cursor (optional)
- `drift.contacts.create()`
- **attributes (required)
Example:
`drift.contacts.create(email='johndoe@drift.com')`
- `drift.contacts.update()`
- contact_id (required)
- **attributes (required)
- `drift.contacts.delete()`
- contact_id (required)
- `drift.contacts.add_tags()`
- contact_id (required)
- tags (required)
Example:
```
drift.contacts.add_tags(
conversation_id=1,
tags=[{'name': 'My Tag'}]
)
```
- `drift.contacts.remove_tag()`
- contact_id (required)
- tag_name (required)
- `drift.contacts.remove_tags_bulk()`
- contact_id (required)
## Conversations
Read the docs here [Conversations API](https://devdocs.drift.com/docs/conversation-overview)
**Available Methods**
- `drift.conversations.get()`
- conversation_id (required)
- `drift.conversations.list()`
- limit (optional) - defaults to `50`
- next_ (optional)
- `drift.conversations.create_message()`
- conversation_id (required)
- org_id (required)
- type (required)
- edited_message_id (optional)
- edit_type (optional)
Example:
```
drift.conversations.create_message(
conversation_id=1,
org_id=1,
type='chat'
)
```
- `drift.conversations.get_messages()`
- conversation_id (required)
- next_ (optional)
- `drift.conversations.get_attachments()`
- doc_id (required)
- `drift.conversations.get_metrics()`
- query (required)
Example:
```
drift.conversations.get_metrics(
{
"metrics": [
{
"type": "AVG",
"property": "numBotMessages"
}
],
"filters": [
{
"property": "createdAt",
"operation": "BETWEEN",
"values": ["2018-01-01", "2018-07-31"]
}
]
}
)
```
## Contributors
- Lemuel Boyce [rhymiz](https://github.com/rhymiz)
- Chris Buonocore [cbonoz](https://github.com/cbonoz)
## Support / Feedback / Bugs
For support and feedback, you can find us on [Slack](https://join.slack.com/t/devdrift/shared_invite/enQtMzg4MTI3NDk5NDQ0LWUwMWYzZTkyMmQ1YjdkNjkwZDg2Mzk2YjAyMDg4MWViYmIzZjVhZTczNDQwMDVjOGRjZGU5OTkxMWQ0ZGU0Mjg)!
If you've found a bug, feel free to open up a PR with a fix or submit an issue.
<img src="img/drift_python.png" width="300"/>
</p>
# Drift Python
A [Drift API](https://devdocs.drift.com) wrapper written in Python.
## Getting Started
To get started run `pip install drift-python`
```python
from drift import Drift
drift = Drift("YOUR ACCESS TOKEN")
```
## Contacts
Read the docs here: [Contacts API](https://devdocs.drift.com/docs/contact-model).
**Available Methods**
- `drift.contacts.get()`
- contact_id (required)
- email (optional)
- limit (optional)
- `drift.contacts.list()`
- limit (optional) - defaults to `40`
- cursor (optional)
- `drift.contacts.create()`
- **attributes (required)
Example:
`drift.contacts.create(email='johndoe@drift.com')`
- `drift.contacts.update()`
- contact_id (required)
- **attributes (required)
- `drift.contacts.delete()`
- contact_id (required)
- `drift.contacts.add_tags()`
- contact_id (required)
- tags (required)
Example:
```
drift.contacts.add_tags(
conversation_id=1,
tags=[{'name': 'My Tag'}]
)
```
- `drift.contacts.remove_tag()`
- contact_id (required)
- tag_name (required)
- `drift.contacts.remove_tags_bulk()`
- contact_id (required)
## Conversations
Read the docs here [Conversations API](https://devdocs.drift.com/docs/conversation-overview)
**Available Methods**
- `drift.conversations.get()`
- conversation_id (required)
- `drift.conversations.list()`
- limit (optional) - defaults to `50`
- next_ (optional)
- `drift.conversations.create_message()`
- conversation_id (required)
- org_id (required)
- type (required)
- edited_message_id (optional)
- edit_type (optional)
Example:
```
drift.conversations.create_message(
conversation_id=1,
org_id=1,
type='chat'
)
```
- `drift.conversations.get_messages()`
- conversation_id (required)
- next_ (optional)
- `drift.conversations.get_attachments()`
- doc_id (required)
- `drift.conversations.get_metrics()`
- query (required)
Example:
```
drift.conversations.get_metrics(
{
"metrics": [
{
"type": "AVG",
"property": "numBotMessages"
}
],
"filters": [
{
"property": "createdAt",
"operation": "BETWEEN",
"values": ["2018-01-01", "2018-07-31"]
}
]
}
)
```
## Contributors
- Lemuel Boyce [rhymiz](https://github.com/rhymiz)
- Chris Buonocore [cbonoz](https://github.com/cbonoz)
## Support / Feedback / Bugs
For support and feedback, you can find us on [Slack](https://join.slack.com/t/devdrift/shared_invite/enQtMzg4MTI3NDk5NDQ0LWUwMWYzZTkyMmQ1YjdkNjkwZDg2Mzk2YjAyMDg4MWViYmIzZjVhZTczNDQwMDVjOGRjZGU5OTkxMWQ0ZGU0Mjg)!
If you've found a bug, feel free to open up a PR with a fix or submit an issue.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
drift-python-1.0.1.tar.gz
(4.4 kB
view hashes)
Built Distribution
Close
Hashes for drift_python-1.0.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e0dcd10ccb5973e54cc4c957429b6a6b5e913f2ab1f4111706ec66d0044e46b4 |
|
MD5 | 85a10948e80793c4ee74badfb4d60fc1 |
|
BLAKE2b-256 | c3b32a09451ed46e7eaf69f0f52e0782ee802cfe9fd887aa10e74483970f2dac |