Node.js module to interact with official Telegram Bot API. A bot token is needed, to obtain one, talk to @botfather and create a new bot.
npm install node-telegram-bot-api
var TelegramBot = require('node-telegram-bot-api');
var token = 'YOUR_TELEGRAM_BOT_TOKEN';
// Setup polling way
var bot = new TelegramBot(token, {polling: true});
bot.on('text', function (msg) {
var chatId = msg.chat.id;
// photo can be: a file path, a stream or a Telegram file_id
var photo = 'cats.png';
bot.sendPhoto(chatId, photo, {caption: 'Lovely kittens'});
});
There are some other examples on examples.
Every time TelegramBot receives a message, it emits a message
. Depending on which message was received, emits an event from this ones: text
, audio
, document
, photo
, sticker
, video
, contact
, location
, new_chat_participant
, left_chat_participant
, new_chat_title
, new_chat_photo
, delete_chat_photo
, group_chat_created
. Its much better to listen a specific event rather than a message
in order to stay safe from the content.
Both request method to obtain messages are implemented. To use standard polling, set polling: true
on options
. Notice that webHook will need a valid (not self signed) SSL certificate.
Emits message
when a message arrives.
See: https://core.telegram.org/bots/api
- String token Bot Token
- Object [options]
- Boolean|Object [options.polling=false] Set true to enable polling or set options
- String|Number [options.polling.timeout=4] Polling time
- String|Number [options.polling.interval=2000] Interval between requests in miliseconds
- Boolean|Object [options.webHook=false] Set true to enable WebHook or set options
- String [options.webHook.key] PEM private key to webHook server
- String [options.webHook.cert] PEM certificate key to webHook server
Returns basic information about the bot in form of a User
object.
See: https://core.telegram.org/bots/api#getme
- Promise
Specify an url to receive incoming updates via an outgoing webHook.
See: https://core.telegram.org/bots/api#setwebhook
- String url URL where Telegram will make HTTP Post. Leave empty to delete webHook.
Use this method to receive incoming updates using long polling
See: https://core.telegram.org/bots/api#getupdates
- Number|String [timeout] Timeout in seconds for long polling.
- Number|String [limit] Limits the number of updates to be retrieved.
- Number|String [offset] Identifier of the first update to be returned.
- Promise Updates
Send text message.
See: https://core.telegram.org/bots/api#sendmessage
- Number|String chatId Unique identifier for the message recipient
- String text Text of the message to be sent
- Object [options] Additional Telegram query options
- Promise
Forward messages of any kind.
- Number|String chatId Unique identifier for the message recipient
- Number|String fromChatId Unique identifier for the chat where the original message was sent
- Number|String messageId Unique message identifier
- Promise
Send photo
See: https://core.telegram.org/bots/api#sendphoto
- Number|String chatId Unique identifier for the message recipient
- String|stream.Stream photo A file path or a Stream. Can also be a
file_id
previously uploaded - Object [options] Additional Telegram query options
- Promise
Send audio
See: https://core.telegram.org/bots/api#sendaudio
- Number|String chatId Unique identifier for the message recipient
- String|stream.Stream audio A file path or a Stream. Can also be a
file_id
previously uploaded. - Object [options] Additional Telegram query options
- Promise
Send Document
See: https://core.telegram.org/bots/api#sendDocument
- Number|String chatId Unique identifier for the message recipient
- String|stream.Stream A file path or a Stream. Can also be a
file_id
previously uploaded. - Object [options] Additional Telegram query options
- Promise
Send .webp stickers.
See: https://core.telegram.org/bots/api#sendsticker
- Number|String chatId Unique identifier for the message recipient
- String|stream.Stream A file path or a Stream. Can also be a
file_id
previously uploaded. - Object [options] Additional Telegram query options
- Promise
Use this method to send video files, Telegram clients support mp4 videos (other formats may be sent as Document).
See: https://core.telegram.org/bots/api#sendvideo
- Number|String chatId Unique identifier for the message recipient
- String|stream.Stream A file path or a Stream. Can also be a
file_id
previously uploaded. - Object [options] Additional Telegram query options
- Promise
Send chat action.
typing
for text messages,
upload_photo
for photos, record_video
or upload_video
for videos,
record_audio
or upload_audio
for audio files, upload_document
for general files,
find_location
for location data.
See: https://core.telegram.org/bots/api#sendchataction
- Number|String chatId Unique identifier for the message recipient
- String action Type of action to broadcast.
- Promise
Use this method to get a list of profile pictures for a user. Returns a UserProfilePhotos object.
See: https://core.telegram.org/bots/api#getuserprofilephotos
- Number|String userId Unique identifier of the target user
- Number [offset] Sequential number of the first photo to be returned. By default, all photos are returned.
- Number [limit] Limits the number of photos to be retrieved. Values between 1—100 are accepted. Defaults to 100.
- Promise
Send location. Use this method to send point on the map.
See: https://core.telegram.org/bots/api#sendlocation
- Number|String chatId Unique identifier for the message recipient
- Float latitude Latitude of location
- Float longitude Longitude of location
- Object [options] Additional Telegram query options
- Promise