Bugfix
This commit is contained in:
parent
ce0e12c747
commit
93bd9073e1
@ -25,8 +25,8 @@
|
||||
"amphp/http-client": "^4",
|
||||
"amphp/socket": "^1",
|
||||
"amphp/dns": "^1",
|
||||
"amphp/file": "^1",
|
||||
"amphp/byte-stream": "^1",
|
||||
"amphp/file": "^1",
|
||||
"danog/dns-over-https": "^0.2",
|
||||
"amphp/http-client-cookies": "^1",
|
||||
"danog/tg-file-decoder": "^0.1",
|
||||
@ -49,7 +49,8 @@
|
||||
"ext-ctype": "*",
|
||||
"danog/7to70": "^1",
|
||||
"danog/7to5": "^1",
|
||||
"vimeo/psalm": "dev-master"
|
||||
"vimeo/psalm": "dev-master",
|
||||
"phpstan/phpstan": "^0.12.14"
|
||||
},
|
||||
"suggest": {
|
||||
"ext-libtgvoip": "Install the php-libtgvoip extension to make phone calls (https://github.com/danog/php-libtgvoip)"
|
||||
|
2
docs
2
docs
@ -1 +1 @@
|
||||
Subproject commit 1e1967391fe643b6ecc0e6f22a800386cbd22e5d
|
||||
Subproject commit eda40443bf6215bc8eff7842a5eaaae70b4c4ee3
|
@ -20,7 +20,7 @@
|
||||
|
||||
require '../vendor/autoload.php';
|
||||
|
||||
$MadelineProto = new \danog\MadelineProto\API('session.madeline');
|
||||
$MadelineProto = new \danog\MadelineProto\API('index.madeline');
|
||||
$me = $MadelineProto->start();
|
||||
|
||||
$me = $MadelineProto->getSelf();
|
||||
|
@ -39,7 +39,7 @@ interface SignalLoopInterface extends LoopInterface
|
||||
/**
|
||||
* Send a signal to the the loop.
|
||||
*
|
||||
* @param \Throwable|any $data Signal to send
|
||||
* @param \Throwable|mixed $data Signal to send
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
|
@ -310,14 +310,17 @@ class Magic
|
||||
// Even an empty handler is enough to catch ctrl+c
|
||||
if (\defined('SIGINT')) {
|
||||
//if (function_exists('pcntl_async_signals')) pcntl_async_signals(true);
|
||||
Loop::unreference(Loop::onSignal(SIGINT, static function () {
|
||||
Logger::log('Got sigint', Logger::FATAL_ERROR);
|
||||
Magic::shutdown(1);
|
||||
}));
|
||||
Loop::unreference(Loop::onSignal(SIGTERM, static function () {
|
||||
Logger::log('Got sigterm', Logger::FATAL_ERROR);
|
||||
Magic::shutdown(1);
|
||||
}));
|
||||
try {
|
||||
Loop::unreference(Loop::onSignal(SIGINT, static function () {
|
||||
Logger::log('Got sigint', Logger::FATAL_ERROR);
|
||||
Magic::shutdown(1);
|
||||
}));
|
||||
Loop::unreference(Loop::onSignal(SIGTERM, static function () {
|
||||
Logger::log('Got sigterm', Logger::FATAL_ERROR);
|
||||
Magic::shutdown(1);
|
||||
}));
|
||||
} catch (\Throwable $e) {
|
||||
}
|
||||
}
|
||||
/*if (!self::$altervista && !self::$zerowebhost) {
|
||||
$DohConfig = new DoHConfig(
|
||||
|
@ -1,102 +0,0 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* Server 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>
|
||||
* @copyright 2016-2020 Daniil Gentili <daniil@daniil.it>
|
||||
* @license https://opensource.org/licenses/AGPL-3.0 AGPLv3
|
||||
*
|
||||
* @link https://docs.madelineproto.xyz MadelineProto documentation
|
||||
*/
|
||||
|
||||
namespace danog\MadelineProto;
|
||||
|
||||
/*
|
||||
* Socket server for multi-language API
|
||||
*/
|
||||
class Server
|
||||
{
|
||||
private $settings;
|
||||
private $pids = [];
|
||||
private $mypid;
|
||||
public function __construct($settings)
|
||||
{
|
||||
\set_error_handler(['\\danog\\MadelineProto\\Exception', 'ExceptionErrorHandler']);
|
||||
\danog\MadelineProto\Logger::constructor(3);
|
||||
if (!\extension_loaded('sockets')) {
|
||||
throw new Exception(['extension', 'sockets']);
|
||||
}
|
||||
if (!\extension_loaded('pcntl')) {
|
||||
throw new Exception(['extension', 'pcntl']);
|
||||
}
|
||||
$this->settings = $settings;
|
||||
$this->mypid = \getmypid();
|
||||
}
|
||||
public function start()
|
||||
{
|
||||
\pcntl_signal(SIGTERM, [$this, 'sigHandler']);
|
||||
\pcntl_signal(SIGINT, [$this, 'sigHandler']);
|
||||
\pcntl_signal(SIGCHLD, [$this, 'sigHandler']);
|
||||
$this->sock = new \Socket($this->settings['type'], SOCK_STREAM, $this->settings['protocol']);
|
||||
$this->sock->bind($this->settings['address'], $this->settings['port']);
|
||||
$this->sock->listen();
|
||||
$this->sock->setBlocking(true);
|
||||
$timeout = 2;
|
||||
$this->sock->setOption(\SOL_SOCKET, \SO_RCVTIMEO, $timeout);
|
||||
$this->sock->setOption(\SOL_SOCKET, \SO_SNDTIMEO, $timeout);
|
||||
\danog\MadelineProto\Logger::log('Server started! Listening on ' . $this->settings['address'] . ':' . $this->settings['port']);
|
||||
while (true) {
|
||||
\pcntl_signal_dispatch();
|
||||
try {
|
||||
if ($sock = $this->sock->accept()) {
|
||||
$this->handle($sock);
|
||||
}
|
||||
} catch (\danog\MadelineProto\Exception $e) {
|
||||
}
|
||||
}
|
||||
}
|
||||
private function handle($socket)
|
||||
{
|
||||
$pid = \pcntl_fork();
|
||||
if ($pid == -1) {
|
||||
die('could not fork');
|
||||
} elseif ($pid) {
|
||||
return $this->pids[] = $pid;
|
||||
}
|
||||
$handler = new $this->settings['handler']($socket, $this->settings['extra'], null, null, null, null, null);
|
||||
$handler->loop();
|
||||
die;
|
||||
}
|
||||
public function __destruct()
|
||||
{
|
||||
if ($this->mypid === \getmypid()) {
|
||||
\danog\MadelineProto\Logger::log('Shutting main process ' . $this->mypid . ' down');
|
||||
unset($this->sock);
|
||||
foreach ($this->pids as $pid) {
|
||||
\danog\MadelineProto\Logger::log("Waiting for {$pid}");
|
||||
\pcntl_wait($pid);
|
||||
}
|
||||
\danog\MadelineProto\Logger::log('Done, closing main process');
|
||||
return;
|
||||
}
|
||||
}
|
||||
public function sigHandler($sig)
|
||||
{
|
||||
switch ($sig) {
|
||||
case SIGTERM:
|
||||
case SIGINT:
|
||||
exit;
|
||||
case SIGCHLD:
|
||||
\pcntl_waitpid(-1, $status);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user