Fixes
This commit is contained in:
parent
558afb9183
commit
d42f677884
@ -46,7 +46,7 @@ class CheckLoop extends ResumableSignalLoop
|
|||||||
$connection = $this->connection;
|
$connection = $this->connection;
|
||||||
|
|
||||||
$this->startedLoop();
|
$this->startedLoop();
|
||||||
$API->logger->logger("Entered check loop in DC {$datacenter}", Logger::ULTRA_VERBOSE);
|
$API->logger->logger("Entered $this", Logger::ULTRA_VERBOSE);
|
||||||
|
|
||||||
$dc_config_number = isset($API->settings['connection_settings'][$datacenter]) ? $datacenter : 'all';
|
$dc_config_number = isset($API->settings['connection_settings'][$datacenter]) ? $datacenter : 'all';
|
||||||
|
|
||||||
@ -54,7 +54,7 @@ class CheckLoop extends ResumableSignalLoop
|
|||||||
while (true) {
|
while (true) {
|
||||||
while (empty($connection->new_outgoing)) {
|
while (empty($connection->new_outgoing)) {
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting check loop in DC {$datacenter}");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -140,7 +140,7 @@ class CheckLoop extends ResumableSignalLoop
|
|||||||
$connection->writer->resume();
|
$connection->writer->resume();
|
||||||
}
|
}
|
||||||
if (yield $this->waitSignal($this->pause($timeout))) {
|
if (yield $this->waitSignal($this->pause($timeout))) {
|
||||||
$API->logger->logger("Exiting check loop in DC $datacenter");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -155,7 +155,7 @@ class CheckLoop extends ResumableSignalLoop
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (yield $this->waitSignal($this->pause($timeout))) {
|
if (yield $this->waitSignal($this->pause($timeout))) {
|
||||||
$API->logger->logger("Exiting check loop in DC $datacenter");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -163,4 +163,9 @@ class CheckLoop extends ResumableSignalLoop
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function __toString(): string
|
||||||
|
{
|
||||||
|
return "check loop in DC {$this->datacenter}";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -53,13 +53,13 @@ class HttpWaitLoop extends ResumableSignalLoop
|
|||||||
}
|
}
|
||||||
|
|
||||||
$this->startedLoop();
|
$this->startedLoop();
|
||||||
$API->logger->logger("Entered HTTP wait loop in DC {$datacenter}", Logger::ULTRA_VERBOSE);
|
$API->logger->logger("Entered $this", Logger::ULTRA_VERBOSE);
|
||||||
|
|
||||||
$timeout = $API->settings['connection_settings'][isset($API->settings['connection_settings'][$datacenter]) ? $datacenter : 'all']['timeout'];
|
$timeout = $API->settings['connection_settings'][isset($API->settings['connection_settings'][$datacenter]) ? $datacenter : 'all']['timeout'];
|
||||||
while (true) {
|
while (true) {
|
||||||
//var_dump("http loop DC $datacenter");
|
//var_dump("http loop DC $datacenter");
|
||||||
if ($a = yield $this->waitSignal($this->pause())) {
|
if ($a = yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting HTTP wait loop in DC $datacenter");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -72,7 +72,7 @@ class HttpWaitLoop extends ResumableSignalLoop
|
|||||||
}
|
}
|
||||||
while ($connection->temp_auth_key === null) {
|
while ($connection->temp_auth_key === null) {
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting HTTP wait loop in DC $datacenter");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -89,4 +89,9 @@ class HttpWaitLoop extends ResumableSignalLoop
|
|||||||
//($connection->last_http_wait + $timeout) - time()
|
//($connection->last_http_wait + $timeout) - time()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function __toString(): string
|
||||||
|
{
|
||||||
|
return "HTTP wait loop in DC {$this->datacenter}";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -53,7 +53,7 @@ class ReadLoop extends SignalLoop
|
|||||||
$connection = $this->connection;
|
$connection = $this->connection;
|
||||||
|
|
||||||
$this->startedLoop();
|
$this->startedLoop();
|
||||||
$API->logger->logger("Entered read loop in DC {$datacenter}", Logger::ULTRA_VERBOSE);
|
$API->logger->logger("Entered $this", Logger::ULTRA_VERBOSE);
|
||||||
//$timeout = $API->settings['connection_settings'][isset($API->settings['connection_settings'][$datacenter]) ? $datacenter : 'all']['timeout'];
|
//$timeout = $API->settings['connection_settings'][isset($API->settings['connection_settings'][$datacenter]) ? $datacenter : 'all']['timeout'];
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
@ -62,7 +62,7 @@ class ReadLoop extends SignalLoop
|
|||||||
} catch (NothingInTheSocketException $e) {
|
} catch (NothingInTheSocketException $e) {
|
||||||
if (isset($connection->old)) {
|
if (isset($connection->old)) {
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
$API->logger->logger("Exiting read loop in DC $datacenter");
|
$API->logger->logger("Exiting $this");
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -231,4 +231,9 @@ class ReadLoop extends SignalLoop
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function __toString(): string
|
||||||
|
{
|
||||||
|
return "read loop in DC {$this->datacenter}";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -53,20 +53,20 @@ class WriteLoop extends ResumableSignalLoop
|
|||||||
$connection = $this->connection;
|
$connection = $this->connection;
|
||||||
|
|
||||||
$this->startedLoop();
|
$this->startedLoop();
|
||||||
$API->logger->logger("Entered write loop in DC {$datacenter}", Logger::ULTRA_VERBOSE);
|
$API->logger->logger("Entered $this", Logger::ULTRA_VERBOSE);
|
||||||
|
|
||||||
$please_wait = false;
|
$please_wait = false;
|
||||||
while (true) {
|
while (true) {
|
||||||
if (empty($connection->pending_outgoing) || $please_wait) {
|
if (empty($connection->pending_outgoing) || $please_wait) {
|
||||||
$API->logger->logger("Waiting in write loop in DC {$datacenter}", Logger::ULTRA_VERBOSE);
|
$API->logger->logger("Waiting in $this", Logger::ULTRA_VERBOSE);
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting write loop in DC $datacenter");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
yield new Success(0);
|
yield new Success(0);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$API->logger->logger("Done waiting in write loop in DC {$datacenter}", Logger::ULTRA_VERBOSE);
|
$API->logger->logger("Done waiting in $this", Logger::ULTRA_VERBOSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@ -345,4 +345,9 @@ class WriteLoop extends ResumableSignalLoop
|
|||||||
$connection->pending_outgoing_key = 0;
|
$connection->pending_outgoing_key = 0;
|
||||||
return $skipped;
|
return $skipped;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function __toString(): string
|
||||||
|
{
|
||||||
|
return "write loop in DC {$this->datacenter}";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -52,18 +52,22 @@ class PeriodicFetcherLoop extends ResumableSignalLoop
|
|||||||
{
|
{
|
||||||
$API = $this->API;
|
$API = $this->API;
|
||||||
$callback = $this->callback;
|
$callback = $this->callback;
|
||||||
$name = $this->name;
|
|
||||||
|
|
||||||
$this->startedLoop();
|
$this->startedLoop();
|
||||||
$API->logger->logger("Entered $name loop", Logger::ULTRA_VERBOSE);
|
$API->logger->logger("Entered $this", Logger::ULTRA_VERBOSE);
|
||||||
while (true) {
|
while (true) {
|
||||||
$timeout = yield $callback();
|
$timeout = yield $callback();
|
||||||
if ($timeout === self::STOP || yield $this->waitSignal($this->pause($timeout))) {
|
if ($timeout === self::STOP || yield $this->waitSignal($this->pause($timeout))) {
|
||||||
$API->logger->logger("Exiting $name loop");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function __toString(): string
|
||||||
|
{
|
||||||
|
return "{$this->name} loop";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -44,7 +44,7 @@ abstract class Loop implements LoopInterface
|
|||||||
public function start()
|
public function start()
|
||||||
{
|
{
|
||||||
if ($this->count) {
|
if ($this->count) {
|
||||||
$this->API->logger->logger("NOT entering loop with running count {$this->count}", Logger::ERROR);
|
$this->API->logger->logger("NOT entering $this with running count {$this->count}", Logger::ERROR);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -67,4 +67,6 @@ abstract class Loop implements LoopInterface
|
|||||||
{
|
{
|
||||||
return $this->count;
|
return $this->count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
abstract public function __toString(): string;
|
||||||
}
|
}
|
||||||
|
@ -53,10 +53,10 @@ class FeedLoop extends ResumableSignalLoop
|
|||||||
}
|
}
|
||||||
|
|
||||||
$this->startedLoop();
|
$this->startedLoop();
|
||||||
$API->logger->logger("Entered update feed loop in channel {$this->channelId}", Logger::ULTRA_VERBOSE);
|
$API->logger->logger("Entered $this", Logger::ULTRA_VERBOSE);
|
||||||
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting update feed loop in channel {$this->channelId}");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -67,23 +67,24 @@ class FeedLoop extends ResumableSignalLoop
|
|||||||
while (true) {
|
while (true) {
|
||||||
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting update feed loop channel {$this->channelId}");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting update feed loop channel {$this->channelId}");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!$this->API->settings['updates']['handle_updates']) {
|
if (!$this->API->settings['updates']['handle_updates']) {
|
||||||
$API->logger->logger("Exiting update feed loop channel {$this->channelId}");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
$API->logger->logger("Resumed $this");
|
||||||
while ($this->incomingUpdates) {
|
while ($this->incomingUpdates) {
|
||||||
$updates = $this->incomingUpdates;
|
$updates = $this->incomingUpdates;
|
||||||
$this->incomingUpdates = [];
|
$this->incomingUpdates = [];
|
||||||
@ -95,9 +96,9 @@ class FeedLoop extends ResumableSignalLoop
|
|||||||
yield $API->save_update_async($update);
|
yield $API->save_update_async($update);
|
||||||
}
|
}
|
||||||
$this->parsedUpdates = [];
|
$this->parsedUpdates = [];
|
||||||
}
|
if ($API->update_deferred) {
|
||||||
if ($API->update_deferred) {
|
Loop::defer([$API->update_deferred, 'resolve']);
|
||||||
Loop::defer([$API->update_deferred, 'resolve']);
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -111,7 +112,7 @@ class FeedLoop extends ResumableSignalLoop
|
|||||||
unset($updates[$key]);
|
unset($updates[$key]);
|
||||||
if ($update['_'] === 'updateChannelTooLong') {
|
if ($update['_'] === 'updateChannelTooLong') {
|
||||||
$this->API->logger->logger('Got channel too long update, getting difference...', \danog\MadelineProto\Logger::VERBOSE);
|
$this->API->logger->logger('Got channel too long update, getting difference...', \danog\MadelineProto\Logger::VERBOSE);
|
||||||
$this->API->updaters[$this->channelId]->resumeDefer();
|
$this->API->updaters[$this->channelId]->resume();
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -167,87 +168,85 @@ class FeedLoop extends ResumableSignalLoop
|
|||||||
}
|
}
|
||||||
public function feedSingle($update)
|
public function feedSingle($update)
|
||||||
{
|
{
|
||||||
if (!$this->channelId) {
|
$channelId = false;
|
||||||
$channelId = false;
|
switch ($update['_']) {
|
||||||
switch ($update['_']) {
|
case 'updateChannelWebPage':
|
||||||
case 'updateChannelWebPage':
|
case 'updateNewChannelMessage':
|
||||||
case 'updateNewChannelMessage':
|
case 'updateEditChannelMessage':
|
||||||
case 'updateEditChannelMessage':
|
$channelId = $update['message']['to_id']['channel_id'];
|
||||||
$channelId = $update['message']['to_id']['channel_id'];
|
break;
|
||||||
break;
|
case 'updateDeleteChannelMessages':
|
||||||
case 'updateDeleteChannelMessages':
|
$channelId = $update['channel_id'];
|
||||||
$channelId = $update['channel_id'];
|
break;
|
||||||
break;
|
case 'updateChannelTooLong':
|
||||||
case 'updateChannelTooLong':
|
$channelId = $update['channel_id'];
|
||||||
$channelId = $update['channel_id'];
|
if (!isset($update['pts'])) {
|
||||||
if (!isset($update['pts'])) {
|
$update['pts'] = 1;
|
||||||
$update['pts'] = 1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($channelId && !$this->API->getChannelStates()->has($channelId)) {
|
|
||||||
$this->API->loadChannelState($channelId, $update);
|
|
||||||
if (!isset($this->API->feeders[$channelId])) {
|
|
||||||
$this->API->feeders[$channelId] = new FeedLoop($this, $channelId);
|
|
||||||
}
|
}
|
||||||
if (!isset($this->API->updaters[$channelId])) {
|
break;
|
||||||
$this->API->updaters[$channelId] = new UpdateLoop($this, $channelId);
|
|
||||||
}
|
|
||||||
$this->API->feeders[$channelId]->start();
|
|
||||||
$this->API->updaters[$channelId]->start();
|
|
||||||
}
|
|
||||||
|
|
||||||
switch ($update['_']) {
|
|
||||||
case 'updateNewMessage':
|
|
||||||
case 'updateEditMessage':
|
|
||||||
case 'updateNewChannelMessage':
|
|
||||||
case 'updateEditChannelMessage':
|
|
||||||
$to = false;
|
|
||||||
$from = false;
|
|
||||||
$via_bot = false;
|
|
||||||
$entities = false;
|
|
||||||
if (($from = isset($update['message']['from_id']) && !yield $this->peer_isset_async($update['message']['from_id'])) ||
|
|
||||||
($to = !yield $this->peer_isset_async($update['message']['to_id'])) ||
|
|
||||||
($via_bot = isset($update['message']['via_bot_id']) && !yield $this->peer_isset_async($update['message']['via_bot_id'])) ||
|
|
||||||
($entities = isset($update['message']['entities']) && !yield $this->entities_peer_isset_async($update['message']['entities'])) // ||
|
|
||||||
//isset($update['message']['fwd_from']) && !yield $this->fwd_peer_isset_async($update['message']['fwd_from'])
|
|
||||||
) {
|
|
||||||
$log = '';
|
|
||||||
if ($from) {
|
|
||||||
$log .= "from_id {$update['message']['from_id']}, ";
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($to) {
|
|
||||||
$log .= "to_id ".json_encode($update['message']['to_id']).", ";
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($via_bot) {
|
|
||||||
$log .= "via_bot {$update['message']['via_bot_id']}, ";
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($entities) {
|
|
||||||
$log .= "entities ".json_encode($update['message']['entities']).", ";
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->logger->logger("Not enough data: for message update $log, getting difference...", \danog\MadelineProto\Logger::VERBOSE);
|
|
||||||
$update = ['_' => 'updateChannelTooLong'];
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
if ($channelId !== false && !yield $this->peer_isset_async($this->to_supergroup($channelId))) {
|
|
||||||
$this->logger->logger('Skipping update, I do not have the channel id '.$channelId, \danog\MadelineProto\Logger::ERROR);
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if ($channelId) {
|
|
||||||
return $this->feeders[$channelId]->feedSingle($update);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->logger->logger('Was fed an update of type '.$update['_'].'...', \danog\MadelineProto\Logger::VERBOSE);
|
if ($channelId && !$this->API->getChannelStates()->has($channelId)) {
|
||||||
|
$this->API->loadChannelState($channelId, $update);
|
||||||
|
if (!isset($this->API->feeders[$channelId])) {
|
||||||
|
$this->API->feeders[$channelId] = new FeedLoop($this, $channelId);
|
||||||
|
}
|
||||||
|
if (!isset($this->API->updaters[$channelId])) {
|
||||||
|
$this->API->updaters[$channelId] = new UpdateLoop($this, $channelId);
|
||||||
|
}
|
||||||
|
$this->API->feeders[$channelId]->start();
|
||||||
|
$this->API->updaters[$channelId]->start();
|
||||||
|
}
|
||||||
|
|
||||||
|
switch ($update['_']) {
|
||||||
|
case 'updateNewMessage':
|
||||||
|
case 'updateEditMessage':
|
||||||
|
case 'updateNewChannelMessage':
|
||||||
|
case 'updateEditChannelMessage':
|
||||||
|
$to = false;
|
||||||
|
$from = false;
|
||||||
|
$via_bot = false;
|
||||||
|
$entities = false;
|
||||||
|
if (($from = isset($update['message']['from_id']) && !yield $this->API->peer_isset_async($update['message']['from_id'])) ||
|
||||||
|
($to = !yield $this->API->peer_isset_async($update['message']['to_id'])) ||
|
||||||
|
($via_bot = isset($update['message']['via_bot_id']) && !yield $this->API->peer_isset_async($update['message']['via_bot_id'])) ||
|
||||||
|
($entities = isset($update['message']['entities']) && !yield $this->API->entities_peer_isset_async($update['message']['entities'])) // ||
|
||||||
|
//isset($update['message']['fwd_from']) && !yield $this->fwd_peer_isset_async($update['message']['fwd_from'])
|
||||||
|
) {
|
||||||
|
$log = '';
|
||||||
|
if ($from) {
|
||||||
|
$log .= "from_id {$update['message']['from_id']}, ";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($to) {
|
||||||
|
$log .= "to_id ".json_encode($update['message']['to_id']).", ";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($via_bot) {
|
||||||
|
$log .= "via_bot {$update['message']['via_bot_id']}, ";
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($entities) {
|
||||||
|
$log .= "entities ".json_encode($update['message']['entities']).", ";
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->API->logger->logger("Not enough data: for message update $log, getting difference...", \danog\MadelineProto\Logger::VERBOSE);
|
||||||
|
$update = ['_' => 'updateChannelTooLong'];
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
if ($channelId !== false && !yield $this->API->peer_isset_async($this->API->to_supergroup($channelId))) {
|
||||||
|
$this->API->logger->logger('Skipping update, I do not have the channel id '.$channelId, \danog\MadelineProto\Logger::ERROR);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if ($channelId !== $this->channelId) {
|
||||||
|
return yield $this->API->feeders[$channelId]->feedSingle($update);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->API->logger->logger('Was fed an update of type '.$update['_']." in $this...", \danog\MadelineProto\Logger::VERBOSE);
|
||||||
$this->incomingUpdates[] = $update;
|
$this->incomingUpdates[] = $update;
|
||||||
return $this->channelId;
|
return $this->channelId;
|
||||||
}
|
}
|
||||||
@ -276,4 +275,9 @@ class FeedLoop extends ResumableSignalLoop
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function __toString(): string
|
||||||
|
{
|
||||||
|
return !$this->channelId ? "update feed loop generic" : "update feed loop channel {$this->channelId}";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -50,10 +50,10 @@ class SeqLoop extends ResumableSignalLoop
|
|||||||
}
|
}
|
||||||
|
|
||||||
$this->startedLoop();
|
$this->startedLoop();
|
||||||
$API->logger->logger("Entered update seq loop", Logger::ULTRA_VERBOSE);
|
$API->logger->logger("Entered $this", Logger::ULTRA_VERBOSE);
|
||||||
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting update seq loop");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -64,20 +64,20 @@ class SeqLoop extends ResumableSignalLoop
|
|||||||
while (true) {
|
while (true) {
|
||||||
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting update seq loop");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting update seq loop");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!$this->API->settings['updates']['handle_updates']) {
|
if (!$this->API->settings['updates']['handle_updates']) {
|
||||||
$API->logger->logger("Exiting update seq loop");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -134,6 +134,8 @@ class SeqLoop extends ResumableSignalLoop
|
|||||||
}
|
}
|
||||||
public function feed($updates)
|
public function feed($updates)
|
||||||
{
|
{
|
||||||
|
$this->API->logger->logger('Was fed updates of type '.$updates['_'].'...', \danog\MadelineProto\Logger::VERBOSE);
|
||||||
|
|
||||||
$this->incomingUpdates[] = $updates;
|
$this->incomingUpdates[] = $updates;
|
||||||
}
|
}
|
||||||
public function save($updates)
|
public function save($updates)
|
||||||
@ -158,4 +160,9 @@ class SeqLoop extends ResumableSignalLoop
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function __toString(): string
|
||||||
|
{
|
||||||
|
return "update seq loop";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -46,7 +46,7 @@ class UpdateLoop extends ResumableSignalLoop
|
|||||||
|
|
||||||
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting update feed loop in channel {$this->channelId}");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -56,13 +56,13 @@ class UpdateLoop extends ResumableSignalLoop
|
|||||||
|
|
||||||
$this->startedLoop();
|
$this->startedLoop();
|
||||||
|
|
||||||
$API->logger->logger("Entered updates loop in channel {$this->channelId}", Logger::ULTRA_VERBOSE);
|
$API->logger->logger("Entered $this", Logger::ULTRA_VERBOSE);
|
||||||
|
|
||||||
$timeout = $API->settings['updates']['getdifference_interval'];
|
$timeout = $API->settings['updates']['getdifference_interval'];
|
||||||
while (true) {
|
while (true) {
|
||||||
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
while (!$this->API->settings['updates']['handle_updates'] || !$this->has_all_auth()) {
|
||||||
if (yield $this->waitSignal($this->pause())) {
|
if (yield $this->waitSignal($this->pause())) {
|
||||||
$API->logger->logger("Exiting update loop in channel {$this->channelId}");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -73,7 +73,7 @@ class UpdateLoop extends ResumableSignalLoop
|
|||||||
$this->toPts = null;
|
$this->toPts = null;
|
||||||
while (true) {
|
while (true) {
|
||||||
if ($this->channelId) {
|
if ($this->channelId) {
|
||||||
$this->API->logger->logger('Fetching '.$this->channelId.' difference...', \danog\MadelineProto\Logger::ULTRA_VERBOSE);
|
$this->API->logger->logger('Resumed and fetching '.$this->channelId.' difference...', \danog\MadelineProto\Logger::ULTRA_VERBOSE);
|
||||||
if ($state->pts() <= 1) {
|
if ($state->pts() <= 1) {
|
||||||
$limit = 10;
|
$limit = 10;
|
||||||
} else if ($API->authorization['user']['bot']) {
|
} else if ($API->authorization['user']['bot']) {
|
||||||
@ -86,14 +86,13 @@ class UpdateLoop extends ResumableSignalLoop
|
|||||||
$timeout = $difference['timeout'];
|
$timeout = $difference['timeout'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->API->logger->logger('Got '.$difference['_'], \danog\MadelineProto\Logger::VERBOSE);
|
||||||
switch ($difference['_']) {
|
switch ($difference['_']) {
|
||||||
case 'updates.channelDifferenceEmpty':
|
case 'updates.channelDifferenceEmpty':
|
||||||
$this->API->logger->logger('Got '.$difference['_'], \danog\MadelineProto\Logger::VERBOSE);
|
|
||||||
$state->update($difference);
|
$state->update($difference);
|
||||||
unset($difference);
|
unset($difference);
|
||||||
break 2;
|
break 2;
|
||||||
case 'updates.channelDifference':
|
case 'updates.channelDifference':
|
||||||
$this->API->logger->logger('Got '.$difference['_'], \danog\MadelineProto\Logger::VERBOSE);
|
|
||||||
if ($state->pts() >= $difference['pts'] && $state->pts() > 1) {
|
if ($state->pts() >= $difference['pts'] && $state->pts() > 1) {
|
||||||
$this->API->logger->logger("The PTS ({$difference['pts']}) I got with getDifference is smaller than the PTS I requested ".$state->pts().", using ".($state->pts() + 1), \danog\MadelineProto\Logger::VERBOSE);
|
$this->API->logger->logger("The PTS ({$difference['pts']}) I got with getDifference is smaller than the PTS I requested ".$state->pts().", using ".($state->pts() + 1), \danog\MadelineProto\Logger::VERBOSE);
|
||||||
$difference['pts'] = $state->pts() + 1;
|
$difference['pts'] = $state->pts() + 1;
|
||||||
@ -113,7 +112,6 @@ class UpdateLoop extends ResumableSignalLoop
|
|||||||
unset($difference);
|
unset($difference);
|
||||||
break 2;
|
break 2;
|
||||||
case 'updates.channelDifferenceTooLong':
|
case 'updates.channelDifferenceTooLong':
|
||||||
$this->API->logger->logger('Got '.$difference['_'], \danog\MadelineProto\Logger::VERBOSE);
|
|
||||||
$state->update($difference);
|
$state->update($difference);
|
||||||
$feeder->saveMessages($difference['messages']);
|
$feeder->saveMessages($difference['messages']);
|
||||||
unset($difference);
|
unset($difference);
|
||||||
@ -122,7 +120,7 @@ class UpdateLoop extends ResumableSignalLoop
|
|||||||
throw new \danog\MadelineProto\Exception('Unrecognized update difference received: '.var_export($difference, true));
|
throw new \danog\MadelineProto\Exception('Unrecognized update difference received: '.var_export($difference, true));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$this->API->logger->logger('Fetching normal difference...', \danog\MadelineProto\Logger::ULTRA_VERBOSE);
|
$this->API->logger->logger('Resumed and fetching normal difference...', \danog\MadelineProto\Logger::ULTRA_VERBOSE);
|
||||||
|
|
||||||
$difference = yield $this->API->method_call_async_read('updates.getDifference', ['pts' => $state->pts(), 'date' => $state->date(), 'qts' => $state->qts()], ['datacenter' => $this->API->settings['connection_settings']['default_dc']]);
|
$difference = yield $this->API->method_call_async_read('updates.getDifference', ['pts' => $state->pts(), 'date' => $state->date(), 'qts' => $state->qts()], ['datacenter' => $this->API->settings['connection_settings']['default_dc']]);
|
||||||
$this->API->logger->logger('Got '.$difference['_'], \danog\MadelineProto\Logger::ULTRA_VERBOSE);
|
$this->API->logger->logger('Got '.$difference['_'], \danog\MadelineProto\Logger::ULTRA_VERBOSE);
|
||||||
@ -161,11 +159,11 @@ class UpdateLoop extends ResumableSignalLoop
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
foreach ($result as $channelId) {
|
foreach ($result as $channelId => $boh) {
|
||||||
$this->API->feeders[$channelId]->resumeDefer();
|
$this->API->feeders[$channelId]->resumeDefer();
|
||||||
}
|
}
|
||||||
if (yield $this->waitSignal($this->pause($timeout))) {
|
if (yield $this->waitSignal($this->pause($timeout))) {
|
||||||
$API->logger->logger("Exiting update loop in channel {$this->channelId}");
|
$API->logger->logger("Exiting $this");
|
||||||
$this->exitedLoop();
|
$this->exitedLoop();
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -190,4 +188,9 @@ class UpdateLoop extends ResumableSignalLoop
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function __toString(): string
|
||||||
|
{
|
||||||
|
return !$this->channelId ? "getUpdate loop generic" : "getUpdate loop channel {$this->channelId}";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -236,6 +236,10 @@ class MTProto extends AsyncConstruct implements TLCallback
|
|||||||
return $this->initing_authorization;
|
return $this->initing_authorization;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getHTTPClient()
|
||||||
|
{
|
||||||
|
return $this->datacenter->getHTTPClient();
|
||||||
|
}
|
||||||
public function __wakeup()
|
public function __wakeup()
|
||||||
{
|
{
|
||||||
$backtrace = debug_backtrace(DEBUG_BACKTRACE_PROVIDE_OBJECT, 3);
|
$backtrace = debug_backtrace(DEBUG_BACKTRACE_PROVIDE_OBJECT, 3);
|
||||||
@ -848,13 +852,10 @@ class MTProto extends AsyncConstruct implements TLCallback
|
|||||||
if (!isset($this->updaters[$channelId])) {
|
if (!isset($this->updaters[$channelId])) {
|
||||||
$this->updaters[$channelId] = new UpdateLoop($this, $channelId);
|
$this->updaters[$channelId] = new UpdateLoop($this, $channelId);
|
||||||
}
|
}
|
||||||
$this->feeders[$channelId]->start();
|
|
||||||
$this->updaters[$channelId]->start();
|
|
||||||
}
|
}
|
||||||
if (!isset($this->seqUpdater)) {
|
if (!isset($this->seqUpdater)) {
|
||||||
$this->seqUpdater = new SeqLoop($this);
|
$this->seqUpdater = new SeqLoop($this);
|
||||||
}
|
}
|
||||||
$this->seqUpdater->start();
|
|
||||||
|
|
||||||
$this->datacenter->__construct($this, $this->settings['connection'], $this->settings['connection_settings']);
|
$this->datacenter->__construct($this, $this->settings['connection'], $this->settings['connection_settings']);
|
||||||
$dcs = [];
|
$dcs = [];
|
||||||
@ -875,6 +876,18 @@ class MTProto extends AsyncConstruct implements TLCallback
|
|||||||
|
|
||||||
yield $this->get_phone_config_async();
|
yield $this->get_phone_config_async();
|
||||||
|
|
||||||
|
foreach ($this->channels_state->get() as $state) {
|
||||||
|
$channelId = $state->getChannel();
|
||||||
|
if (!isset($this->feeders[$channelId])) {
|
||||||
|
$this->feeders[$channelId] = new FeedLoop($this, $channelId);
|
||||||
|
}
|
||||||
|
if (!isset($this->updaters[$channelId])) {
|
||||||
|
$this->updaters[$channelId] = new UpdateLoop($this, $channelId);
|
||||||
|
}
|
||||||
|
$this->feeders[$channelId]->start();
|
||||||
|
$this->updaters[$channelId]->start();
|
||||||
|
}
|
||||||
|
$this->seqUpdater->start();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function get_phone_config_async($watcherId = null)
|
public function get_phone_config_async($watcherId = null)
|
||||||
|
@ -574,6 +574,7 @@ trait ResponseHandler
|
|||||||
switch ($updates['_']) {
|
switch ($updates['_']) {
|
||||||
case 'updates':
|
case 'updates':
|
||||||
case 'updatesCombined':
|
case 'updatesCombined':
|
||||||
|
$result = [];
|
||||||
foreach ($updates['updates'] as $key => $update) {
|
foreach ($updates['updates'] as $key => $update) {
|
||||||
if ($update['_'] === 'updateNewMessage' || $update['_'] === 'updateReadMessagesContents' ||
|
if ($update['_'] === 'updateNewMessage' || $update['_'] === 'updateReadMessagesContents' ||
|
||||||
$update['_'] === 'updateEditMessage' || $update['_'] === 'updateDeleteMessages' ||
|
$update['_'] === 'updateEditMessage' || $update['_'] === 'updateDeleteMessages' ||
|
||||||
|
Loading…
x
Reference in New Issue
Block a user