Commit 3d14b749 authored by Marco Boretto's avatar Marco Boretto Committed by GitHub

Merge pull request #264 from noplanman/improve_example_inline_comments

Update inline comments for hook.php and getUpdatesCLI.php
parents 52b3c94d 3890c5f2
## 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,53 +31,54 @@ try { ...@@ -24,53 +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);
//// Enable admin users // Enable admin user(s)
//$telegram->enableAdmin(your_telegram_id); //$telegram->enableAdmin(your_telegram_id);
//$telegram->enableAdmins([your_telegram_id, other_telegram_id]);
//// Add the channel you want to manage // 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,46 +30,48 @@ try { ...@@ -22,46 +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);
//// Enable admin users // Enable admin user(s)
//$telegram->enableAdmin(your_telegram_id); //$telegram->enableAdmin(your_telegram_id);
//$telegram->enableAdmins([your_telegram_id, other_telegram_id]);
//// Add the channel you want to manage // 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;
} }
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