tje3d / telegram
1.3.1
2017-05-06 21:50 UTC
Requires
- php: >=5.5
- guzzlehttp/guzzle: ^6.2
This package is not auto-updated.
Last update: 2024-12-17 11:31:54 UTC
README
PHP Telegram Bot API, Supports Laravel.
Installation
composer require tje3d/telegram
Laravel Only
Service Provider
Tje3d\Telegram\Laravel\TelegramServiceProvider::class
Facade
'Bot' => Tje3d\Telegram\Laravel\Facades\Bot::class
Publish Assets
artisan vendor:publish --tag=telegram
Will make a config file named telegram (config/telegram.php)
Examples
✔️ Initialize a Bot
$bot = new \Tje3d\Telegram\Bot($token);
$info = $bot->getMe();
print_r($info);
✔️ Set Web Hook
$bot->setWebhook('https://sld.tld');
✔️ Get Updates
$response = $bot->getUpdates();
...
$response = $bot->getUpdates($offset=0, $limit=100, $timeout=10); // Long pull
✔️ Send text message (known as sendMessage)
$bot->sendMethod(
(new \Tje3d\Telegram\Methods\Text())
->text('test')
->chat_id($chatId)
);
⭐️ Or pass configuration as array
$bot->sendMethod(
(new Tje3d\Telegram\Methods\Text(['text' => 'hi', 'chat_id' => $chatId]))
);
✔️ Keyboard
⭐️ Reply Keyboard
$bot->sendMethod(
(new Tje3d\Telegram\Methods\Text)
->text('My Sample Text')
->chat_id($chatId)
->reply_markup(
(new Tje3d\Telegram\Markups\ReplayKeyboardMarkup)
->row(function($handler){
$handler->addButton(['text' => 'btn1']);
$handler->addButton(['text' => 'my special button ⭐️']);
})
->row(function($handler){
$handler->addButton(['text' => 'WOW']);
})
->row(function($handler){
$handler->addButton(['text' => 'Hey this is third line!']);
})
->row(function($handler){
$handler->addButton(['text' => '1']);
$handler->addButton(['text' => '2']);
$handler->addButton(['text' => '3']);
$handler->addButton(['text' => '4']);
})
)
);
⭐️ Inline Keyboard
$bot->sendMethod(
(new Tje3d\Telegram\Methods\Text)
->text('My Sample Text')
->chat_id($testChatId)
->reply_markup(
(new Tje3d\Telegram\Markups\InlineKeyboardMarkup)
->row(function($handler){
$handler->addButton(['text' => 'btn1', 'url' => 'http://sld.tld']);
$handler->addButton(['text' => 'my special button ⭐️', 'url' => 'http://sld.tld']);
})
->row(function($handler){
$handler->addButton(['text' => 'WOW', 'callback_data' => 'doSomethingSpecial']);
})
)
);
✔️ Photo, Audio, Video, Document ...
$bot->sendMethod(
(new \Tje3d\Telegram\Methods\Photo)
->chat_id($chatId)
->photo(realpath('pic.png'))
);
...
$bot->sendMethod(
(new \Tje3d\Telegram\Methods\Video)
->chat_id($chatId)
->video(realpath('video.mp4'))
->duration(10) // optional
->width(320) // optional
->height(320) // optional
);
...
$bot->sendMethod(
(new \Tje3d\Telegram\Methods\Audio)
->chat_id($chatId)
->audio(realpath('video.mp3'))
->duration(30) // optional
->performer('tje3d') // optional
->title('Great music') // optional
);
...
✔️ ChatAction
$bot->sendMethod(
(new \Tje3d\Telegram\Methods\ChatAction)
->chat_id($testChatId)
->typing() // Could be: upload_photo, record_video, upload_video, record_audio, upload_audio, upload_document, find_location
);
Exceptions
Throw's Tje3d\Telegram\Exceptions\TelegramResponseException if sendMethod failed.
try {
$bot = new \Tje3d\Telegram\Bot($token);
$response = $bot->sendMethod(
(new \Tje3d\Telegram\Methods\Text())
->text($text)
->chat_id($chatId)
);
} catch (TelegramResponseException $e) {
print_r($e->response());
}