TelegramApiServer/server.php
2020-01-18 17:25:53 +03:00

79 lines
2.4 KiB
PHP

<?php
use TelegramApiServer\Migrations;
chdir(__DIR__);
require_once __DIR__ . '/bootstrap.php';
if (PHP_SAPI !== 'cli') {
throw new RuntimeException('Start in CLI');
}
$shortopts = 'a::p::s::';
$longopts = [
'address::', // ip адресс сервера, необязательное значение
'port::', // порт сервера, необязательное значение
'session::', //префикс session файла
'help', //нужна ли справка?
];
$options = getopt($shortopts, $longopts);
$options = [
'address' => $options['address'] ?? $options['a'] ?? '',
'port' => $options['port'] ?? $options['p'] ?? '',
'session' => (array) ($options['session'] ?? $options['s'] ?? ''),
'help' => isset($options['help']),
];
if ($options['help']) {
$help = 'Fast, simple, async php telegram parser: MadelineProto + Swoole Server
usage: php server.php [--help] [-a=|--address=127.0.0.1] [-p=|--port=9503] [-s=|--session=session]
Options:
--help Show this message
-a --address Server ip (optional) (default: 127.0.0.1)
To listen external connections use 0.0.0.0 and fill IP_WHITELIST in .env
-p --port Server port (optional) (default: 9503)
-s --session Name for session file (optional) (default: session)
Multiple sessions can be specified: "--session=user --session=bot"
Each session is stored in `sessions/{$session}.madeline`.
Nested folders supported.
See README for more examples.
Also all options can be set in .env file (see .env.example)
Example:
php server.php
';
echo $help;
exit;
}
Migrations\Sessions::move(__DIR__);
$sessionFiles = [];
foreach ($options['session'] as $session) {
$session = trim($session);
if (mb_substr($session, -1) === '/') {
throw new InvalidArgumentException('Session name specified as directory');
}
if (!$session) {
$session = 'session';
}
$session = TelegramApiServer\Client::getSessionFile($session);
foreach (glob($session) as $file) {
TelegramApiServer\Client::checkOrCreateSessionFolder($file, __DIR__);
$sessionFiles[$file] = null;
}
}
$client = new TelegramApiServer\Client($sessionFiles);
new TelegramApiServer\Server\Server($client, $options);