Commit 203d4a55 authored by Armando Lüscher's avatar Armando Lüscher Committed by GitHub

Merge pull request #282 from noplanman/master

Update example docs and add GitHub templates
parents d97f3862 139bfe25
### Required Information
- PHP version:
- PHP Telegram Bot version:
- Using MySQL database: yes / no
- Update Method: Webhook / getUpdates
- Self-signed certificate: yes / no
- RAW update (if available):
### Expected behaviour
> What SHOULD be happening?
### Actual behaviour
> What IS happening?
### Steps to reproduce
> Explain how to reproduce the issue
### Extra details
> Please post any extra details that might help solve the issue (e.g. logs)
> Make sure this pull request is pointed towards the "develop" branch!
> Explain in detail what this pull request contains.
...@@ -487,7 +487,11 @@ Enabling this feature, the admin bot can perform some super user commands like: ...@@ -487,7 +487,11 @@ Enabling this feature, the admin bot can perform some super user commands like:
You can specify one or more admins with this option: You can specify one or more admins with this option:
```php ```php
$telegram->enableAdmins(['your_telegram_user_id', 'other_telegram_user_id']); //Single admin
$telegram->enableAdmin(your_telegram_user_id);
//Multiple admins
$telegram->enableAdmins([your_telegram_user_id, other_telegram_user_id]);
``` ```
Telegram user id can be retrieved with the command **/whoami**. Telegram user id can be retrieved with the command **/whoami**.
Admin commands are stored in *src/Admin/* folder. Admin commands are stored in *src/Admin/* folder.
......
## Logging ## Logging
Telegram bot library feats [Monolog](https://github.com/Seldaek/monolog) to store logs. PHP Telegram Bot library features [Monolog](https://github.com/Seldaek/monolog) to store logs.
Logs are divided in those streams: Logs are divided into the following streams:
### Error ### Error
Collects all the exceptions throwned by the library: Collects all the exceptions thrown by the library:
```php ```php
TelegramLog::initErrorLog($path . '/' . $BOT_NAME . '_error.log'); TelegramLog::initErrorLog($path . '/' . $BOT_NAME . '_error.log');
``` ```
### Debug ### Debug
Stores Curl messages with the server, useful for debugging: Stores requests made to the Telegram API, useful for debugging:
```php ```php
TelegramLog::initDebugLog($path . '/' . $BOT_NAME . '_debug.log'); TelegramLog::initDebugLog($path . '/' . $BOT_NAME . '_debug.log');
``` ```
### Raw data ### Raw data
Incoming updates (json string from webhook and getUpdates) can be logged in a text file. Set this option with the methods: Incoming updates (JSON string from Webhook and getUpdates) get logged in a text file:
```php ```php
TelegramLog::initUpdateLog($path . '/' . $BOT_NAME . '_update.log'); TelegramLog::initUpdateLog($path . '/' . $BOT_NAME . '_update.log');
``` ```
Why I need raw log? Why do I need to log the raw updates?
Telegram api changes continuously and often happen that db schema is not uptodate with new entities/features. So can happen that your table schema would not be able to store valuable new information coming from Telegram. Telegram API changes continuously and it often happens that the database schema is not up to date with new entities/features. So it can happen that your table schema doesn't allow storing new valuable information coming from Telegram.
If you store raw data you can port all updates on the newest table schema just using [this script](../utils/importFromLog.php). If you store the raw data you can import all updates on the newest table schema by simply using [this script](../utils/importFromLog.php).
Remember always backup first!! Remember to always backup first!!
## Stream and external sources ## Stream and external sources
Error and Debug streams relies on the `bot_log` instance that can be provided from an external source: Error and Debug streams rely on the `bot_log` instance that can be provided from an external source:
```php ```php
TelegramLog::initialize($monolog); TelegramLog::initialize($monolog);
``` ```
Raw data relies on the `bot_update_log` instance that feats a custom format for this kind of logs. Raw data relies on the `bot_update_log` instance that uses a custom format.
#!/usr/bin/env php #!/usr/bin/env php
<?php <?php
//README /**
//This configuration file is intented to run the bot with the webhook method * README
//Uncommented parameters must be filled * This configuration file is intented to run the bot with the getUpdates method
* Uncommented parameters must be filled
*/
//bash script // Bash script
//while true; do ./getUpdatesCLI.php; done // while true; do ./getUpdatesCLI.php; done
// Load composer // Load composer
require __DIR__ . '/vendor/autoload.php'; require __DIR__ . '/vendor/autoload.php';
// Add you bot's API key and name
$API_KEY = 'your_bot_api_key'; $API_KEY = 'your_bot_api_key';
$BOT_NAME = 'username_bot'; $BOT_NAME = 'username_bot';
// Define a path for your custom commands
//$commands_path = __DIR__ . '/Commands/'; //$commands_path = __DIR__ . '/Commands/';
// Enter your MySQL database credentials
$mysql_credentials = [ $mysql_credentials = [
'host' => 'localhost', 'host' => 'localhost',
'user' => 'dbuser', 'user' => 'dbuser',
...@@ -24,51 +31,54 @@ try { ...@@ -24,51 +31,54 @@ try {
// Create Telegram API object // Create Telegram API object
$telegram = new Longman\TelegramBot\Telegram($API_KEY, $BOT_NAME); $telegram = new Longman\TelegramBot\Telegram($API_KEY, $BOT_NAME);
// Error, Debug and Raw Update logging
//Longman\TelegramBot\TelegramLog::initialize($your_external_monolog_instance);
//Longman\TelegramBot\TelegramLog::initErrorLog($path . '/' . $BOT_NAME . '_error.log');
//Longman\TelegramBot\TelegramLog::initDebugLog($path . '/' . $BOT_NAME . '_debug.log');
//Longman\TelegramBot\TelegramLog::initUpdateLog($path . '/' . $BOT_NAME . '_update.log');
// Enable MySQL // Enable MySQL
$telegram->enableMySQL($mysql_credentials); $telegram->enableMySql($mysql_credentials);
//// Enable MySQL with table prefix // Enable MySQL with table prefix
//$telegram->enableMySQL($mysql_credentials, $BOT_NAME . '_'); //$telegram->enableMySql($mysql_credentials, $BOT_NAME . '_');
//// Add an additional commands path // Add an additional commands path
//$telegram->addCommandsPath($commands_path); //$telegram->addCommandsPath($commands_path);
//// Here you can enable admin interface for the channel you want to manage // Enable admin user(s)
//$telegram->enableAdmins(['your_telegram_id']); //$telegram->enableAdmin(your_telegram_id);
//$telegram->enableAdmins([your_telegram_id, other_telegram_id]);
// Add the channel you want to manage
//$telegram->setCommandConfig('sendtochannel', ['your_channel' => '@type_here_your_channel']); //$telegram->setCommandConfig('sendtochannel', ['your_channel' => '@type_here_your_channel']);
//// Here you can set some command specific parameters, // Here you can set some command specific parameters,
//// for example, google geocode/timezone api key for date command: // for example, google geocode/timezone api key for /date command:
//$telegram->setCommandConfig('date', ['google_api_key' => 'your_google_api_key_here']); //$telegram->setCommandConfig('date', ['google_api_key' => 'your_google_api_key_here']);
//// Logging // Set custom Upload and Download path
//\Longman\TelegramBot\TelegramLog::initialize($your_external_monolog_instance);
//\Longman\TelegramBot\TelegramLog::initErrorLog($path . '/' . $BOT_NAME . '_error.log');
//\Longman\TelegramBot\TelegramLog::initDebugLog($path . '/' . $BOT_NAME . '_debug.log');
//\Longman\TelegramBot\TelegramLog::initUpdateLog($path . '/' . $BOT_NAME . '_update.log');
//// Set custom Upload and Download path
//$telegram->setDownloadPath('../Download'); //$telegram->setDownloadPath('../Download');
//$telegram->setUploadPath('../Upload'); //$telegram->setUploadPath('../Upload');
//// Botan.io integration // Botan.io integration
//$telegram->enableBotan('your_token'); //$telegram->enableBotan('your_token');
// Handle telegram getUpdate request // Handle telegram getUpdates request
$ServerResponse = $telegram->handleGetUpdates(); $serverResponse = $telegram->handleGetUpdates();
if ($ServerResponse->isOk()) { if ($serverResponse->isOk()) {
$n_update = count($ServerResponse->getResult()); $updateCount = count($serverResponse->getResult());
print(date('Y-m-d H:i:s', time()) . ' - Processed ' . $n_update . ' updates' . "\n"); echo date('Y-m-d H:i:s', time()) . ' - Processed ' . $updateCount . ' updates';
} else { } else {
print(date('Y-m-d H:i:s', time()) . ' - Failed to fetch updates' . "\n"); echo date('Y-m-d H:i:s', time()) . ' - Failed to fetch updates' . PHP_EOL;
echo $ServerResponse->printError() . "\n"; echo $serverResponse->printError();
} }
} catch (Longman\TelegramBot\Exception\TelegramException $e) { } catch (Longman\TelegramBot\Exception\TelegramException $e) {
echo $e; echo $e;
// log telegram errors // Log telegram errors
\Longman\TelegramBot\TelegramLog::error($e); Longman\TelegramBot\TelegramLog::error($e);
} catch (Longman\TelegramBot\Exception\TelegramLogException $e) { } catch (Longman\TelegramBot\Exception\TelegramLogException $e) {
//catch log initilization errors // Catch log initilization errors
echo $e; echo $e;
} }
<?php <?php
//README /**
//This configuration file is intended to run the bot with the webhook method. * README
//Uncommented parameters must be filled * This configuration file is intended to run the bot with the webhook method.
//Please notice that if you open this file with your browser you'll get the "Input is empty!" Exception. * Uncommented parameters must be filled
//This is a normal behaviour because this address has to be reached only by Telegram server. *
* Please note that if you open this file with your browser you'll get the "Input is empty!" Exception.
* This is a normal behaviour because this address has to be reached only by Telegram server.
*/
// Load composer // Load composer
require __DIR__ . '/vendor/autoload.php'; require __DIR__ . '/vendor/autoload.php';
// Add you bot's API key and name
$API_KEY = 'your_bot_api_key'; $API_KEY = 'your_bot_api_key';
$BOT_NAME = 'username_bot'; $BOT_NAME = 'username_bot';
// Define a path for your custom commands
//$commands_path = __DIR__ . '/Commands/'; //$commands_path = __DIR__ . '/Commands/';
// Enter your MySQL database credentials
//$mysql_credentials = [ //$mysql_credentials = [
// 'host' => 'localhost', // 'host' => 'localhost',
// 'user' => 'dbuser', // 'user' => 'dbuser',
...@@ -22,44 +30,48 @@ try { ...@@ -22,44 +30,48 @@ try {
// Create Telegram API object // Create Telegram API object
$telegram = new Longman\TelegramBot\Telegram($API_KEY, $BOT_NAME); $telegram = new Longman\TelegramBot\Telegram($API_KEY, $BOT_NAME);
//// Enable MySQL // Error, Debug and Raw Update logging
//$telegram->enableMySQL($mysql_credentials); //Longman\TelegramBot\TelegramLog::initialize($your_external_monolog_instance);
//Longman\TelegramBot\TelegramLog::initErrorLog($path . '/' . $BOT_NAME . '_error.log');
//Longman\TelegramBot\TelegramLog::initDebugLog($path . '/' . $BOT_NAME . '_debug.log');
//Longman\TelegramBot\TelegramLog::initUpdateLog($path . '/' . $BOT_NAME . '_update.log');
// Enable MySQL
//$telegram->enableMySql($mysql_credentials);
//// Enable MySQL with table prefix // Enable MySQL with table prefix
//$telegram->enableMySQL($mysql_credentials, $BOT_NAME . '_'); //$telegram->enableMySql($mysql_credentials, $BOT_NAME . '_');
//// Add an additional commands path // Add an additional commands path
//$telegram->addCommandsPath($commands_path); //$telegram->addCommandsPath($commands_path);
//// Here you can enable admin interface for the channel you want to manage // Enable admin user(s)
//$telegram->enableAdmins(['your_telegram_id']); //$telegram->enableAdmin(your_telegram_id);
//$telegram->enableAdmins([your_telegram_id, other_telegram_id]);
// Add the channel you want to manage
//$telegram->setCommandConfig('sendtochannel', ['your_channel' => '@type_here_your_channel']); //$telegram->setCommandConfig('sendtochannel', ['your_channel' => '@type_here_your_channel']);
//// Here you can set some command specific parameters, // Here you can set some command specific parameters,
//// for example, google geocode/timezone api key for date command: // for example, google geocode/timezone api key for /date command:
//$telegram->setCommandConfig('date', ['google_api_key' => 'your_google_api_key_here']); //$telegram->setCommandConfig('date', ['google_api_key' => 'your_google_api_key_here']);
//// Logging // Set custom Upload and Download path
//\Longman\TelegramBot\TelegramLog::initialize($your_external_monolog_instance);
//\Longman\TelegramBot\TelegramLog::initErrorLog($path . '/' . $BOT_NAME . '_error.log');
//\Longman\TelegramBot\TelegramLog::initDebugLog($path . '/' . $BOT_NAME . '_debug.log');
//\Longman\TelegramBot\TelegramLog::initUpdateLog($path . '/' . $BOT_NAME . '_update.log');
//// Set custom Upload and Download path
//$telegram->setDownloadPath('../Download'); //$telegram->setDownloadPath('../Download');
//$telegram->setUploadPath('../Upload'); //$telegram->setUploadPath('../Upload');
//// Botan.io integration // Botan.io integration
//$telegram->enableBotan('your_token'); //$telegram->enableBotan('your_token');
// Handle telegram webhook request // Handle telegram webhook request
$telegram->handle(); $telegram->handle();
} catch (Longman\TelegramBot\Exception\TelegramException $e) { } catch (Longman\TelegramBot\Exception\TelegramException $e) {
// Silence is gold! // Silence is golden!
// echo $e; //echo $e;
// log telegram errors // Log telegram errors
\Longman\TelegramBot\TelegramLog::error($e); Longman\TelegramBot\TelegramLog::error($e);
} catch (Longman\TelegramBot\Exception\TelegramLogException $e) { } catch (Longman\TelegramBot\Exception\TelegramLogException $e) {
// Silence is gold! Uncomment this to catch log initilization errors // Silence is golden!
// Uncomment this to catch log initilization errors
//echo $e; //echo $e;
} }
...@@ -91,15 +91,23 @@ class TelegramTest extends TestCase ...@@ -91,15 +91,23 @@ class TelegramTest extends TestCase
$this->assertEmpty($tg->getAdminList()); $this->assertEmpty($tg->getAdminList());
// Single
$tg->enableAdmin(1); $tg->enableAdmin(1);
$this->assertCount(1, $tg->getAdminList()); $this->assertCount(1, $tg->getAdminList());
// Multiple
$tg->enableAdmins([2, 3]); $tg->enableAdmins([2, 3]);
$this->assertCount(3, $tg->getAdminList()); $this->assertCount(3, $tg->getAdminList());
// Already added
$tg->enableAdmin(2); $tg->enableAdmin(2);
$this->assertCount(3, $tg->getAdminList()); $this->assertCount(3, $tg->getAdminList());
// Integer as a string
$tg->enableAdmin('4');
$this->assertCount(3, $tg->getAdminList());
// Random string
$tg->enableAdmin('a string?'); $tg->enableAdmin('a string?');
$this->assertCount(3, $tg->getAdminList()); $this->assertCount(3, $tg->getAdminList());
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment