1
0
mirror of https://github.com/danog/MadelineProto.git synced 2025-01-12 14:38:17 +01:00
MadelineProto/src/DocsBuilder.php

175 lines
7.0 KiB
PHP
Raw Normal View History

2022-12-30 21:54:44 +01:00
<?php
declare(strict_types=1);
Merge alpha into master (async, huge bugfixes and more) (#546) * Implement async and lots of bugfixes * Implement more async * Implement async, implement bugfixes for the connection module, for the datacenter module, huge bugfixes, huge perfomance improvements, media DCs for https, advanced selecting, custom var_dump, totally rewritten IOLoop and response mechanism, promises, improvements to the TL parser, custom mb_substr * Apply fixes from StyleCI * Bugfixes * Apply fixes from StyleCI * Bugfixes, implement combined promises * Apply fixes from StyleCI * Support passing method arguments as callable * Starting to write async upload logic * Apply fixes from StyleCI * Start implementing async file upload * Apply fixes from StyleCI * bugfix * Apply fixes from StyleCI * Start rewriting connection module * Add PHP file docblocks for all classes * Start working on new async stream API * Finish writing stream API * More stream API fixes * Apply fixes from StyleCI * Rewrite DataCenter and Connection modules * Clean up stream API documentation * Fixes * Apply fixes from StyleCI * Add referenced parameter to get length of buffer to read in getReadBuffer API * Moved all MessageHandler code in the Connection module, added a PHP version warning in the phar * Start fixing reads * Fix all protocol stream wrappers * Apply fixes from StyleCI * Implement disconnection, and remove end function * Working async RPC * Implement async file upload * Bugfix * Method recall bugfixes * Bugfixes * Trait bugfixes * Fix FIFO buffer * Bugfixes and speedtests * Async logging * Implement websocket streams * Implement loop API, signal API, clean closing and start changing layer * Small magna, websocket and HTTP fixes * Clean up loop API * Improved stack traces, 2FA and async * Login fixes * Added instructions for manual verification * Small fixes * More app info improvements * More app info improvements * TL and 2FA fixes * Update to layer 89 * More bugfixes * Implement broken media reporting * Remove debug comments * PHP 7.2 backwards compatibility * Bugfixes * Async key generation * Some simplifications * Transport fixes * Cleanup * async API * Performance fixes * Fixes to async API * Bugfixes * Implement one-time async loop * Authorization and logging fixes * Update to layer 91 * 7to5 fix * Null coalesce conversion * Implement socks5 proxy * Implement HTTP proxy * Fixes to HTTP proxy * MTProxy and socks5 fixes * Disable PHP 5 conversion * Proxies have higher priority * Avoid error handling in vendor * Override composer dependencies * Fix travis build * Final composer fixes * Proxy logic fixes * Fix get_updates update handling * Do not use parallel file driver if not supported * Refactor loader and implement HTTP fixes * Suppress errors in loader * HTTP and authorization fixes * HTTP fixes * Improved peer management * Use HTTP protocol on altervista * Small bugfixes * Minor fixes * Docufix * Docufix * Legacy fixes * Fix message queue * Avoid updating if using MTProxy * Improve logs and examples * Trim final newlines while converting parse mode * Reimplement noResponse flag * Async combined event handler and APIFactory fixes * Actually return config * Case-insensitive methods * Bugfix * Apply fixes from StyleCI (#545) * MTProxy fixes * PHP 5 warning * Improved PHP 5 warning * Use <br> along with newlines in web logs * Update docs
2018-12-26 20:51:14 +01:00
/**
* DocsBuilder module.
*
* This file is part of MadelineProto.
* MadelineProto is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
* MadelineProto is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Affero General Public License for more details.
* You should have received a copy of the GNU General Public License along with MadelineProto.
* If not, see <http://www.gnu.org/licenses/>.
*
* @author Daniil Gentili <daniil@daniil.it>
2023-01-04 12:43:01 +01:00
* @copyright 2016-2023 Daniil Gentili <daniil@daniil.it>
Merge alpha into master (async, huge bugfixes and more) (#546) * Implement async and lots of bugfixes * Implement more async * Implement async, implement bugfixes for the connection module, for the datacenter module, huge bugfixes, huge perfomance improvements, media DCs for https, advanced selecting, custom var_dump, totally rewritten IOLoop and response mechanism, promises, improvements to the TL parser, custom mb_substr * Apply fixes from StyleCI * Bugfixes * Apply fixes from StyleCI * Bugfixes, implement combined promises * Apply fixes from StyleCI * Support passing method arguments as callable * Starting to write async upload logic * Apply fixes from StyleCI * Start implementing async file upload * Apply fixes from StyleCI * bugfix * Apply fixes from StyleCI * Start rewriting connection module * Add PHP file docblocks for all classes * Start working on new async stream API * Finish writing stream API * More stream API fixes * Apply fixes from StyleCI * Rewrite DataCenter and Connection modules * Clean up stream API documentation * Fixes * Apply fixes from StyleCI * Add referenced parameter to get length of buffer to read in getReadBuffer API * Moved all MessageHandler code in the Connection module, added a PHP version warning in the phar * Start fixing reads * Fix all protocol stream wrappers * Apply fixes from StyleCI * Implement disconnection, and remove end function * Working async RPC * Implement async file upload * Bugfix * Method recall bugfixes * Bugfixes * Trait bugfixes * Fix FIFO buffer * Bugfixes and speedtests * Async logging * Implement websocket streams * Implement loop API, signal API, clean closing and start changing layer * Small magna, websocket and HTTP fixes * Clean up loop API * Improved stack traces, 2FA and async * Login fixes * Added instructions for manual verification * Small fixes * More app info improvements * More app info improvements * TL and 2FA fixes * Update to layer 89 * More bugfixes * Implement broken media reporting * Remove debug comments * PHP 7.2 backwards compatibility * Bugfixes * Async key generation * Some simplifications * Transport fixes * Cleanup * async API * Performance fixes * Fixes to async API * Bugfixes * Implement one-time async loop * Authorization and logging fixes * Update to layer 91 * 7to5 fix * Null coalesce conversion * Implement socks5 proxy * Implement HTTP proxy * Fixes to HTTP proxy * MTProxy and socks5 fixes * Disable PHP 5 conversion * Proxies have higher priority * Avoid error handling in vendor * Override composer dependencies * Fix travis build * Final composer fixes * Proxy logic fixes * Fix get_updates update handling * Do not use parallel file driver if not supported * Refactor loader and implement HTTP fixes * Suppress errors in loader * HTTP and authorization fixes * HTTP fixes * Improved peer management * Use HTTP protocol on altervista * Small bugfixes * Minor fixes * Docufix * Docufix * Legacy fixes * Fix message queue * Avoid updating if using MTProxy * Improve logs and examples * Trim final newlines while converting parse mode * Reimplement noResponse flag * Async combined event handler and APIFactory fixes * Actually return config * Case-insensitive methods * Bugfix * Apply fixes from StyleCI (#545) * MTProxy fixes * PHP 5 warning * Improved PHP 5 warning * Use <br> along with newlines in web logs * Update docs
2018-12-26 20:51:14 +01:00
* @license https://opensource.org/licenses/AGPL-3.0 AGPLv3
2019-10-31 15:07:35 +01:00
* @link https://docs.madelineproto.xyz MadelineProto documentation
Merge alpha into master (async, huge bugfixes and more) (#546) * Implement async and lots of bugfixes * Implement more async * Implement async, implement bugfixes for the connection module, for the datacenter module, huge bugfixes, huge perfomance improvements, media DCs for https, advanced selecting, custom var_dump, totally rewritten IOLoop and response mechanism, promises, improvements to the TL parser, custom mb_substr * Apply fixes from StyleCI * Bugfixes * Apply fixes from StyleCI * Bugfixes, implement combined promises * Apply fixes from StyleCI * Support passing method arguments as callable * Starting to write async upload logic * Apply fixes from StyleCI * Start implementing async file upload * Apply fixes from StyleCI * bugfix * Apply fixes from StyleCI * Start rewriting connection module * Add PHP file docblocks for all classes * Start working on new async stream API * Finish writing stream API * More stream API fixes * Apply fixes from StyleCI * Rewrite DataCenter and Connection modules * Clean up stream API documentation * Fixes * Apply fixes from StyleCI * Add referenced parameter to get length of buffer to read in getReadBuffer API * Moved all MessageHandler code in the Connection module, added a PHP version warning in the phar * Start fixing reads * Fix all protocol stream wrappers * Apply fixes from StyleCI * Implement disconnection, and remove end function * Working async RPC * Implement async file upload * Bugfix * Method recall bugfixes * Bugfixes * Trait bugfixes * Fix FIFO buffer * Bugfixes and speedtests * Async logging * Implement websocket streams * Implement loop API, signal API, clean closing and start changing layer * Small magna, websocket and HTTP fixes * Clean up loop API * Improved stack traces, 2FA and async * Login fixes * Added instructions for manual verification * Small fixes * More app info improvements * More app info improvements * TL and 2FA fixes * Update to layer 89 * More bugfixes * Implement broken media reporting * Remove debug comments * PHP 7.2 backwards compatibility * Bugfixes * Async key generation * Some simplifications * Transport fixes * Cleanup * async API * Performance fixes * Fixes to async API * Bugfixes * Implement one-time async loop * Authorization and logging fixes * Update to layer 91 * 7to5 fix * Null coalesce conversion * Implement socks5 proxy * Implement HTTP proxy * Fixes to HTTP proxy * MTProxy and socks5 fixes * Disable PHP 5 conversion * Proxies have higher priority * Avoid error handling in vendor * Override composer dependencies * Fix travis build * Final composer fixes * Proxy logic fixes * Fix get_updates update handling * Do not use parallel file driver if not supported * Refactor loader and implement HTTP fixes * Suppress errors in loader * HTTP and authorization fixes * HTTP fixes * Improved peer management * Use HTTP protocol on altervista * Small bugfixes * Minor fixes * Docufix * Docufix * Legacy fixes * Fix message queue * Avoid updating if using MTProxy * Improve logs and examples * Trim final newlines while converting parse mode * Reimplement noResponse flag * Async combined event handler and APIFactory fixes * Actually return config * Case-insensitive methods * Bugfix * Apply fixes from StyleCI (#545) * MTProxy fixes * PHP 5 warning * Improved PHP 5 warning * Use <br> along with newlines in web logs * Update docs
2018-12-26 20:51:14 +01:00
*/
2018-02-24 17:54:39 +01:00
namespace danog\MadelineProto;
2022-12-30 19:21:36 +01:00
use danog\MadelineProto\DocsBuilder\Constructors;
use danog\MadelineProto\DocsBuilder\Methods;
use danog\MadelineProto\Settings\TLSchema;
2019-10-31 20:48:06 +01:00
use danog\MadelineProto\TL\TL;
2019-06-27 11:26:39 +02:00
// This code was written a few years ago: it is garbage, and has to be rewritten
2023-01-15 12:05:38 +01:00
final class DocsBuilder
{
2020-06-16 17:52:55 +02:00
const DEFAULT_TEMPLATES = [
'User' => ['User', 'InputUser', 'Chat', 'InputChannel', 'Peer', 'InputDialogPeer', 'DialogPeer', 'InputPeer', 'NotifyPeer', 'InputNotifyPeer'],
2022-05-11 20:35:26 +02:00
'ReplyMarkup' => ['ReplyMarkup'],
2020-06-16 17:52:55 +02:00
'InputFile' => ['InputFile', 'InputEncryptedFile'],
'InputEncryptedChat' => ['InputEncryptedChat'],
'PhoneCall' => ['PhoneCall'],
'InputPhoto' => ['InputPhoto'],
'InputDocument' => ['InputDocument'],
'InputMedia' => ['InputMedia'],
'InputMessage' => ['InputMessage'],
'KeyboardButton' => ['KeyboardButton'],
2023-05-11 12:51:35 +02:00
'InputCheckPasswordSRP' => ['InputCheckPasswordSRP'],
'Updates' => ['Updates'],
2020-06-16 17:52:55 +02:00
];
2022-12-30 19:21:36 +01:00
use Methods;
use Constructors;
2017-06-06 18:39:21 +02:00
public $td = false;
2020-10-03 15:36:03 +02:00
protected array $settings;
protected string $index;
protected Logger $logger;
protected TL $TL;
protected array $tdDescriptions;
public function __construct(Logger $logger, array $settings)
2017-01-02 19:52:29 +01:00
{
2018-04-19 19:56:52 +02:00
$this->logger = $logger;
2019-09-02 17:08:36 +02:00
\set_error_handler(['\\danog\\MadelineProto\\Exception', 'ExceptionErrorHandler']);
2020-10-03 15:36:03 +02:00
/** @psalm-suppress InvalidArgument */
2023-01-08 20:33:54 +01:00
$this->TL = new TL(null);
$new = new TLSchema;
2020-09-24 20:49:34 +02:00
$new->mergeArray($settings);
$this->TL->init($new);
2017-03-11 19:55:56 +01:00
if (isset($settings['tl_schema']['td']) && !isset($settings['tl_schema']['telegram'])) {
2017-06-06 18:39:21 +02:00
$this->td = true;
2017-03-11 19:55:56 +01:00
}
$this->settings = $settings;
2019-09-02 17:08:36 +02:00
if (!\file_exists($this->settings['output_dir'])) {
\mkdir($this->settings['output_dir']);
2017-01-02 19:52:29 +01:00
}
2019-09-02 17:08:36 +02:00
\chdir($this->settings['output_dir']);
$this->index = $settings['readme'] ? 'README.md' : 'index.md';
2020-06-16 17:52:55 +02:00
2023-01-04 15:13:55 +01:00
foreach (\glob($this->settings['template'].'/*') as $template) {
2020-06-16 17:52:55 +02:00
$this->templates[\basename($template, '.md')] = \file_get_contents($template);
}
}
2020-06-16 17:52:55 +02:00
/**
* Documentation templates.
*
*/
2023-01-04 15:13:55 +01:00
protected array $templates = [];
2020-06-16 17:52:55 +02:00
2023-07-16 13:43:55 +02:00
protected static function markdownEscape(string $s): string
{
return \str_replace('_', '\\_', $s);
}
2017-08-18 18:10:30 +02:00
public $types = [];
public $any = '*';
2020-10-01 21:03:25 +02:00
public function mkDocs(): void
2017-01-02 19:52:29 +01:00
{
2022-12-30 19:21:36 +01:00
Logger::log('Generating documentation index...', Logger::NOTICE);
2022-05-01 20:17:16 +02:00
\file_put_contents($this->index, $this->template('index', $this->settings['description']));
2020-06-16 17:52:55 +02:00
$this->mkMethods();
2019-10-29 21:33:23 +01:00
$this->mkConstructors();
2019-09-02 17:08:36 +02:00
foreach (\glob('types/*') as $unlink) {
\unlink($unlink);
}
2019-09-02 17:08:36 +02:00
if (\file_exists('types')) {
\rmdir('types');
}
2019-09-02 17:08:36 +02:00
\mkdir('types');
\ksort($this->types);
$index = '';
2022-12-30 19:21:36 +01:00
Logger::log('Generating types documentation...', Logger::NOTICE);
2017-08-18 18:10:30 +02:00
foreach ($this->types as $otype => $keys) {
2020-06-16 17:52:55 +02:00
$type = StrTools::typeEscape($otype);
2023-07-16 13:43:55 +02:00
$index .= '['.self::markdownEscape($type).'](/API_docs/types/'.$type.'.md)<a name="'.$type.'"></a>
';
$constructors = '';
2017-08-18 18:10:30 +02:00
foreach ($keys['constructors'] as $data) {
2020-04-05 22:22:47 +02:00
$predicate = $data['predicate'].(isset($data['layer']) && $data['layer'] !== '' ? '_'.$data['layer'] : '');
2023-07-16 13:43:55 +02:00
$md_predicate = self::markdownEscape($predicate);
2022-05-01 20:17:16 +02:00
$constructors .= "[$md_predicate](/API_docs/constructors/$predicate.md) \n\n";
}
$methods = '';
2017-08-18 18:10:30 +02:00
foreach ($keys['methods'] as $data) {
2019-12-27 18:26:47 +01:00
$name = $data['method'];
$md_name = \str_replace(['.', '_'], ['->', '\\_'], $name);
2022-05-01 20:17:16 +02:00
$methods .= "[\$MadelineProto->$md_name](/API_docs/methods/$name.md) \n\n";
}
2019-12-27 18:50:56 +01:00
$symFile = \str_replace('.', '_', $type);
2020-01-31 19:29:43 +01:00
$redir = $symFile !== $type ? "\nredirect_from: /API_docs/types/{$symFile}.html" : '';
2020-06-16 17:52:55 +02:00
$header = '';
2017-08-25 14:43:29 +02:00
if (!isset($this->settings['td'])) {
2020-06-16 17:52:55 +02:00
foreach (self::DEFAULT_TEMPLATES as $template => $types) {
2023-06-28 15:50:38 +02:00
if (\in_array($type, $types, true)) {
2020-06-16 17:52:55 +02:00
$header .= $this->template($template, $type);
}
2017-08-25 14:43:50 +02:00
}
}
2020-10-03 15:36:03 +02:00
if (isset($this->tdDescriptions['types'][$otype])) {
$header = "{$this->tdDescriptions['types'][$otype]}\n\n$header";
2017-04-21 13:14:21 +02:00
}
2020-06-16 17:52:55 +02:00
$header = \sprintf(
$this->templates['Type'],
$type,
$redir,
2023-07-16 13:43:55 +02:00
self::markdownEscape($type),
2020-06-16 17:52:55 +02:00
$header,
$constructors,
2022-12-30 19:21:36 +01:00
$methods,
2020-06-16 17:52:55 +02:00
);
2022-07-26 18:07:51 +02:00
\file_put_contents('types/'.$type.'.md', $header);
}
2022-12-30 19:21:36 +01:00
Logger::log('Generating types index...', Logger::NOTICE);
2020-06-16 17:52:55 +02:00
\file_put_contents('types/'.$this->index, $this->templates['types-index'].$index);
2022-12-30 19:21:36 +01:00
Logger::log('Generating additional types...', Logger::NOTICE);
2023-07-08 17:11:21 +02:00
foreach (['waveform', 'string', 'bytes', 'int', 'int53', 'long', 'int128', 'int256', 'int512', 'double', 'Bool', 'DataJSON', '!X'] as $type) {
2020-06-16 17:52:55 +02:00
\file_put_contents("types/$type.md", $this->templates[$type]);
}
foreach (['boolFalse', 'boolTrue', 'null', 'photoStrippedSize'] as $constructor) {
2020-06-16 17:52:55 +02:00
\file_put_contents("constructors/$constructor.md", $this->templates[$constructor]);
}
2022-12-30 19:21:36 +01:00
Logger::log('Done!', Logger::NOTICE);
}
2020-10-01 21:03:25 +02:00
public static function addToLang(string $key, string $value = '', bool $force = false): void
2018-03-23 16:39:58 +01:00
{
2022-12-30 19:21:36 +01:00
if (!isset(Lang::$lang['en'][$key]) || $force) {
Lang::$lang['en'][$key] = $value;
}
}
2020-06-16 17:52:55 +02:00
/**
* Get formatted template string.
*
* @param string $name Template name
2020-10-03 15:04:35 +02:00
* @param string ...$params Params
2020-06-16 17:52:55 +02:00
*/
2020-10-03 15:04:35 +02:00
protected function template(string $name, string ...$params): string
2020-06-16 17:52:55 +02:00
{
return \sprintf($this->templates[$name], ...$params);
}
2018-02-24 17:54:39 +01:00
}