This document contains a description for every service implemented in the sendeR
package on how to start sending messages with it. Each chapter contains information about acquiring either an API webhook, a token or some other form of credentials required for sending messages via the API.
Other than the API access acquisition usage of each client is very straightforward. With the acquired form of authorization we create a client for the service. Once the service client is created the send_message
has three basic parameters:
client
- the created client,message
- a text message to be sent,destination
- a chat id.Additionally, a client specific arguments can be passed through the ellipsis. Those arguments are also covered below.
First visit Google API web interface: https://console.developers.google.com/apis/credentials
Click Select a project, then NEW PROJECT, and enter a name for the project, and optionally, edit the provided project ID. Click Create.
On the Credentials page, select Create credentials, then OAuth client ID.
You may be prompted to set a product name on the Consent screen; if so, click Configure consent screen, supply the requested information, and click Save to return to the Credentials screen.
Select Other for the Application type, and enter any additional information required.
Click Create.
On the page that appears, copy the client ID and client secret to your clipboard, as you will need them when you configure your client library.
Create a Slack app here: https://api.slack.com/apps?new_app=1
Enable Incoming Webhooks from the settings page.
After the settings page refreshes, click Add New Webhook to Workspace. Pick a channel that the app will post to, then click Authorize.
Use your Incoming Webhook URL to post a message to Slack.
Creating a Telegram bot is really simply (simpler than guessing your chat id I would say!). To create the bow simply find the @BotFather
- chat with it should look similarly to this:
Once the chat is started BotFather will send a message with available commands. The one which interests us is /newbot
. After sending the command we will be prompted to enter our bot display name.
Once the display name is provided we will be asked for bot username, that is, the name which we can @tag the bot or search for it in the Telegram.
Once that is done BotFather will send the message with our bot API token. This token is passed to the client_telegram
function of sendeR
package.
For Telegram client the destination
argument is a chat_id where the message is supposed to be sent. Before sending messages we have to determine what is the chat id we want to use.
If we want to send messages to the one on one chat with bot. To do that open the chat with bot and initialize the chat by pressing /start
as shown below.
Now we will use the bot to read our chat id. In order to do so head to https://api.telegram.org/bot<your-bot-token>/getupdates
. Page should display a JSON response with no updates received by the bot:
{
"ok": true,
"result": []
}
Sending an example message “Hello!” to the bot and refreshing the page should result in response containing information similar to the one below (among other parameters).
{
"ok": true,
"result": [
{
"update_id": 164384282,
"message": {
"message_id": 2,
"from": {
"id": your_user_id
},
"chat": {
"id": your_chat_id
},
"date": 1573660088,
"text": "Hello!"
}
}
]
}
Here is the chat id (the destination
parameter) we were looking for.
Note that the chat id and the user id are the same that is due to the user id being used as chat id for one on one chats.
Similarly to the one on one chats we have to retrieve the information from https://api.telegram.org/bot<your-bot-token>/getupdates
page.
To get group’s chat id we need to add our bot to the group. Once the bot is added to the group an update containing following information should appear if we refresh the above page:
{
"ok": true,
"result": [
{
"update_id": 164384283,
"message": {
"message_id": 3,
"from": {
"id": your_user_id,
},
"chat": {
"id": your_group_id,
"type": "group"
},
"date": 1573661039,
"group_chat_created": true
}
}
]
}
From the response we can extract the group id (note: group ids are negative numbers).