More bugfixes
This commit is contained in:
parent
c00c7c600d
commit
e13d28ecda
@ -1,6 +1,9 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
require 'vendor/autoload.php';
|
require 'vendor/autoload.php';
|
||||||
|
$secret = 'pony';
|
||||||
|
$secret = md5('pony');
|
||||||
|
echo "Secret is $secret\n";
|
||||||
|
|
||||||
$handler = new \danog\MadelineProto\Server(['type' => AF_INET, 'protocol' => 0, 'address' => 'localhost', 'port' => 8002, 'handler' => '\danog\MadelineProto\Server\Proxy', 'extra' => ['madeline' => new \danog\MadelineProto\API(['app_info' => ['api_id' => 6, 'api_hash' => 'eb06d4abfb49dc3eeb1aeb98ae0f581e']]), 'secret' => 'pony']]);
|
$handler = new \danog\MadelineProto\Server(['type' => AF_INET, 'protocol' => 0, 'address' => '0.0.0.0', 'port' => 7777, 'handler' => '\danog\MadelineProto\Server\Proxy', 'extra' => ['madeline' => new \danog\MadelineProto\API('proxy.madeline', ['app_info' => ['api_id' => 6, 'api_hash' => 'eb06d4abfb49dc3eeb1aeb98ae0f581e']]), 'secret' => hex2bin($secret), 'timeout' => 30]]);
|
||||||
$handler->start();
|
$handler->start();
|
||||||
|
@ -118,12 +118,14 @@ If not, see <http://www.gnu.org/licenses/>.
|
|||||||
public function read(int $length, int $flags = 0)
|
public function read(int $length, int $flags = 0)
|
||||||
{
|
{
|
||||||
$packet = '';
|
$packet = '';
|
||||||
|
$try = 0;
|
||||||
while (strlen($packet) < $length) {
|
while (strlen($packet) < $length) {
|
||||||
$read = stream_get_contents($this->sock, $length - strlen($packet));
|
$read = stream_get_contents($this->sock, $length - strlen($packet));
|
||||||
if ($read === false || strlen($read) === 0) {
|
if ($read === false || (strlen($read) === 0 && $try > 10)) {
|
||||||
throw new \danog\MadelineProto\NothingInTheSocketException('Nothing in the socket!');
|
throw new \danog\MadelineProto\NothingInTheSocketException('Nothing in the socket!');
|
||||||
}
|
}
|
||||||
$packet .= $read;
|
$packet .= $read;
|
||||||
|
$try++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $packet;
|
return $packet;
|
||||||
@ -283,12 +285,14 @@ if (!extension_loaded('pthreads')) {
|
|||||||
public function read(int $length, int $flags = 0)
|
public function read(int $length, int $flags = 0)
|
||||||
{
|
{
|
||||||
$packet = '';
|
$packet = '';
|
||||||
|
$try = 0;
|
||||||
while (strlen($packet) < $length) {
|
while (strlen($packet) < $length) {
|
||||||
$read = socket_read($this->sock, $length - strlen($packet), $flags);
|
$read = socket_read($this->sock, $length - strlen($packet), $flags);
|
||||||
if ($read === false || strlen($read) === 0) {
|
if ($read === false || (strlen($read) === 0 && $try > 10)) {
|
||||||
throw new \danog\MadelineProto\NothingInTheSocketException('Nothing in the socket!');
|
throw new \danog\MadelineProto\NothingInTheSocketException('Nothing in the socket!');
|
||||||
}
|
}
|
||||||
$packet .= $read;
|
$packet .= $read;
|
||||||
|
$try++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $packet;
|
return $packet;
|
||||||
|
@ -69,6 +69,11 @@ class Connection
|
|||||||
- https
|
- https
|
||||||
- udp
|
- udp
|
||||||
*/
|
*/
|
||||||
|
if ($proxy === '\\MTProxySocket') {
|
||||||
|
$proxy = '\\Socket';
|
||||||
|
$protocol = 'obfuscated2';
|
||||||
|
}
|
||||||
|
|
||||||
$this->protocol = $protocol;
|
$this->protocol = $protocol;
|
||||||
$this->timeout = $timeout;
|
$this->timeout = $timeout;
|
||||||
$this->ipv6 = $ipv6;
|
$this->ipv6 = $ipv6;
|
||||||
@ -76,7 +81,7 @@ class Connection
|
|||||||
$this->port = $port;
|
$this->port = $port;
|
||||||
$this->proxy = $proxy;
|
$this->proxy = $proxy;
|
||||||
$this->extra = $extra;
|
$this->extra = $extra;
|
||||||
if (($has_proxy = $proxy !== '\\Socket') && !isset(class_implements($proxy)['danog\\MadelineProto\\Proxy'])) {
|
if (($has_proxy = !in_array($proxy, ['\\MTProxySocket', '\\Socket'])) && !isset(class_implements($proxy)['danog\\MadelineProto\\Proxy'])) {
|
||||||
throw new \danog\MadelineProto\Exception(\danog\MadelineProto\Lang::$current_lang['proxy_class_invalid']);
|
throw new \danog\MadelineProto\Exception(\danog\MadelineProto\Lang::$current_lang['proxy_class_invalid']);
|
||||||
}
|
}
|
||||||
switch ($this->protocol) {
|
switch ($this->protocol) {
|
||||||
@ -135,6 +140,7 @@ class Connection
|
|||||||
$random = $this->random(64);
|
$random = $this->random(64);
|
||||||
} while (in_array(substr($random, 0, 4), ['PVrG', 'GET ', 'POST', 'HEAD', str_repeat(chr(238), 4)]) || $random[0] === chr(0xef) || substr($random, 4, 4) === "\0\0\0\0");
|
} while (in_array(substr($random, 0, 4), ['PVrG', 'GET ', 'POST', 'HEAD', str_repeat(chr(238), 4)]) || $random[0] === chr(0xef) || substr($random, 4, 4) === "\0\0\0\0");
|
||||||
$random[56] = $random[57] = $random[58] = $random[59] = chr(0xef);
|
$random[56] = $random[57] = $random[58] = $random[59] = chr(0xef);
|
||||||
|
|
||||||
$reversed = strrev(substr($random, 8, 48));
|
$reversed = strrev(substr($random, 8, 48));
|
||||||
$this->obfuscated = ['encryption' => new \phpseclib\Crypt\AES('ctr'), 'decryption' => new \phpseclib\Crypt\AES('ctr')];
|
$this->obfuscated = ['encryption' => new \phpseclib\Crypt\AES('ctr'), 'decryption' => new \phpseclib\Crypt\AES('ctr')];
|
||||||
$this->obfuscated['encryption']->enableContinuousBuffer();
|
$this->obfuscated['encryption']->enableContinuousBuffer();
|
||||||
|
@ -16,20 +16,20 @@ namespace danog\MadelineProto\Server;
|
|||||||
/*
|
/*
|
||||||
* Socket handler for server
|
* Socket handler for server
|
||||||
*/
|
*/
|
||||||
class Handler extends \danog\MadelineProto\Connection
|
class Proxy extends \danog\MadelineProto\Connection
|
||||||
{
|
{
|
||||||
use \danog\MadelineProto\Tools;
|
use \danog\MadelineProto\Tools;
|
||||||
private $madeline;
|
private $madeline;
|
||||||
|
|
||||||
public function __magic_construct($socket, $extra, $ip, $port, $protocol, $timeout, $ipv6)
|
public function __magic_construct($socket, $extra, $ip, $port, $protocol, $timeout, $ipv6)
|
||||||
{
|
{
|
||||||
|
\danog\MadelineProto\Logger::log('Got connection '.getmypid().'!');
|
||||||
\danog\MadelineProto\Magic::$pid = getmypid();
|
\danog\MadelineProto\Magic::$pid = getmypid();
|
||||||
$this->sock = $socket;
|
$this->sock = $socket;
|
||||||
$this->sock->setBlocking(true);
|
$this->sock->setBlocking(true);
|
||||||
$this->must_open = false;
|
$this->must_open = false;
|
||||||
$timeout = 2;
|
$this->sock->setOption(\SOL_SOCKET, \SO_RCVTIMEO, $extra['timeout']);
|
||||||
$this->sock->setOption(\SOL_SOCKET, \SO_RCVTIMEO, $timeout);
|
$this->sock->setOption(\SOL_SOCKET, \SO_SNDTIMEO, $extra['timeout']);
|
||||||
$this->sock->setOption(\SOL_SOCKET, \SO_SNDTIMEO, $timeout);
|
|
||||||
$this->logger = new \danog\MadelineProto\Logger(3);
|
$this->logger = new \danog\MadelineProto\Logger(3);
|
||||||
$this->extra = $extra;
|
$this->extra = $extra;
|
||||||
}
|
}
|
||||||
@ -46,40 +46,51 @@ class Handler extends \danog\MadelineProto\Connection
|
|||||||
$random = $this->sock->read(64);
|
$random = $this->sock->read(64);
|
||||||
|
|
||||||
$reversed = strrev(substr($random, 8, 48));
|
$reversed = strrev(substr($random, 8, 48));
|
||||||
|
$key = substr($random, 8, 32);
|
||||||
|
$keyRev = substr($reversed, 0, 32);
|
||||||
if (isset($this->extra['secret'])) {
|
if (isset($this->extra['secret'])) {
|
||||||
$random = substr_replace($random, hash('sha256', $key.$this->extra['secret'], true), 32, 8);
|
$key = hash('sha256', $key.$this->extra['secret'], true);
|
||||||
|
$keyRev = hash('sha256', $keyRev.$this->extra['secret'], true);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->obfuscated = ['encryption' => new \phpseclib\Crypt\AES('ctr'), 'decryption' => new \phpseclib\Crypt\AES('ctr')];
|
$this->obfuscated = ['encryption' => new \phpseclib\Crypt\AES('ctr'), 'decryption' => new \phpseclib\Crypt\AES('ctr')];
|
||||||
$this->obfuscated['encryption']->enableContinuousBuffer();
|
$this->obfuscated['encryption']->enableContinuousBuffer();
|
||||||
$this->obfuscated['decryption']->enableContinuousBuffer();
|
$this->obfuscated['decryption']->enableContinuousBuffer();
|
||||||
$this->obfuscated['decryption']->setKey(substr($random, 8, 32));
|
$this->obfuscated['decryption']->setKey($key);
|
||||||
$this->obfuscated['decryption']->setIV(substr($random, 40, 16));
|
$this->obfuscated['decryption']->setIV(substr($random, 40, 16));
|
||||||
$this->obfuscated['encryption']->setKey(substr($reversed, 0, 32));
|
$this->obfuscated['encryption']->setKey($keyRev);
|
||||||
$this->obfuscated['encryption']->setIV(substr($reversed, 32, 16));
|
$this->obfuscated['encryption']->setIV(substr($reversed, 32, 16));
|
||||||
$random = substr_replace($random, substr(@$this->obfuscated['encryption']->encrypt($random), 56, 8), 56, 8);
|
$random = substr_replace($random, substr(@$this->obfuscated['decryption']->encrypt($random), 56, 8), 56, 8);
|
||||||
|
|
||||||
$random[56] = $random[57] = $random[58] = $random[59] = chr(0xef);
|
|
||||||
|
|
||||||
if (substr($random, 56, 4) !== str_repeat(chr(0xef), 4)) {
|
if (substr($random, 56, 4) !== str_repeat(chr(0xef), 4)) {
|
||||||
throw new \danog\MadelineProto\Exception('Wrong protocol version');
|
throw new \danog\MadelineProto\Exception('Wrong protocol version');
|
||||||
}
|
}
|
||||||
$socket = $this->extra['madeline']->API->datacenter->sockets[unpack('v', substr($random, 60, 2)[1]];
|
$dc = abs(unpack('s', substr($random, 60, 2))[1]);
|
||||||
$socket->close_and_reopen();
|
|
||||||
|
$socket = $this->extra['madeline']->API->datacenter->sockets[$dc];
|
||||||
|
$socket->__construct($socket->proxy, $socket->extra, $socket->ip, $socket->port, $socket->protocol, $this->extra['timeout'], $socket->ipv6);
|
||||||
|
|
||||||
|
$write = [];
|
||||||
|
$except = [];
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
pcntl_signal_dispatch();
|
pcntl_signal_dispatch();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$time = time();
|
$read = [$this->getSocket(), $socket->getSocket()];
|
||||||
|
\Socket::select($read, $write, $except, 2);
|
||||||
|
if (isset($read[0])) {
|
||||||
|
\danog\MadelineProto\Logger::log("Will write to DC $dc on ".\danog\MadelineProto\Magic::$pid);
|
||||||
$socket->send_message($this->read_message());
|
$socket->send_message($this->read_message());
|
||||||
|
}
|
||||||
|
if (isset($read[1])) {
|
||||||
|
\danog\MadelineProto\Logger::log("Will read from DC $dc on ".\danog\MadelineProto\Magic::$pid);
|
||||||
|
$this->send_message($socket->read_message());
|
||||||
|
}
|
||||||
} catch (\danog\MadelineProto\NothingInTheSocketException $e) {
|
} catch (\danog\MadelineProto\NothingInTheSocketException $e) {
|
||||||
echo $e;
|
echo $e;
|
||||||
if (time() - $time < 2) {
|
|
||||||
exit();
|
exit();
|
||||||
}
|
}
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user