@saysimple/node-sdk
Version:
The official SaySimple Node SDK. Want to use our awesome customer conversations platform? Please visit: https://saysimple.com
116 lines (90 loc) • 6.68 kB
Markdown
# SaySimple SDK for JavaScript
We’re Saysimple — the Messaging Platform Pioneer — and we’re on a mission to
change customer service centers into commercial profit centers. We’re turning
social messaging channels that are used for personal communication into
powerful communication channels for any kind of business, providing
conversational excellence with unrivaled ease.
And this, is our SDK for JavaScript for you.
## Installation
**For NPM**
```
npm i @saysimple/node-sdk
```
**For Yarn**
```
yarn add @saysimple/node-sdk
```
## Usage
### API Documentation 📑
The SDK is a one-on-one translation of the native REST API, which can be found here.
You can get a more in-depth knowledge of the API and the possible parameters if
you read the [API documentation](https://api.saysimple.io/docs).
### Intelligence V1 👩🏻🔬
**Initialization**
```javascript
const SaySimpleClient = require("@saysimple/node-sdk");
const Intelligence = SaySimpleClient.Intelligence.V1("[API TOKEN]", "[SECRET KEY]");
// Or:
const Intelligence = SaySimpleClient.Intelligence.Latest("[API TOKEN]", "[SECRET KEY]");
```
*If you omit a secret key, the SDK will assume you put a valid access token
directly on the first parameter.*
**Functions**
| Function | Parameters |
|----------|------------|
| addMessage | See [**Add A Message** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/postMessage) |
| getMessagesSummed | See [**Total Messages Summed** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getTotalMessagesSummed) |
| getActiveContactsSummed | See [**Total Active Contacts** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getTotalActiveContacts) |
| getActiveContactsDistribution| See [**Total Active Contacts Distribution** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getActiveContactsDistributions) |
| getSendPaidTemplatesSummed | See [**Total Paid Templates Sent** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getTotalPaidTemplatesSent) |
| getAgents | See [**List all Agents** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getAgents) |
| getChannels | See [**List all Channels** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getChannels) |
| getTags| See [**List all Tags** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getTags) |
| getTeams | See [**List all Teams** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getTeams) |
| getMessageDistribution | See [**Message Distribution** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getMessageDistribution) |
| getConversationsResolved | See [**Total Resolved Conversations** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getResolvedCoversations) |
| getConversationsResolveTimesAverage | See [**Get Conversations Resolve Times (Average)** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getConversationResolveTimesAverage) |
| getConversationsResolveTimesMedian | See [**Get Conversations Resolve Times (Median)** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getConversationResolveTimesMedian) |
| resolveConversation | See [**Resolve a Conversation** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/postEventsConversationsResolve) |
| getConversationsFirstReplyTimesAverage | See [**Get Conversations Reply Times (Average)** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getConversationsFirstReplyTimesAverage) |
| getConversationsFirstReplyTimesMedian | See [**Get Conversations Reply Times (Median)** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getConversationsFirstReplyTimesMedian) |
| getConversationsFirstReplyTimesBusinessHoursAverage | See [**Get Conversations Reply Times During Business Hours (Average)** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getConversationsFirstReplyTimesBusinessHoursAverage) |
| getConversationsFirstReplyTimesBusinessHoursMedian | See [**Get Conversations Reply Times During Business Hours (Median)** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getConversationsFirstReplyTimesBusinessHoursMedian) |
| getConversationsMessagesAverage | See [**Average Messages per Conversation** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getConversationsMessagesAverage) |
| getConversationsTagsUsed | See [**Conversations Tags Used** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getConversationsTags) |
| getMessagesResponseTimesAverage | See [**Response Times (Average)** in the API Docs](https://docs.saysimple.io/insights/index.html#operation/getMessagesResponseTimesAverage) |
To get all messages summed you can run the following code
```javascript
const SaySimpleClient = require("@saysimple/node-sdk");
const Intelligence = SaySimpleClient.Intelligence.V1("[API TOKEN]", "[SECRET KEY]");
(async () => {
const messagesSummed = await Intelligence.getMessagesSummed({
agent: "agent@teddies.com"
});
console.log(messagesSummed);
})();
```
That's it! 🚀
## Messaging V1 💌
_Will be implemented as soon as possible.
For now please refer to the [API documentation](https://docs.saysimple.io/messaging/index.html)._
## Showcasing 🎭
We are really keen to know what you build with SaySimple, so please do let us
know when your project is up-and-running!
## TypeScript support ⌨️
This package exports type declarations, thus it can be used in TypeScript
projects without requiring extra dependencies.
## Support 🧞
We tried to make the API and SDK as easy as possible, but maybe we didn't
succeed on every aspect of it. Please don't hesitate to contact us if something
is not working or is unclear.
You can reach us at: [support@saysimple.nl](mailto:support@saysimple.nl).
## Raising an issue 🤕
If you encounter a bug in this software we'd love to hear about it. So we can
work on improving our SDK, and your developer experience.
Please be sure you've searched for the same problem in the tickets opened
already. Also, it would be helpful if you can provide as many details as possible.
Like the versions of the SDK and Node.js and how your (environment) set up is.
## License 🕵🏽♀️
This software is distributed under the Apache License 2.0 license. See [LICENSE.txt](./LICENSE.txt).
Copyright 2019 - 2021 Just Internet B.V. or its affiliates. All Rights Reserved.