Asyncify (2nd pass)
This commit is contained in:
parent
66f84f4b05
commit
cacc792619
@ -403,7 +403,7 @@ class MTProto implements TLCallback
|
|||||||
}
|
}
|
||||||
if ($this->authorized === self::LOGGED_IN && $this->settings['updates']['handle_updates'] && !$this->updates_state['sync_loading']) {
|
if ($this->authorized === self::LOGGED_IN && $this->settings['updates']['handle_updates'] && !$this->updates_state['sync_loading']) {
|
||||||
$this->logger->logger(\danog\MadelineProto\Lang::$current_lang['getupdates_deserialization'], Logger::NOTICE);
|
$this->logger->logger(\danog\MadelineProto\Lang::$current_lang['getupdates_deserialization'], Logger::NOTICE);
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
}
|
}
|
||||||
$this->datacenter->sockets[$this->settings['connection_settings']['default_dc']]->updater->start();
|
$this->datacenter->sockets[$this->settings['connection_settings']['default_dc']]->updater->start();
|
||||||
}
|
}
|
||||||
@ -865,7 +865,7 @@ class MTProto implements TLCallback
|
|||||||
return $this->config;
|
return $this->config;
|
||||||
}
|
}
|
||||||
$this->config = empty($config) ? yield $this->method_call_async_read('help.getConfig', $config, empty($options) ? ['datacenter' => $this->settings['connection_settings']['default_dc']] : $options) : $config;
|
$this->config = empty($config) ? yield $this->method_call_async_read('help.getConfig', $config, empty($options) ? ['datacenter' => $this->settings['connection_settings']['default_dc']] : $options) : $config;
|
||||||
yield $this->parse_config();
|
yield $this->parse_config_async();
|
||||||
|
|
||||||
return $this->config;
|
return $this->config;
|
||||||
}
|
}
|
||||||
@ -893,7 +893,7 @@ class MTProto implements TLCallback
|
|||||||
public function parse_config_async()
|
public function parse_config_async()
|
||||||
{
|
{
|
||||||
if (isset($this->config['dc_options'])) {
|
if (isset($this->config['dc_options'])) {
|
||||||
yield $this->parse_dc_options($this->config['dc_options']);
|
yield $this->parse_dc_options_async($this->config['dc_options']);
|
||||||
unset($this->config['dc_options']);
|
unset($this->config['dc_options']);
|
||||||
}
|
}
|
||||||
$this->logger->logger(\danog\MadelineProto\Lang::$current_lang['config_updated'], Logger::NOTICE);
|
$this->logger->logger(\danog\MadelineProto\Lang::$current_lang['config_updated'], Logger::NOTICE);
|
||||||
|
@ -226,7 +226,7 @@ trait Files
|
|||||||
return $this->gen_all_file($constructor, $regenerate);
|
return $this->gen_all_file($constructor, $regenerate);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function get_download_info($message_media)
|
public function get_download_info_async($message_media)
|
||||||
{
|
{
|
||||||
if (is_string($message_media)) {
|
if (is_string($message_media)) {
|
||||||
$message_media = $this->unpack_file_id($message_media)['MessageMedia'];
|
$message_media = $this->unpack_file_id($message_media)['MessageMedia'];
|
||||||
@ -290,7 +290,7 @@ trait Files
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!isset($res['ext'])) {
|
if (!isset($res['ext'])) {
|
||||||
$res['ext'] = $this->get_extension_from_location($res['InputFileLocation'], $this->get_extension_from_mime(isset($res['mime']) ? $res['mime'] : 'image/jpeg'));
|
$res['ext'] = yield $this->get_extension_from_location_async($res['InputFileLocation'], $this->get_extension_from_mime(isset($res['mime']) ? $res['mime'] : 'image/jpeg'));
|
||||||
}
|
}
|
||||||
if (!isset($res['mime'])) {
|
if (!isset($res['mime'])) {
|
||||||
$res['mime'] = $this->get_mime_from_extension($res['ext'], 'image/jpeg');
|
$res['mime'] = $this->get_mime_from_extension($res['ext'], 'image/jpeg');
|
||||||
@ -348,7 +348,7 @@ trait Files
|
|||||||
case 'fileLocation':
|
case 'fileLocation':
|
||||||
$res['name'] = $message_media['volume_id'].'_'.$message_media['local_id'];
|
$res['name'] = $message_media['volume_id'].'_'.$message_media['local_id'];
|
||||||
$res['InputFileLocation'] = ['_' => 'inputFileLocation', 'volume_id' => $message_media['volume_id'], 'local_id' => $message_media['local_id'], 'secret' => $message_media['secret'], 'dc_id' => $message_media['dc_id'], 'file_reference' => $this->wait($this->referenceDatabase->getReference(ReferenceDatabase::PHOTO_LOCATION_LOCATION, $message_media))];
|
$res['InputFileLocation'] = ['_' => 'inputFileLocation', 'volume_id' => $message_media['volume_id'], 'local_id' => $message_media['local_id'], 'secret' => $message_media['secret'], 'dc_id' => $message_media['dc_id'], 'file_reference' => $this->wait($this->referenceDatabase->getReference(ReferenceDatabase::PHOTO_LOCATION_LOCATION, $message_media))];
|
||||||
$res['ext'] = $this->get_extension_from_location($res['InputFileLocation'], '.jpg');
|
$res['ext'] = yield $this->get_extension_from_location_async($res['InputFileLocation'], '.jpg');
|
||||||
$res['mime'] = $this->get_mime_from_extension($res['ext'], 'image/jpeg');
|
$res['mime'] = $this->get_mime_from_extension($res['ext'], 'image/jpeg');
|
||||||
|
|
||||||
return $res;
|
return $res;
|
||||||
@ -382,7 +382,7 @@ trait Files
|
|||||||
}
|
}
|
||||||
$res['InputFileLocation'] = ['_' => 'inputDocumentFileLocation', 'id' => $message_media['document']['id'], 'access_hash' => $message_media['document']['access_hash'], 'version' => isset($message_media['document']['version']) ? $message_media['document']['version'] : 0, 'dc_id' => $message_media['document']['dc_id'], 'file_reference' => $this->wait($this->referenceDatabase->getReference(ReferenceDatabase::DOCUMENT_LOCATION_LOCATION, $message_media['document']))];
|
$res['InputFileLocation'] = ['_' => 'inputDocumentFileLocation', 'id' => $message_media['document']['id'], 'access_hash' => $message_media['document']['access_hash'], 'version' => isset($message_media['document']['version']) ? $message_media['document']['version'] : 0, 'dc_id' => $message_media['document']['dc_id'], 'file_reference' => $this->wait($this->referenceDatabase->getReference(ReferenceDatabase::DOCUMENT_LOCATION_LOCATION, $message_media['document']))];
|
||||||
if (!isset($res['ext'])) {
|
if (!isset($res['ext'])) {
|
||||||
$res['ext'] = $this->get_extension_from_location($res['InputFileLocation'], $this->get_extension_from_mime($message_media['document']['mime_type']));
|
$res['ext'] = yield $this->get_extension_from_location_async($res['InputFileLocation'], $this->get_extension_from_mime($message_media['document']['mime_type']));
|
||||||
}
|
}
|
||||||
if (!isset($res['name'])) {
|
if (!isset($res['name'])) {
|
||||||
$res['name'] = $message_media['document']['access_hash'];
|
$res['name'] = $message_media['document']['access_hash'];
|
||||||
@ -411,7 +411,7 @@ trait Files
|
|||||||
return $this->download_to_file($message_media, $dir.'/'.$message_media['name'].$message_media['ext'], $cb);
|
return $this->download_to_file($message_media, $dir.'/'.$message_media['name'].$message_media['ext'], $cb);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function download_to_file($message_media, $file, $cb = null)
|
public function download_to_file_async($message_media, $file, $cb = null)
|
||||||
{
|
{
|
||||||
if (is_object($file) && class_implements($file)['danog\MadelineProto\FileCallbackInterface']) {
|
if (is_object($file) && class_implements($file)['danog\MadelineProto\FileCallbackInterface']) {
|
||||||
$cb = $file;
|
$cb = $file;
|
||||||
@ -429,7 +429,7 @@ trait Files
|
|||||||
flock($stream, LOCK_EX);
|
flock($stream, LOCK_EX);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$this->download_to_stream($message_media, $stream, $cb, $size, -1);
|
yield $this->download_to_stream_async($message_media, $stream, $cb, $size, -1);
|
||||||
} finally {
|
} finally {
|
||||||
flock($stream, LOCK_UN);
|
flock($stream, LOCK_UN);
|
||||||
fclose($stream);
|
fclose($stream);
|
||||||
|
@ -90,7 +90,7 @@ trait PeerHandler
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function add_chat($chat)
|
public function add_chat_async($chat)
|
||||||
{
|
{
|
||||||
switch ($chat['_']) {
|
switch ($chat['_']) {
|
||||||
case 'chat':
|
case 'chat':
|
||||||
@ -126,7 +126,7 @@ trait PeerHandler
|
|||||||
|
|
||||||
$this->chats[$bot_api_id] = $chat;
|
$this->chats[$bot_api_id] = $chat;
|
||||||
|
|
||||||
if ($this->settings['peer']['full_fetch'] && (!isset($this->full_chats[$bot_api_id]) || $this->full_chats[$bot_api_id]['full']['participants_count'] !== $this->get_full_info($bot_api_id)['full']['participants_count'])) {
|
if ($this->settings['peer']['full_fetch'] && (!isset($this->full_chats[$bot_api_id]) || $this->full_chats[$bot_api_id]['full']['participants_count'] !== yield $this->get_full_info_async($bot_api_id)['full']['participants_count'])) {
|
||||||
$this->cache_pwr_chat($bot_api_id, $this->settings['peer']['full_fetch'], true);
|
$this->cache_pwr_chat($bot_api_id, $this->settings['peer']['full_fetch'], true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -150,10 +150,10 @@ trait PeerHandler
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public function peer_isset($id)
|
public function peer_isset_async($id)
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
return isset($this->chats[$this->get_info($id)['bot_api_id']]);
|
return isset($this->chats[yield $this->get_info_async($id)['bot_api_id']]);
|
||||||
} catch (\danog\MadelineProto\Exception $e) {
|
} catch (\danog\MadelineProto\Exception $e) {
|
||||||
return false;
|
return false;
|
||||||
} catch (\danog\MadelineProto\RPCErrorException $e) {
|
} catch (\danog\MadelineProto\RPCErrorException $e) {
|
||||||
@ -384,9 +384,9 @@ trait PeerHandler
|
|||||||
if (!isset($this->settings['pwr']['requests']) || $this->settings['pwr']['requests'] === true && $recursive) {
|
if (!isset($this->settings['pwr']['requests']) || $this->settings['pwr']['requests'] === true && $recursive) {
|
||||||
$dbres = json_decode(@file_get_contents('https://id.pwrtelegram.xyz/db/getusername?id='.$id, false, stream_context_create(['http' => ['timeout' => 2]])), true);
|
$dbres = json_decode(@file_get_contents('https://id.pwrtelegram.xyz/db/getusername?id='.$id, false, stream_context_create(['http' => ['timeout' => 2]])), true);
|
||||||
if (isset($dbres['ok']) && $dbres['ok']) {
|
if (isset($dbres['ok']) && $dbres['ok']) {
|
||||||
$this->resolve_username('@'.$dbres['result']);
|
yield $this->resolve_username_async('@'.$dbres['result']);
|
||||||
|
|
||||||
return $this->get_info($id, false);
|
return yield $this->get_info_async($id, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ($tried_simple && isset($this->caching_possible_username[$id])) {
|
if ($tried_simple && isset($this->caching_possible_username[$id])) {
|
||||||
@ -394,7 +394,7 @@ trait PeerHandler
|
|||||||
|
|
||||||
$user = $this->caching_possible_username[$id];
|
$user = $this->caching_possible_username[$id];
|
||||||
unset($this->caching_possible_username[$id]);
|
unset($this->caching_possible_username[$id]);
|
||||||
return $this->get_info($user);
|
return yield $this->get_info_async($user);
|
||||||
}
|
}
|
||||||
throw new \danog\MadelineProto\Exception('This peer is not present in the internal peer database');
|
throw new \danog\MadelineProto\Exception('This peer is not present in the internal peer database');
|
||||||
}
|
}
|
||||||
@ -404,7 +404,7 @@ trait PeerHandler
|
|||||||
} else {
|
} else {
|
||||||
$invite = yield $this->method_call_async_read('messages.checkChatInvite', ['hash' => $matches[2]], ['datacenter' => $this->datacenter->curdc]);
|
$invite = yield $this->method_call_async_read('messages.checkChatInvite', ['hash' => $matches[2]], ['datacenter' => $this->datacenter->curdc]);
|
||||||
if (isset($invite['chat'])) {
|
if (isset($invite['chat'])) {
|
||||||
return $this->get_info($invite['chat']);
|
return yield $this->get_info_async($invite['chat']);
|
||||||
} else {
|
} else {
|
||||||
throw new \danog\MadelineProto\Exception('You have not joined this chat');
|
throw new \danog\MadelineProto\Exception('You have not joined this chat');
|
||||||
}
|
}
|
||||||
@ -412,14 +412,14 @@ trait PeerHandler
|
|||||||
}
|
}
|
||||||
$id = strtolower(str_replace('@', '', $id));
|
$id = strtolower(str_replace('@', '', $id));
|
||||||
if ($id === 'me') {
|
if ($id === 'me') {
|
||||||
return $this->get_info($this->authorization['user']['id']);
|
return yield $this->get_info_async($this->authorization['user']['id']);
|
||||||
}
|
}
|
||||||
if ($id === 'support') {
|
if ($id === 'support') {
|
||||||
if (!$this->supportUser) {
|
if (!$this->supportUser) {
|
||||||
yield $this->method_call_async_read('help.getSupport', [], ['datacenter' => $this->settings['connection_settings']['default_dc']]);
|
yield $this->method_call_async_read('help.getSupport', [], ['datacenter' => $this->settings['connection_settings']['default_dc']]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->get_info($this->supportUser);
|
return yield $this->get_info_async($this->supportUser);
|
||||||
}
|
}
|
||||||
foreach ($this->chats as $chat) {
|
foreach ($this->chats as $chat) {
|
||||||
if (isset($chat['username']) && strtolower($chat['username']) === $id) {
|
if (isset($chat['username']) && strtolower($chat['username']) === $id) {
|
||||||
@ -427,9 +427,9 @@ trait PeerHandler
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ($recursive) {
|
if ($recursive) {
|
||||||
$this->resolve_username($id);
|
yield $this->resolve_username_async($id);
|
||||||
|
|
||||||
return $this->get_info($id, false);
|
return yield $this->get_info_async($id, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new \danog\MadelineProto\Exception('This peer is not present in the internal peer database');
|
throw new \danog\MadelineProto\Exception('This peer is not present in the internal peer database');
|
||||||
@ -501,7 +501,7 @@ trait PeerHandler
|
|||||||
|
|
||||||
public function get_full_info_async($id)
|
public function get_full_info_async($id)
|
||||||
{
|
{
|
||||||
$partial = $this->get_info($id);
|
$partial = yield $this->get_info_async($id);
|
||||||
if (time() - $this->full_chat_last_updated($partial['bot_api_id']) < (isset($this->settings['peer']['full_info_cache_time']) ? $this->settings['peer']['full_info_cache_time'] : 0)) {
|
if (time() - $this->full_chat_last_updated($partial['bot_api_id']) < (isset($this->settings['peer']['full_info_cache_time']) ? $this->settings['peer']['full_info_cache_time'] : 0)) {
|
||||||
return array_merge($partial, $this->full_chats[$partial['bot_api_id']]);
|
return array_merge($partial, $this->full_chats[$partial['bot_api_id']]);
|
||||||
}
|
}
|
||||||
@ -524,14 +524,14 @@ trait PeerHandler
|
|||||||
$res['last_update'] = time();
|
$res['last_update'] = time();
|
||||||
$this->full_chats[$partial['bot_api_id']] = $res;
|
$this->full_chats[$partial['bot_api_id']] = $res;
|
||||||
|
|
||||||
$partial = $this->get_info($id);
|
$partial = yield $this->get_info_async($id);
|
||||||
|
|
||||||
return array_merge($partial, $res);
|
return array_merge($partial, $res);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function get_pwr_chat($id, $fullfetch = true, $send = true)
|
public function get_pwr_chat_async($id, $fullfetch = true, $send = true)
|
||||||
{
|
{
|
||||||
$full = $fullfetch ? $this->get_full_info($id) : $this->get_info($id);
|
$full = $fullfetch ? yield $this->get_full_info_async($id) : yield $this->get_info_async($id);
|
||||||
$res = ['id' => $full['bot_api_id'], 'type' => $full['type']];
|
$res = ['id' => $full['bot_api_id'], 'type' => $full['type']];
|
||||||
switch ($full['type']) {
|
switch ($full['type']) {
|
||||||
case 'user':
|
case 'user':
|
||||||
@ -547,19 +547,8 @@ trait PeerHandler
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (isset($full['full']['profile_photo']['sizes'])) {
|
if (isset($full['full']['profile_photo']['sizes'])) {
|
||||||
$res['photo'] = $this->photosize_to_botapi(end($full['full']['profile_photo']['sizes']), $full['full']['profile_photo']);
|
$res['photo'] = yield $this->photosize_to_botapi_async(end($full['full']['profile_photo']['sizes']), $full['full']['profile_photo']);
|
||||||
}
|
}
|
||||||
/*$bio = '';
|
|
||||||
if ($full['type'] === 'user' && isset($res['username']) && !isset($res['about']) && $fullfetch) {
|
|
||||||
if (preg_match('/meta property="og:description" content=".+/', file_get_contents('https://telegram.me/'.$res['username']), $biores)) {
|
|
||||||
$bio = html_entity_decode(preg_replace_callback('/(&#[0-9]+;)/', function ($m) {
|
|
||||||
return mb_convert_encoding($m[1], 'UTF-8', 'HTML-ENTITIES');
|
|
||||||
}, str_replace(['meta property="og:description" content="', '">'], '', $biores[0])));
|
|
||||||
}
|
|
||||||
if ($bio != '' && $bio != 'You can contact @'.$res['username'].' right away.') {
|
|
||||||
$res['about'] = $bio;
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
break;
|
break;
|
||||||
case 'chat':
|
case 'chat':
|
||||||
foreach (['title', 'participants_count', 'admin', 'admins_enabled'] as $key) {
|
foreach (['title', 'participants_count', 'admin', 'admins_enabled'] as $key) {
|
||||||
@ -576,7 +565,7 @@ trait PeerHandler
|
|||||||
$res['all_members_are_administrators'] = !$res['admins_enabled'];
|
$res['all_members_are_administrators'] = !$res['admins_enabled'];
|
||||||
}
|
}
|
||||||
if (isset($full['full']['chat_photo']['sizes'])) {
|
if (isset($full['full']['chat_photo']['sizes'])) {
|
||||||
$res['photo'] = $this->photosize_to_botapi(end($full['full']['chat_photo']['sizes']), $full['full']['chat_photo']);
|
$res['photo'] = yield $this->photosize_to_botapi_async(end($full['full']['chat_photo']['sizes']), $full['full']['chat_photo']);
|
||||||
}
|
}
|
||||||
if (isset($full['full']['exported_invite']['link'])) {
|
if (isset($full['full']['exported_invite']['link'])) {
|
||||||
$res['invite'] = $full['full']['exported_invite']['link'];
|
$res['invite'] = $full['full']['exported_invite']['link'];
|
||||||
@ -598,7 +587,7 @@ trait PeerHandler
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (isset($full['full']['chat_photo']['sizes'])) {
|
if (isset($full['full']['chat_photo']['sizes'])) {
|
||||||
$res['photo'] = $this->photosize_to_botapi(end($full['full']['chat_photo']['sizes']), $full['full']['chat_photo']);
|
$res['photo'] = yield $this->photosize_to_botapi_async(end($full['full']['chat_photo']['sizes']), $full['full']['chat_photo']);
|
||||||
}
|
}
|
||||||
if (isset($full['full']['exported_invite']['link'])) {
|
if (isset($full['full']['exported_invite']['link'])) {
|
||||||
$res['invite'] = $full['full']['exported_invite']['link'];
|
$res['invite'] = $full['full']['exported_invite']['link'];
|
||||||
@ -656,7 +645,7 @@ trait PeerHandler
|
|||||||
$limit = 200;
|
$limit = 200;
|
||||||
$filters = ['channelParticipantsAdmins', 'channelParticipantsBots'];
|
$filters = ['channelParticipantsAdmins', 'channelParticipantsBots'];
|
||||||
foreach ($filters as $filter) {
|
foreach ($filters as $filter) {
|
||||||
$this->fetch_participants($full['InputChannel'], $filter, '', $total_count, $res);
|
yield $this->fetch_participants_async($full['InputChannel'], $filter, '', $total_count, $res);
|
||||||
}
|
}
|
||||||
$q = '';
|
$q = '';
|
||||||
|
|
||||||
@ -677,9 +666,9 @@ trait PeerHandler
|
|||||||
return $res;
|
return $res;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function recurse_alphabet_search_participants($channel, $filter, $q, $total_count, &$res)
|
public function recurse_alphabet_search_participants_async($channel, $filter, $q, $total_count, &$res)
|
||||||
{
|
{
|
||||||
if (!$this->fetch_participants($channel, $filter, $q, $total_count, $res)) {
|
if (!yield $this->fetch_participants_async($channel, $filter, $q, $total_count, $res)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -552,17 +552,19 @@ trait ResponseHandler
|
|||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
$botAPI = isset($request['botAPI']) && $request['botAPI'];
|
||||||
if (isset($request['botAPI']) && $request['botAPI']) {
|
|
||||||
$response = $this->MTProto_to_botAPI($response);
|
|
||||||
}
|
|
||||||
unset($request);
|
unset($request);
|
||||||
$this->got_response_for_outgoing_message_id($request_id, $datacenter);
|
$this->got_response_for_outgoing_message_id($request_id, $datacenter);
|
||||||
Loop::defer(function () use ($request_id, $response, $datacenter) {
|
Loop::defer(function () use ($request_id, $response, $datacenter, $botAPI) {
|
||||||
|
$this->call((function ()use ($request_id, $response, $datacenter, $botAPI) {
|
||||||
$r = isset($response['_']) ? $response['_'] : json_encode($response);
|
$r = isset($response['_']) ? $response['_'] : json_encode($response);
|
||||||
$this->logger->logger("Deferred: sent $r to deferred");
|
$this->logger->logger("Deferred: sent $r to deferred");
|
||||||
|
if ($botAPI) {
|
||||||
|
$response = yield $this->MTProto_to_botAPI_async($response);
|
||||||
|
}
|
||||||
$this->datacenter->sockets[$datacenter]->outgoing_messages[$request_id]['promise']->resolve($response);
|
$this->datacenter->sockets[$datacenter]->outgoing_messages[$request_id]['promise']->resolve($response);
|
||||||
unset($this->datacenter->sockets[$datacenter]->outgoing_messages[$request_id]['promise']);
|
unset($this->datacenter->sockets[$datacenter]->outgoing_messages[$request_id]['promise']);
|
||||||
|
})());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -583,7 +585,7 @@ trait ResponseHandler
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function handle_updates($updates, $actual_updates = null)
|
public function handle_updates_async($updates, $actual_updates = null)
|
||||||
{
|
{
|
||||||
if (!$this->settings['updates']['handle_updates']) {
|
if (!$this->settings['updates']['handle_updates']) {
|
||||||
return;
|
return;
|
||||||
@ -627,14 +629,14 @@ trait ResponseHandler
|
|||||||
$to_id = isset($updates['chat_id']) ? -$updates['chat_id'] : ($updates['out'] ? $updates['user_id'] : $this->authorization['user']['id']);
|
$to_id = isset($updates['chat_id']) ? -$updates['chat_id'] : ($updates['out'] ? $updates['user_id'] : $this->authorization['user']['id']);
|
||||||
if (!$this->peer_isset($from_id) || !$this->peer_isset($to_id) || isset($updates['via_bot_id']) && !$this->peer_isset($updates['via_bot_id']) || isset($updates['entities']) && !$this->entities_peer_isset($updates['entities']) || isset($updates['fwd_from']) && !$this->fwd_peer_isset($updates['fwd_from'])) {
|
if (!$this->peer_isset($from_id) || !$this->peer_isset($to_id) || isset($updates['via_bot_id']) && !$this->peer_isset($updates['via_bot_id']) || isset($updates['entities']) && !$this->entities_peer_isset($updates['entities']) || isset($updates['fwd_from']) && !$this->fwd_peer_isset($updates['fwd_from'])) {
|
||||||
$this->logger->logger('getDifference: good - getting user for updateShortMessage', \danog\MadelineProto\Logger::VERBOSE);
|
$this->logger->logger('getDifference: good - getting user for updateShortMessage', \danog\MadelineProto\Logger::VERBOSE);
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
}
|
}
|
||||||
$message = $updates;
|
$message = $updates;
|
||||||
$message['_'] = 'message';
|
$message['_'] = 'message';
|
||||||
$message['from_id'] = $from_id;
|
$message['from_id'] = $from_id;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$message['to_id'] = $this->get_info($to_id)['Peer'];
|
$message['to_id'] = yield $this->get_info_async($to_id)['Peer'];
|
||||||
} catch (\danog\MadelineProto\Exception $e) {
|
} catch (\danog\MadelineProto\Exception $e) {
|
||||||
$this->logger->logger('Still did not get user in database, postponing update', \danog\MadelineProto\Logger::ERROR);
|
$this->logger->logger('Still did not get user in database, postponing update', \danog\MadelineProto\Logger::ERROR);
|
||||||
//$this->pending_updates[] = $updates;
|
//$this->pending_updates[] = $updates;
|
||||||
@ -651,7 +653,7 @@ trait ResponseHandler
|
|||||||
//$this->set_update_state(['date' => $updates['date']]);
|
//$this->set_update_state(['date' => $updates['date']]);
|
||||||
break;
|
break;
|
||||||
case 'updatesTooLong':
|
case 'updatesTooLong':
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
throw new \danog\MadelineProto\ResponseException('Unrecognized update received: '.var_export($updates, true));
|
throw new \danog\MadelineProto\ResponseException('Unrecognized update received: '.var_export($updates, true));
|
||||||
|
@ -150,7 +150,7 @@ trait UpdateHandler
|
|||||||
$this->postpone_updates = true;
|
$this->postpone_updates = true;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$input = $this->get_info('channel#'.$channel);
|
$input = yield $this->get_info_async('channel#'.$channel);
|
||||||
if (!isset($input['InputChannel'])) {
|
if (!isset($input['InputChannel'])) {
|
||||||
throw new \danog\MadelineProto\Exception('This peer is not present in the internal peer database');
|
throw new \danog\MadelineProto\Exception('This peer is not present in the internal peer database');
|
||||||
}
|
}
|
||||||
@ -179,7 +179,7 @@ trait UpdateHandler
|
|||||||
$this->logger->logger($e->getMessage());
|
$this->logger->logger($e->getMessage());
|
||||||
unset($this->channels_state[$channel]);
|
unset($this->channels_state[$channel]);
|
||||||
|
|
||||||
return false; //$this->get_channel_difference($channel);
|
return false; //yield $this->get_channel_difference_async($channel);
|
||||||
} finally {
|
} finally {
|
||||||
$this->postpone_updates = false;
|
$this->postpone_updates = false;
|
||||||
$this->load_channel_state($channel)['sync_loading'] = false;
|
$this->load_channel_state($channel)['sync_loading'] = false;
|
||||||
@ -204,7 +204,7 @@ trait UpdateHandler
|
|||||||
}
|
}
|
||||||
if (!$difference['final']) {
|
if (!$difference['final']) {
|
||||||
unset($difference);
|
unset($difference);
|
||||||
$this->get_channel_difference($channel);
|
yield $this->get_channel_difference_async($channel);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'updates.channelDifferenceTooLong':
|
case 'updates.channelDifferenceTooLong':
|
||||||
@ -220,7 +220,7 @@ trait UpdateHandler
|
|||||||
$this->postpone_updates = false;
|
$this->postpone_updates = false;
|
||||||
$this->load_channel_state($channel)['sync_loading'] = false;
|
$this->load_channel_state($channel)['sync_loading'] = false;
|
||||||
}
|
}
|
||||||
$this->get_channel_difference($channel);
|
yield $this->get_channel_difference_async($channel);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
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));
|
||||||
@ -229,7 +229,7 @@ trait UpdateHandler
|
|||||||
$this->handle_pending_updates();
|
$this->handle_pending_updates();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function set_update_state($data)
|
public function set_update_state_async($data)
|
||||||
{
|
{
|
||||||
if (isset($data['pts']) && $data['pts'] !== 0) {
|
if (isset($data['pts']) && $data['pts'] !== 0) {
|
||||||
$this->load_update_state()['pts'] = $data['pts'];
|
$this->load_update_state()['pts'] = $data['pts'];
|
||||||
@ -244,7 +244,7 @@ trait UpdateHandler
|
|||||||
$this->load_update_state()['date'] = $data['date'];
|
$this->load_update_state()['date'] = $data['date'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public function reset_update_state()
|
public function reset_update_state_async()
|
||||||
{
|
{
|
||||||
$this->load_update_state()['pts'] = 1;
|
$this->load_update_state()['pts'] = 1;
|
||||||
$this->load_update_state()['qts'] = 0;
|
$this->load_update_state()['qts'] = 0;
|
||||||
@ -255,14 +255,14 @@ trait UpdateHandler
|
|||||||
}
|
}
|
||||||
$this->msg_ids = [];
|
$this->msg_ids = [];
|
||||||
}
|
}
|
||||||
public function &load_update_state()
|
public function &load_update_state_async()
|
||||||
{
|
{
|
||||||
if (!isset($this->updates_state['qts'])) {
|
if (!isset($this->updates_state['qts'])) {
|
||||||
$this->updates_state['qts'] = 0;
|
$this->updates_state['qts'] = 0;
|
||||||
}
|
}
|
||||||
if (!$this->got_state) {
|
if (!$this->got_state) {
|
||||||
$this->got_state = true;
|
$this->got_state = true;
|
||||||
$this->set_update_state($this->get_updates_state());
|
$this->set_update_state(yield $this->get_updates_state_async());
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->updates_state;
|
return $this->updates_state;
|
||||||
@ -319,7 +319,7 @@ trait UpdateHandler
|
|||||||
$this->set_update_state($difference['intermediate_state']);
|
$this->set_update_state($difference['intermediate_state']);
|
||||||
unset($difference);
|
unset($difference);
|
||||||
$this->updates_state['sync_loading'] = false;
|
$this->updates_state['sync_loading'] = false;
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
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));
|
||||||
@ -356,7 +356,7 @@ trait UpdateHandler
|
|||||||
return $data;
|
return $data;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function handle_update($update, $options = [])
|
public function handle_update_async($update, $options = [])
|
||||||
{
|
{
|
||||||
if (!$this->settings['updates']['handle_updates']) {
|
if (!$this->settings['updates']['handle_updates']) {
|
||||||
return;
|
return;
|
||||||
@ -400,7 +400,7 @@ trait UpdateHandler
|
|||||||
}*/
|
}*/
|
||||||
switch ($update['_']) {
|
switch ($update['_']) {
|
||||||
case 'updateChannelTooLong':
|
case 'updateChannelTooLong':
|
||||||
$this->get_channel_difference($channel_id);
|
yield $this->get_channel_difference_async($channel_id);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
case 'updateNewMessage':
|
case 'updateNewMessage':
|
||||||
@ -424,9 +424,9 @@ trait UpdateHandler
|
|||||||
if ($entities) $log .= "entities ".json_encode($update['message']['entities']).", ";
|
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);
|
$this->logger->logger("Not enough data: for message update $log, getting difference...", \danog\MadelineProto\Logger::VERBOSE);
|
||||||
if ($channel_id !== false && $this->peer_isset($this->to_supergroup($channel_id))) {
|
if ($channel_id !== false && $this->peer_isset($this->to_supergroup($channel_id))) {
|
||||||
$this->get_channel_difference($channel_id);
|
yield $this->get_channel_difference_async($channel_id);
|
||||||
} else {
|
} else {
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
@ -456,9 +456,9 @@ trait UpdateHandler
|
|||||||
if ($cur_state['pts'] + (isset($update['pts_count']) ? $update['pts_count'] : 0) !== $update['pts']) {
|
if ($cur_state['pts'] + (isset($update['pts_count']) ? $update['pts_count'] : 0) !== $update['pts']) {
|
||||||
$logger("PTS hole");
|
$logger("PTS hole");
|
||||||
if ($channel_id !== false && $this->peer_isset($this->to_supergroup($channel_id))) {
|
if ($channel_id !== false && $this->peer_isset($this->to_supergroup($channel_id))) {
|
||||||
$this->get_channel_difference($channel_id);
|
yield $this->get_channel_difference_async($channel_id);
|
||||||
} else {
|
} else {
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
@ -483,7 +483,7 @@ trait UpdateHandler
|
|||||||
$seq_start = isset($options['seq_start']) ? $options['seq_start'] : $options['seq'];
|
$seq_start = isset($options['seq_start']) ? $options['seq_start'] : $options['seq'];
|
||||||
if ($seq_start != $cur_state['seq'] + 1 && $seq_start > $cur_state['seq']) {
|
if ($seq_start != $cur_state['seq'] + 1 && $seq_start > $cur_state['seq']) {
|
||||||
$this->logger->logger('Seq hole. seq_start: '.$seq_start.' != cur seq: '.$cur_state['seq'].' + 1', \danog\MadelineProto\Logger::ERROR);
|
$this->logger->logger('Seq hole. seq_start: '.$seq_start.' != cur seq: '.$cur_state['seq'].' + 1', \danog\MadelineProto\Logger::ERROR);
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -494,7 +494,7 @@ trait UpdateHandler
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$this->save_update($update);
|
yield $this->save_update_async($update);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function handle_multiple_update($updates, $options = [], $channel = false)
|
public function handle_multiple_update($updates, $options = [], $channel = false)
|
||||||
@ -532,11 +532,11 @@ trait UpdateHandler
|
|||||||
if (in_array($update['_'], ['updateUserName', 'updateUserPhone', 'updateUserBlocked', 'updateUserPhoto', 'updateContactRegistered', 'updateContactLink'])) {
|
if (in_array($update['_'], ['updateUserName', 'updateUserPhone', 'updateUserBlocked', 'updateUserPhoto', 'updateContactRegistered', 'updateContactLink'])) {
|
||||||
$id = $this->get_id($update);
|
$id = $this->get_id($update);
|
||||||
$this->full_chats[$id]['last_update'] = 0;
|
$this->full_chats[$id]['last_update'] = 0;
|
||||||
$this->get_full_info($id);
|
yield $this->get_full_info_async($id);
|
||||||
}
|
}
|
||||||
if ($update['_'] === 'updateDcOptions') {
|
if ($update['_'] === 'updateDcOptions') {
|
||||||
$this->logger->logger('Got new dc options', \danog\MadelineProto\Logger::VERBOSE);
|
$this->logger->logger('Got new dc options', \danog\MadelineProto\Logger::VERBOSE);
|
||||||
$this->parse_dc_options($update['dc_options']);
|
yield $this->parse_dc_options_async($update['dc_options']);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -557,13 +557,13 @@ trait UpdateHandler
|
|||||||
$update['phone_call'] = $this->calls[$update['phone_call']['id']] = $controller;
|
$update['phone_call'] = $this->calls[$update['phone_call']['id']] = $controller;
|
||||||
break;
|
break;
|
||||||
case 'phoneCallAccepted':
|
case 'phoneCallAccepted':
|
||||||
if (!$this->confirm_call($update['phone_call'])) {
|
if (!yield $this->confirm_call_async($update['phone_call'])) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$update['phone_call'] = $this->calls[$update['phone_call']['id']];
|
$update['phone_call'] = $this->calls[$update['phone_call']['id']];
|
||||||
break;
|
break;
|
||||||
case 'phoneCall':
|
case 'phoneCall':
|
||||||
if (!$this->complete_call($update['phone_call'])) {
|
if (!yield $this->complete_call_async($update['phone_call'])) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$update['phone_call'] = $this->calls[$update['phone_call']['id']];
|
$update['phone_call'] = $this->calls[$update['phone_call']['id']];
|
||||||
@ -588,7 +588,7 @@ trait UpdateHandler
|
|||||||
}
|
}
|
||||||
if ($update['qts'] > $cur_state['qts'] + 1) {
|
if ($update['qts'] > $cur_state['qts'] + 1) {
|
||||||
$this->logger->logger('Qts hole. Fetching updates manually: update qts: '.$update['qts'].' > current qts '.$cur_state['qts'].'+1, chat id: '.$update['message']['chat_id'], \danog\MadelineProto\Logger::ERROR);
|
$this->logger->logger('Qts hole. Fetching updates manually: update qts: '.$update['qts'].' > current qts '.$cur_state['qts'].'+1, chat id: '.$update['message']['chat_id'], \danog\MadelineProto\Logger::ERROR);
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -610,7 +610,7 @@ trait UpdateHandler
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$this->logger->logger('Accepting secret chat '.$update['chat']['id'], \danog\MadelineProto\Logger::NOTICE);
|
$this->logger->logger('Accepting secret chat '.$update['chat']['id'], \danog\MadelineProto\Logger::NOTICE);
|
||||||
$this->accept_secret_chat($update['chat']);
|
yield $this->accept_secret_chat_async($update['chat']);
|
||||||
break;
|
break;
|
||||||
case 'encryptedChatDiscarded':
|
case 'encryptedChatDiscarded':
|
||||||
$this->logger->logger('Deleting secret chat '.$update['chat']['id'].' because it was revoked by the other user', \danog\MadelineProto\Logger::NOTICE);
|
$this->logger->logger('Deleting secret chat '.$update['chat']['id'].' because it was revoked by the other user', \danog\MadelineProto\Logger::NOTICE);
|
||||||
@ -627,7 +627,7 @@ trait UpdateHandler
|
|||||||
break;
|
break;
|
||||||
case 'encryptedChat':
|
case 'encryptedChat':
|
||||||
$this->logger->logger('Completing creation of secret chat '.$update['chat']['id'], \danog\MadelineProto\Logger::NOTICE);
|
$this->logger->logger('Completing creation of secret chat '.$update['chat']['id'], \danog\MadelineProto\Logger::NOTICE);
|
||||||
$this->complete_secret_chat($update['chat']);
|
yield $this->complete_secret_chat_async($update['chat']);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
//$this->logger->logger($update, \danog\MadelineProto\Logger::NOTICE);
|
//$this->logger->logger($update, \danog\MadelineProto\Logger::NOTICE);
|
||||||
|
@ -59,7 +59,7 @@ trait AuthKeyHandler
|
|||||||
|
|
||||||
public function request_secret_chat_async($user)
|
public function request_secret_chat_async($user)
|
||||||
{
|
{
|
||||||
$user = $this->get_info($user);
|
$user = yield $this->get_info_async($user);
|
||||||
if (!isset($user['InputUser'])) {
|
if (!isset($user['InputUser'])) {
|
||||||
throw new \danog\MadelineProto\Exception('This peer is not present in the internal peer database');
|
throw new \danog\MadelineProto\Exception('This peer is not present in the internal peer database');
|
||||||
}
|
}
|
||||||
@ -74,7 +74,7 @@ trait AuthKeyHandler
|
|||||||
$res = yield $this->method_call_async_read('messages.requestEncryption', ['user_id' => $user, 'g_a' => $g_a->toBytes()], ['datacenter' => $this->datacenter->curdc]);
|
$res = yield $this->method_call_async_read('messages.requestEncryption', ['user_id' => $user, 'g_a' => $g_a->toBytes()], ['datacenter' => $this->datacenter->curdc]);
|
||||||
$this->temp_requested_secret_chats[$res['id']] = $a;
|
$this->temp_requested_secret_chats[$res['id']] = $a;
|
||||||
$this->handle_pending_updates();
|
$this->handle_pending_updates();
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
$this->logger->logger('Secret chat '.$res['id'].' requested successfully!', \danog\MadelineProto\Logger::NOTICE);
|
$this->logger->logger('Secret chat '.$res['id'].' requested successfully!', \danog\MadelineProto\Logger::NOTICE);
|
||||||
|
|
||||||
return $res['id'];
|
return $res['id'];
|
||||||
@ -96,7 +96,7 @@ trait AuthKeyHandler
|
|||||||
$key['fingerprint'] = substr(sha1($key['auth_key'], true), -8);
|
$key['fingerprint'] = substr(sha1($key['auth_key'], true), -8);
|
||||||
//$this->logger->logger($key);
|
//$this->logger->logger($key);
|
||||||
if ($key['fingerprint'] !== $params['key_fingerprint']) {
|
if ($key['fingerprint'] !== $params['key_fingerprint']) {
|
||||||
$this->discard_secret_chat($params['id']);
|
yield $this->discard_secret_chat_async($params['id']);
|
||||||
|
|
||||||
throw new \danog\MadelineProto\SecurityException('Invalid key fingerprint!');
|
throw new \danog\MadelineProto\SecurityException('Invalid key fingerprint!');
|
||||||
}
|
}
|
||||||
@ -136,7 +136,7 @@ trait AuthKeyHandler
|
|||||||
$this->secret_chats[$chat]['rekeying'] = [1, $e];
|
$this->secret_chats[$chat]['rekeying'] = [1, $e];
|
||||||
yield $this->method_call_async_read('messages.sendEncryptedService', ['peer' => $chat, 'message' => ['_' => 'decryptedMessageService', 'action' => ['_' => 'decryptedMessageActionRequestKey', 'g_a' => $g_a->toBytes(), 'exchange_id' => $e]]], ['datacenter' => $this->datacenter->curdc]);
|
yield $this->method_call_async_read('messages.sendEncryptedService', ['peer' => $chat, 'message' => ['_' => 'decryptedMessageService', 'action' => ['_' => 'decryptedMessageActionRequestKey', 'g_a' => $g_a->toBytes(), 'exchange_id' => $e]]], ['datacenter' => $this->datacenter->curdc]);
|
||||||
$this->handle_pending_updates();
|
$this->handle_pending_updates();
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
|
|
||||||
return $e;
|
return $e;
|
||||||
}
|
}
|
||||||
@ -172,7 +172,7 @@ trait AuthKeyHandler
|
|||||||
$this->check_G($g_b, $dh_config['p']);
|
$this->check_G($g_b, $dh_config['p']);
|
||||||
yield $this->method_call_async_read('messages.sendEncryptedService', ['peer' => $chat, 'message' => ['_' => 'decryptedMessageService', 'action' => ['_' => 'decryptedMessageActionAcceptKey', 'g_b' => $g_b->toBytes(), 'exchange_id' => $params['exchange_id'], 'key_fingerprint' => $key['fingerprint']]]], ['datacenter' => $this->datacenter->curdc]);
|
yield $this->method_call_async_read('messages.sendEncryptedService', ['peer' => $chat, 'message' => ['_' => 'decryptedMessageService', 'action' => ['_' => 'decryptedMessageActionAcceptKey', 'g_b' => $g_b->toBytes(), 'exchange_id' => $params['exchange_id'], 'key_fingerprint' => $key['fingerprint']]]], ['datacenter' => $this->datacenter->curdc]);
|
||||||
$this->handle_pending_updates();
|
$this->handle_pending_updates();
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function commit_rekey_async($chat, $params)
|
public function commit_rekey_async($chat, $params)
|
||||||
@ -203,7 +203,7 @@ trait AuthKeyHandler
|
|||||||
$this->secret_chats[$chat]['ttr'] = 100;
|
$this->secret_chats[$chat]['ttr'] = 100;
|
||||||
$this->secret_chats[$chat]['updated'] = time();
|
$this->secret_chats[$chat]['updated'] = time();
|
||||||
$this->handle_pending_updates();
|
$this->handle_pending_updates();
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function complete_rekey_async($chat, $params)
|
public function complete_rekey_async($chat, $params)
|
||||||
|
@ -35,7 +35,7 @@ trait MessageHandler
|
|||||||
$this->secret_chats[$chat_id]['ttr']--;
|
$this->secret_chats[$chat_id]['ttr']--;
|
||||||
if ($this->secret_chats[$chat_id]['layer'] > 8) {
|
if ($this->secret_chats[$chat_id]['layer'] > 8) {
|
||||||
if (($this->secret_chats[$chat_id]['ttr'] <= 0 || time() - $this->secret_chats[$chat_id]['updated'] > 7 * 24 * 60 * 60) && $this->secret_chats[$chat_id]['rekeying'][0] === 0) {
|
if (($this->secret_chats[$chat_id]['ttr'] <= 0 || time() - $this->secret_chats[$chat_id]['updated'] > 7 * 24 * 60 * 60) && $this->secret_chats[$chat_id]['rekeying'][0] === 0) {
|
||||||
$this->rekey($chat_id);
|
yield $this->rekey_async($chat_id);
|
||||||
}
|
}
|
||||||
$message = ['_' => 'decryptedMessageLayer', 'layer' => $this->secret_chats[$chat_id]['layer'], 'in_seq_no' => $this->generate_secret_in_seq_no($chat_id), 'out_seq_no' => $this->generate_secret_out_seq_no($chat_id), 'message' => $message];
|
$message = ['_' => 'decryptedMessageLayer', 'layer' => $this->secret_chats[$chat_id]['layer'], 'in_seq_no' => $this->generate_secret_in_seq_no($chat_id), 'out_seq_no' => $this->generate_secret_out_seq_no($chat_id), 'message' => $message];
|
||||||
$this->secret_chats[$chat_id]['out_seq_no']++;
|
$this->secret_chats[$chat_id]['out_seq_no']++;
|
||||||
@ -61,7 +61,7 @@ trait MessageHandler
|
|||||||
return $message;
|
return $message;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function handle_encrypted_update($message, $test = false)
|
public function handle_encrypted_update_async($message, $test = false)
|
||||||
{
|
{
|
||||||
if (!isset($this->secret_chats[$message['message']['chat_id']])) {
|
if (!isset($this->secret_chats[$message['message']['chat_id']])) {
|
||||||
$this->logger->logger(sprintf(\danog\MadelineProto\Lang::$current_lang['secret_chat_skipping'], $message['message']['chat_id']));
|
$this->logger->logger(sprintf(\danog\MadelineProto\Lang::$current_lang['secret_chat_skipping'], $message['message']['chat_id']));
|
||||||
@ -73,13 +73,13 @@ trait MessageHandler
|
|||||||
if ($auth_key_id !== $this->secret_chats[$message['message']['chat_id']]['key']['fingerprint']) {
|
if ($auth_key_id !== $this->secret_chats[$message['message']['chat_id']]['key']['fingerprint']) {
|
||||||
if (isset($this->secret_chats[$message['message']['chat_id']]['old_key']['fingerprint'])) {
|
if (isset($this->secret_chats[$message['message']['chat_id']]['old_key']['fingerprint'])) {
|
||||||
if ($auth_key_id !== $this->secret_chats[$message['message']['chat_id']]['old_key']['fingerprint']) {
|
if ($auth_key_id !== $this->secret_chats[$message['message']['chat_id']]['old_key']['fingerprint']) {
|
||||||
$this->discard_secret_chat($message['message']['chat_id']);
|
yield $this->discard_secret_chat_async($message['message']['chat_id']);
|
||||||
|
|
||||||
throw new \danog\MadelineProto\SecurityException(\danog\MadelineProto\Lang::$current_lang['fingerprint_mismatch']);
|
throw new \danog\MadelineProto\SecurityException(\danog\MadelineProto\Lang::$current_lang['fingerprint_mismatch']);
|
||||||
}
|
}
|
||||||
$old = true;
|
$old = true;
|
||||||
} else {
|
} else {
|
||||||
$this->discard_secret_chat($message['message']['chat_id']);
|
yield $this->discard_secret_chat_async($message['message']['chat_id']);
|
||||||
|
|
||||||
throw new \danog\MadelineProto\SecurityException(\danog\MadelineProto\Lang::$current_lang['fingerprint_mismatch']);
|
throw new \danog\MadelineProto\SecurityException(\danog\MadelineProto\Lang::$current_lang['fingerprint_mismatch']);
|
||||||
}
|
}
|
||||||
@ -114,12 +114,12 @@ trait MessageHandler
|
|||||||
$deserialized = $this->deserialize($message_data, ['type' => '']);
|
$deserialized = $this->deserialize($message_data, ['type' => '']);
|
||||||
$this->secret_chats[$message['message']['chat_id']]['ttr']--;
|
$this->secret_chats[$message['message']['chat_id']]['ttr']--;
|
||||||
if (($this->secret_chats[$message['message']['chat_id']]['ttr'] <= 0 || time() - $this->secret_chats[$message['message']['chat_id']]['updated'] > 7 * 24 * 60 * 60) && $this->secret_chats[$message['message']['chat_id']]['rekeying'][0] === 0) {
|
if (($this->secret_chats[$message['message']['chat_id']]['ttr'] <= 0 || time() - $this->secret_chats[$message['message']['chat_id']]['updated'] > 7 * 24 * 60 * 60) && $this->secret_chats[$message['message']['chat_id']]['rekeying'][0] === 0) {
|
||||||
$this->rekey($message['message']['chat_id']);
|
yield $this->rekey_async($message['message']['chat_id']);
|
||||||
}
|
}
|
||||||
unset($message['message']['bytes']);
|
unset($message['message']['bytes']);
|
||||||
$message['message']['decrypted_message'] = $deserialized;
|
$message['message']['decrypted_message'] = $deserialized;
|
||||||
$this->secret_chats[$message['message']['chat_id']]['incoming'][$this->secret_chats[$message['message']['chat_id']]['in_seq_no']] = $message['message'];
|
$this->secret_chats[$message['message']['chat_id']]['incoming'][$this->secret_chats[$message['message']['chat_id']]['in_seq_no']] = $message['message'];
|
||||||
$this->handle_decrypted_update($message);
|
yield $this->handle_decrypted_update_async($message);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function try_mtproto_v1_decrypt($message_key, $chat_id, $old, $encrypted_data)
|
public function try_mtproto_v1_decrypt($message_key, $chat_id, $old, $encrypted_data)
|
||||||
|
@ -34,15 +34,15 @@ trait ResponseHandler
|
|||||||
case 'decryptedMessageService':
|
case 'decryptedMessageService':
|
||||||
switch ($update['message']['decrypted_message']['action']['_']) {
|
switch ($update['message']['decrypted_message']['action']['_']) {
|
||||||
case 'decryptedMessageActionRequestKey':
|
case 'decryptedMessageActionRequestKey':
|
||||||
$this->accept_rekey($update['message']['chat_id'], $update['message']['decrypted_message']['action']);
|
yield $this->accept_rekey_async($update['message']['chat_id'], $update['message']['decrypted_message']['action']);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
case 'decryptedMessageActionAcceptKey':
|
case 'decryptedMessageActionAcceptKey':
|
||||||
$this->commit_rekey($update['message']['chat_id'], $update['message']['decrypted_message']['action']);
|
yield $this->commit_rekey_async($update['message']['chat_id'], $update['message']['decrypted_message']['action']);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
case 'decryptedMessageActionCommitKey':
|
case 'decryptedMessageActionCommitKey':
|
||||||
$this->complete_rekey($update['message']['chat_id'], $update['message']['decrypted_message']['action']);
|
yield $this->complete_rekey_async($update['message']['chat_id'], $update['message']['decrypted_message']['action']);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
case 'decryptedMessageActionNotifyLayer':
|
case 'decryptedMessageActionNotifyLayer':
|
||||||
@ -58,7 +58,7 @@ trait ResponseHandler
|
|||||||
case 'decryptedMessageActionSetMessageTTL':
|
case 'decryptedMessageActionSetMessageTTL':
|
||||||
$this->secret_chats[$update['message']['chat_id']]['ttl'] = $update['message']['decrypted_message']['action']['ttl_seconds'];
|
$this->secret_chats[$update['message']['chat_id']]['ttl'] = $update['message']['decrypted_message']['action']['ttl_seconds'];
|
||||||
|
|
||||||
$this->save_update($update);
|
yield $this->save_update_async($update);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
case 'decryptedMessageActionNoop':
|
case 'decryptedMessageActionNoop':
|
||||||
@ -78,12 +78,12 @@ trait ResponseHandler
|
|||||||
|
|
||||||
return;
|
return;
|
||||||
default:
|
default:
|
||||||
// $this->save_update(['_' => 'updateNewDecryptedMessage', 'peer' => $this->secret_chats[$update['message']['chat_id']]['InputEncryptedChat'], 'in_seq_no' => $this->get_in_seq_no($update['message']['chat_id']), 'out_seq_no' => $this->get_out_seq_no($update['message']['chat_id']), 'message' => $update['message']['decrypted_message']]);
|
// yield $this->save_update_async(['_' => 'updateNewDecryptedMessage', 'peer' => $this->secret_chats[$update['message']['chat_id']]['InputEncryptedChat'], 'in_seq_no' => $this->get_in_seq_no($update['message']['chat_id']), 'out_seq_no' => $this->get_out_seq_no($update['message']['chat_id']), 'message' => $update['message']['decrypted_message']]);
|
||||||
$this->save_update($update);
|
yield $this->save_update_async($update);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'decryptedMessage':
|
case 'decryptedMessage':
|
||||||
$this->save_update($update);
|
yield $this->save_update_async($update);
|
||||||
break;
|
break;
|
||||||
case 'decryptedMessageLayer':
|
case 'decryptedMessageLayer':
|
||||||
if ($this->check_secret_out_seq_no($update['message']['chat_id'], $update['message']['decrypted_message']['out_seq_no']) && $this->check_secret_in_seq_no($update['message']['chat_id'], $update['message']['decrypted_message']['in_seq_no'])) {
|
if ($this->check_secret_out_seq_no($update['message']['chat_id'], $update['message']['decrypted_message']['out_seq_no']) && $this->check_secret_in_seq_no($update['message']['chat_id'], $update['message']['decrypted_message']['in_seq_no'])) {
|
||||||
@ -95,7 +95,7 @@ trait ResponseHandler
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
$update['message']['decrypted_message'] = $update['message']['decrypted_message']['message'];
|
$update['message']['decrypted_message'] = $update['message']['decrypted_message']['message'];
|
||||||
$this->handle_decrypted_update($update);
|
yield $this->handle_decrypted_update_async($update);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -24,14 +24,14 @@ namespace danog\MadelineProto\SecretChats;
|
|||||||
*/
|
*/
|
||||||
trait SeqNoHandler
|
trait SeqNoHandler
|
||||||
{
|
{
|
||||||
public function check_secret_in_seq_no($chat_id, $seqno)
|
public function check_secret_in_seq_no_async($chat_id, $seqno)
|
||||||
{
|
{
|
||||||
$seqno = ($seqno - $this->secret_chats[$chat_id]['out_seq_no_x']) / 2;
|
$seqno = ($seqno - $this->secret_chats[$chat_id]['out_seq_no_x']) / 2;
|
||||||
$last = 0;
|
$last = 0;
|
||||||
foreach ($this->secret_chats[$chat_id]['incoming'] as $message) {
|
foreach ($this->secret_chats[$chat_id]['incoming'] as $message) {
|
||||||
if (isset($message['decrypted_message']['in_seq_no'])) {
|
if (isset($message['decrypted_message']['in_seq_no'])) {
|
||||||
if (($message['decrypted_message']['in_seq_no'] - $this->secret_chats[$chat_id]['out_seq_no_x']) / 2 < $last) {
|
if (($message['decrypted_message']['in_seq_no'] - $this->secret_chats[$chat_id]['out_seq_no_x']) / 2 < $last) {
|
||||||
$this->discard_secret_chat($chat_id);
|
yield $this->discard_secret_chat_async($chat_id);
|
||||||
|
|
||||||
throw new \danog\MadelineProto\SecurityException('in_seq_no is not increasing');
|
throw new \danog\MadelineProto\SecurityException('in_seq_no is not increasing');
|
||||||
}
|
}
|
||||||
@ -39,7 +39,7 @@ trait SeqNoHandler
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ($seqno > $this->secret_chats[$chat_id]['out_seq_no'] + 1) {
|
if ($seqno > $this->secret_chats[$chat_id]['out_seq_no'] + 1) {
|
||||||
$this->discard_secret_chat($chat_id);
|
yield $this->discard_secret_chat_async($chat_id);
|
||||||
|
|
||||||
throw new \danog\MadelineProto\SecurityException('in_seq_no is too big');
|
throw new \danog\MadelineProto\SecurityException('in_seq_no is too big');
|
||||||
}
|
}
|
||||||
@ -47,14 +47,14 @@ trait SeqNoHandler
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function check_secret_out_seq_no($chat_id, $seqno)
|
public function check_secret_out_seq_no_async($chat_id, $seqno)
|
||||||
{
|
{
|
||||||
$seqno = ($seqno - $this->secret_chats[$chat_id]['in_seq_no_x']) / 2;
|
$seqno = ($seqno - $this->secret_chats[$chat_id]['in_seq_no_x']) / 2;
|
||||||
$C = 0;
|
$C = 0;
|
||||||
foreach ($this->secret_chats[$chat_id]['incoming'] as $message) {
|
foreach ($this->secret_chats[$chat_id]['incoming'] as $message) {
|
||||||
if (isset($message['decrypted_message']['out_seq_no']) && $C < $this->secret_chats[$chat_id]['in_seq_no']) {
|
if (isset($message['decrypted_message']['out_seq_no']) && $C < $this->secret_chats[$chat_id]['in_seq_no']) {
|
||||||
if (($message['decrypted_message']['out_seq_no'] - $this->secret_chats[$chat_id]['in_seq_no_x']) / 2 !== $C) {
|
if (($message['decrypted_message']['out_seq_no'] - $this->secret_chats[$chat_id]['in_seq_no_x']) / 2 !== $C) {
|
||||||
$this->discard_secret_chat($chat_id);
|
yield $this->discard_secret_chat_async($chat_id);
|
||||||
|
|
||||||
throw new \danog\MadelineProto\SecurityException('out_seq_no hole: should be '.$C.', is '.($message['decrypted_message']['out_seq_no'] - $this->secret_chats[$chat_id]['in_seq_no_x']) / 2);
|
throw new \danog\MadelineProto\SecurityException('out_seq_no hole: should be '.$C.', is '.($message['decrypted_message']['out_seq_no'] - $this->secret_chats[$chat_id]['in_seq_no_x']) / 2);
|
||||||
} else {
|
} else {
|
||||||
@ -71,7 +71,7 @@ trait SeqNoHandler
|
|||||||
}
|
}
|
||||||
if ($seqno > $C) {
|
if ($seqno > $C) {
|
||||||
// > C+1
|
// > C+1
|
||||||
$this->discard_secret_chat($chat_id);
|
yield $this->discard_secret_chat_async($chat_id);
|
||||||
|
|
||||||
throw new \danog\MadelineProto\SecurityException('WARNING: out_seq_no gap detected ('.$seqno.' > '.$C.')!');
|
throw new \danog\MadelineProto\SecurityException('WARNING: out_seq_no gap detected ('.$seqno.' > '.$C.')!');
|
||||||
}
|
}
|
||||||
|
@ -160,7 +160,7 @@ trait BotAPI
|
|||||||
$newd = [];
|
$newd = [];
|
||||||
if (!isset($data['_'])) {
|
if (!isset($data['_'])) {
|
||||||
foreach ($data as $key => $element) {
|
foreach ($data as $key => $element) {
|
||||||
$newd[$key] = $this->MTProto_to_botAPI($element, $sent_arguments);
|
$newd[$key] = yield $this->MTProto_to_botAPI_async($element, $sent_arguments);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $newd;
|
return $newd;
|
||||||
@ -175,16 +175,16 @@ trait BotAPI
|
|||||||
}
|
}
|
||||||
$newd['chat'] = $this->get_pwr_chat($sent_arguments['peer']);
|
$newd['chat'] = $this->get_pwr_chat($sent_arguments['peer']);
|
||||||
if (isset($data['entities'])) {
|
if (isset($data['entities'])) {
|
||||||
$newd['entities'] = $this->MTProto_to_botAPI($data['entities'], $sent_arguments);
|
$newd['entities'] = yield $this->MTProto_to_botAPI_async($data['entities'], $sent_arguments);
|
||||||
}
|
}
|
||||||
if (isset($data['media'])) {
|
if (isset($data['media'])) {
|
||||||
$newd = array_merge($newd, $this->MTProto_to_botAPI($data['media'], $sent_arguments));
|
$newd = array_merge($newd, yield $this->MTProto_to_botAPI_async($data['media'], $sent_arguments));
|
||||||
}
|
}
|
||||||
|
|
||||||
return $newd;
|
return $newd;
|
||||||
case 'updateNewChannelMessage':
|
case 'updateNewChannelMessage':
|
||||||
case 'updateNewMessage':
|
case 'updateNewMessage':
|
||||||
return $this->MTProto_to_botAPI($data['message']);
|
return yield $this->MTProto_to_botAPI_async($data['message']);
|
||||||
case 'message':
|
case 'message':
|
||||||
$newd['message_id'] = $data['id'];
|
$newd['message_id'] = $data['id'];
|
||||||
$newd['date'] = $data['date'];
|
$newd['date'] = $data['date'];
|
||||||
@ -196,7 +196,7 @@ trait BotAPI
|
|||||||
}
|
}
|
||||||
$newd['chat'] = $this->get_pwr_chat($data['to_id']);
|
$newd['chat'] = $this->get_pwr_chat($data['to_id']);
|
||||||
if (isset($data['entities'])) {
|
if (isset($data['entities'])) {
|
||||||
$newd['entities'] = $this->MTProto_to_botAPI($data['entities'], $sent_arguments);
|
$newd['entities'] = yield $this->MTProto_to_botAPI_async($data['entities'], $sent_arguments);
|
||||||
}
|
}
|
||||||
if (isset($data['views'])) {
|
if (isset($data['views'])) {
|
||||||
$newd['views'] = $data['views'];
|
$newd['views'] = $data['views'];
|
||||||
@ -220,7 +220,7 @@ trait BotAPI
|
|||||||
$newd['forward_from_message_id'] = $data['fwd_from']['channel_post'];
|
$newd['forward_from_message_id'] = $data['fwd_from']['channel_post'];
|
||||||
}
|
}
|
||||||
if (isset($data['media'])) {
|
if (isset($data['media'])) {
|
||||||
$newd = array_merge($newd, $this->MTProto_to_botAPI($data['media'], $sent_arguments));
|
$newd = array_merge($newd, yield $this->MTProto_to_botAPI_async($data['media'], $sent_arguments));
|
||||||
}
|
}
|
||||||
|
|
||||||
return $newd;
|
return $newd;
|
||||||
@ -287,7 +287,7 @@ trait BotAPI
|
|||||||
}
|
}
|
||||||
$res['photo'] = [];
|
$res['photo'] = [];
|
||||||
foreach ($data['photo']['sizes'] as $key => $photo) {
|
foreach ($data['photo']['sizes'] as $key => $photo) {
|
||||||
$res['photo'][$key] = $this->photosize_to_botapi($photo, $data['photo']);
|
$res['photo'][$key] = yield $this->photosize_to_botapi_async($photo, $data['photo']);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $res;
|
return $res;
|
||||||
@ -297,7 +297,7 @@ trait BotAPI
|
|||||||
$type_name = 'document';
|
$type_name = 'document';
|
||||||
$res = [];
|
$res = [];
|
||||||
if ($data['document']['thumb']['_'] === 'photoSize') {
|
if ($data['document']['thumb']['_'] === 'photoSize') {
|
||||||
$res['thumb'] = $this->photosize_to_botapi($data['document']['thumb'], [], true);
|
$res['thumb'] = yield $this->photosize_to_botapi_async($data['document']['thumb'], [], true);
|
||||||
}
|
}
|
||||||
foreach ($data['document']['attributes'] as $attribute) {
|
foreach ($data['document']['attributes'] as $attribute) {
|
||||||
switch ($attribute['_']) {
|
switch ($attribute['_']) {
|
||||||
@ -396,7 +396,7 @@ trait BotAPI
|
|||||||
return $arguments;
|
return $arguments;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function parse_node($node, &$entities, &$new_message, &$offset)
|
public function parse_node_async($node, &$entities, &$new_message, &$offset)
|
||||||
{
|
{
|
||||||
switch ($node->nodeName) {
|
switch ($node->nodeName) {
|
||||||
case 'br':
|
case 'br':
|
||||||
@ -455,7 +455,7 @@ trait BotAPI
|
|||||||
$length = $this->mb_strlen($text);
|
$length = $this->mb_strlen($text);
|
||||||
$href = $node->getAttribute('href');
|
$href = $node->getAttribute('href');
|
||||||
if (preg_match('|mention:(.*)|', $href, $matches) || preg_match('|tg://user\?id=(.*)|', $href, $matches)) {
|
if (preg_match('|mention:(.*)|', $href, $matches) || preg_match('|tg://user\?id=(.*)|', $href, $matches)) {
|
||||||
$mention = $this->get_info($matches[1]);
|
$mention = yield $this->get_info_async($matches[1]);
|
||||||
if (!isset($mention['InputUser'])) {
|
if (!isset($mention['InputUser'])) {
|
||||||
throw new \danog\MadelineProto\Exception(\danog\MadelineProto\Lang::$current_lang['peer_not_in_db']);
|
throw new \danog\MadelineProto\Exception(\danog\MadelineProto\Lang::$current_lang['peer_not_in_db']);
|
||||||
}
|
}
|
||||||
|
@ -72,7 +72,7 @@ trait BotAPIFiles
|
|||||||
|
|
||||||
public function photosize_to_botapi_async($photoSize, $photo, $thumbnail = false)
|
public function photosize_to_botapi_async($photoSize, $photo, $thumbnail = false)
|
||||||
{
|
{
|
||||||
$ext = $this->get_extension_from_location(['_' => 'inputFileLocation', 'volume_id' => $photoSize['location']['volume_id'], 'local_id' => $photoSize['location']['local_id'], 'secret' => $photoSize['location']['secret'], 'dc_id' => $photoSize['location']['dc_id']], '.jpg');
|
$ext = yield $this->get_extension_from_location_async(['_' => 'inputFileLocation', 'volume_id' => $photoSize['location']['volume_id'], 'local_id' => $photoSize['location']['local_id'], 'secret' => $photoSize['location']['secret'], 'dc_id' => $photoSize['location']['dc_id']], '.jpg');
|
||||||
$photoSize['location']['access_hash'] = isset($photo['access_hash']) ? $photo['access_hash'] : 0;
|
$photoSize['location']['access_hash'] = isset($photo['access_hash']) ? $photo['access_hash'] : 0;
|
||||||
$photoSize['location']['id'] = isset($photo['id']) ? $photo['id'] : 0;
|
$photoSize['location']['id'] = isset($photo['id']) ? $photo['id'] : 0;
|
||||||
$photoSize['location']['_'] = $thumbnail ? 'bot_thumbnail' : 'bot_photo';
|
$photoSize['location']['_'] = $thumbnail ? 'bot_thumbnail' : 'bot_photo';
|
||||||
|
@ -80,7 +80,7 @@ trait TD
|
|||||||
return $this->td_to_tdcli($this->mtproto_to_td($params));
|
return $this->td_to_tdcli($this->mtproto_to_td($params));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function mtproto_to_td(&$params)
|
public function mtproto_to_td_async(&$params)
|
||||||
{
|
{
|
||||||
if (!is_array($params)) {
|
if (!is_array($params)) {
|
||||||
return $params;
|
return $params;
|
||||||
@ -100,7 +100,7 @@ trait TD
|
|||||||
} else {
|
} else {
|
||||||
switch (end($mtproto)) {
|
switch (end($mtproto)) {
|
||||||
case 'choose_chat_id_from_botapi':
|
case 'choose_chat_id_from_botapi':
|
||||||
$newparams[$td] = $this->get_info($params[$mtproto[0]])['bot_api_id'] == $this->authorization['user']['id'] ? $params['from_id'] : $this->get_info($params[$mtproto[0]])['bot_api_id'];
|
$newparams[$td] = yield $this->get_info_async($params[$mtproto[0]])['bot_api_id'] == $this->authorization['user']['id'] ? $params['from_id'] : yield $this->get_info_async($params[$mtproto[0]])['bot_api_id'];
|
||||||
break;
|
break;
|
||||||
case 'choose_incoming_or_sent':
|
case 'choose_incoming_or_sent':
|
||||||
$newparams[$td] = ['_' => $params['out'] ? 'messageIsSuccessfullySent' : 'messageIsIncoming'];
|
$newparams[$td] = ['_' => $params['out'] ? 'messageIsSuccessfullySent' : 'messageIsIncoming'];
|
||||||
|
@ -430,7 +430,7 @@ trait TL
|
|||||||
$concat = $constructorData['id'];
|
$concat = $constructorData['id'];
|
||||||
}
|
}
|
||||||
|
|
||||||
return $concat.yield $this->serialize_params($constructorData, $object, '', $layer);
|
return $concat.yield $this->serialize_params_async($constructorData, $object, '', $layer);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function serialize_object($type, $object, $ctx, $layer = -1)
|
public function serialize_object($type, $object, $ctx, $layer = -1)
|
||||||
@ -483,7 +483,7 @@ trait TL
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} elseif (in_array($method, ['messages.addChatUser', 'messages.deleteChatUser', 'messages.editChatAdmin', 'messages.editChatPhoto', 'messages.editChatTitle', 'messages.getFullChat', 'messages.exportChatInvite', 'messages.editChatAdmin', 'messages.migrateChat']) && isset($arguments['chat_id']) && (!is_numeric($arguments['chat_id']) || $arguments['chat_id'] < 0)) {
|
} elseif (in_array($method, ['messages.addChatUser', 'messages.deleteChatUser', 'messages.editChatAdmin', 'messages.editChatPhoto', 'messages.editChatTitle', 'messages.getFullChat', 'messages.exportChatInvite', 'messages.editChatAdmin', 'messages.migrateChat']) && isset($arguments['chat_id']) && (!is_numeric($arguments['chat_id']) || $arguments['chat_id'] < 0)) {
|
||||||
$res = $this->get_info($arguments['chat_id']);
|
$res = yield $this->get_info_async($arguments['chat_id']);
|
||||||
if ($res['type'] !== 'chat') {
|
if ($res['type'] !== 'chat') {
|
||||||
throw new \danog\MadelineProto\Exception('chat_id is not a chat id (only normal groups allowed, not supergroups)!');
|
throw new \danog\MadelineProto\Exception('chat_id is not a chat id (only normal groups allowed, not supergroups)!');
|
||||||
}
|
}
|
||||||
@ -513,7 +513,7 @@ trait TL
|
|||||||
throw new Exception(\danog\MadelineProto\Lang::$current_lang['method_not_found'].$method);
|
throw new Exception(\danog\MadelineProto\Lang::$current_lang['method_not_found'].$method);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $tl['id'].yield $this->serialize_params($tl, $arguments, $method);
|
return $tl['id'].yield $this->serialize_params_async($tl, $arguments, $method);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function serialize_params_async($tl, $arguments, $ctx, $layer = -1)
|
public function serialize_params_async($tl, $arguments, $ctx, $layer = -1)
|
||||||
@ -553,7 +553,7 @@ trait TL
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ($current_argument['name'] === 'data' && isset($tl['method']) && in_array($tl['method'], ['messages.sendEncrypted', 'messages.sendEncryptedFile', 'messages.sendEncryptedService']) && isset($arguments['message'])) {
|
if ($current_argument['name'] === 'data' && isset($tl['method']) && in_array($tl['method'], ['messages.sendEncrypted', 'messages.sendEncryptedFile', 'messages.sendEncryptedService']) && isset($arguments['message'])) {
|
||||||
$serialized .= yield $this->serialize_object_async($current_argument, $this->encrypt_secret_message($arguments['peer']['chat_id'], $arguments['message']), 'data');
|
$serialized .= yield $this->serialize_object_async($current_argument, yield $this->encrypt_secret_message_async($arguments['peer']['chat_id'], $arguments['message']), 'data');
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ($current_argument['name'] === 'random_id') {
|
if ($current_argument['name'] === 'random_id') {
|
||||||
@ -617,7 +617,7 @@ trait TL
|
|||||||
|
|
||||||
if ($current_argument['type'] === 'InputEncryptedChat' && (!is_array($arguments[$current_argument['name']]) || isset($arguments[$current_argument['name']]['_']) && $this->constructors->find_by_predicate($arguments[$current_argument['name']]['_'])['type'] !== $current_argument['type'])) {
|
if ($current_argument['type'] === 'InputEncryptedChat' && (!is_array($arguments[$current_argument['name']]) || isset($arguments[$current_argument['name']]['_']) && $this->constructors->find_by_predicate($arguments[$current_argument['name']]['_'])['type'] !== $current_argument['type'])) {
|
||||||
if (is_array($arguments[$current_argument['name']])) {
|
if (is_array($arguments[$current_argument['name']])) {
|
||||||
$arguments[$current_argument['name']] = $this->get_info($arguments[$current_argument['name']])['InputEncryptedChat'];
|
$arguments[$current_argument['name']] = yield $this->get_info_async($arguments[$current_argument['name']])['InputEncryptedChat'];
|
||||||
} else {
|
} else {
|
||||||
if (!isset($this->secret_chats[$arguments[$current_argument['name']]])) {
|
if (!isset($this->secret_chats[$arguments[$current_argument['name']]])) {
|
||||||
throw new \danog\MadelineProto\Exception(\danog\MadelineProto\Lang::$current_lang['sec_peer_not_in_db']);
|
throw new \danog\MadelineProto\Exception(\danog\MadelineProto\Lang::$current_lang['sec_peer_not_in_db']);
|
||||||
|
@ -39,7 +39,7 @@ trait AuthKeyHandler
|
|||||||
$controller->discard();
|
$controller->discard();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
$user = $this->get_info($user);
|
$user = yield $this->get_info_async($user);
|
||||||
if (!isset($user['InputUser']) || $user['InputUser']['_'] === 'inputUserSelf') {
|
if (!isset($user['InputUser']) || $user['InputUser']['_'] === 'inputUserSelf') {
|
||||||
throw new \danog\MadelineProto\Exception(\danog\MadelineProto\Lang::$current_lang['peer_not_in_db']);
|
throw new \danog\MadelineProto\Exception(\danog\MadelineProto\Lang::$current_lang['peer_not_in_db']);
|
||||||
}
|
}
|
||||||
@ -57,7 +57,7 @@ trait AuthKeyHandler
|
|||||||
$controller->setCall($res['phone_call']);
|
$controller->setCall($res['phone_call']);
|
||||||
$this->calls[$res['phone_call']['id']] = $controller;
|
$this->calls[$res['phone_call']['id']] = $controller;
|
||||||
$this->handle_pending_updates();
|
$this->handle_pending_updates();
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
|
|
||||||
return $controller;
|
return $controller;
|
||||||
}
|
}
|
||||||
@ -94,7 +94,7 @@ trait AuthKeyHandler
|
|||||||
}
|
}
|
||||||
if ($e->rpc === 'CALL_ALREADY_DECLINED') {
|
if ($e->rpc === 'CALL_ALREADY_DECLINED') {
|
||||||
$this->logger->logger(\danog\MadelineProto\Lang::$current_lang['call_already_declined']);
|
$this->logger->logger(\danog\MadelineProto\Lang::$current_lang['call_already_declined']);
|
||||||
$this->discard_call($call['id'], 'phoneCallDiscardReasonHangup');
|
yield $this->discard_call_async($call['id'], 'phoneCallDiscardReasonHangup');
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -103,7 +103,7 @@ trait AuthKeyHandler
|
|||||||
}
|
}
|
||||||
$this->calls[$res['phone_call']['id']]->storage['b'] = $b;
|
$this->calls[$res['phone_call']['id']]->storage['b'] = $b;
|
||||||
$this->handle_pending_updates();
|
$this->handle_pending_updates();
|
||||||
$this->get_updates_difference();
|
yield $this->get_updates_difference_async();
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -59,7 +59,7 @@ trait DialogHandler
|
|||||||
$last_id = $dialog['top_message'];
|
$last_id = $dialog['top_message'];
|
||||||
}
|
}
|
||||||
foreach ($res['messages'] as $message) {
|
foreach ($res['messages'] as $message) {
|
||||||
if (yield $this->get_info($message)['Peer'] === $last_peer && $last_id === $message['id']) {
|
if (yield $this->get_info_async($message)['Peer'] === $last_peer && $last_id === $message['id']) {
|
||||||
$last_date = $message['date'];
|
$last_date = $message['date'];
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -61,27 +61,27 @@ trait Start
|
|||||||
} else {
|
} else {
|
||||||
if ($this->authorized === self::NOT_LOGGED_IN) {
|
if ($this->authorized === self::NOT_LOGGED_IN) {
|
||||||
if (isset($_POST['phone_number'])) {
|
if (isset($_POST['phone_number'])) {
|
||||||
yield $this->web_phone_login();
|
yield $this->web_phone_login_async();
|
||||||
} elseif (isset($_POST['token'])) {
|
} elseif (isset($_POST['token'])) {
|
||||||
yield $this->web_bot_login();
|
yield $this->web_bot_login_async();
|
||||||
} else {
|
} else {
|
||||||
$this->web_echo();
|
$this->web_echo();
|
||||||
}
|
}
|
||||||
} elseif ($this->authorized === self::WAITING_CODE) {
|
} elseif ($this->authorized === self::WAITING_CODE) {
|
||||||
if (isset($_POST['phone_code'])) {
|
if (isset($_POST['phone_code'])) {
|
||||||
yield $this->web_complete_phone_login();
|
yield $this->web_complete_phone_login_async();
|
||||||
} else {
|
} else {
|
||||||
$this->web_echo("You didn't provide a phone code!");
|
$this->web_echo("You didn't provide a phone code!");
|
||||||
}
|
}
|
||||||
} elseif ($this->authorized === self::WAITING_PASSWORD) {
|
} elseif ($this->authorized === self::WAITING_PASSWORD) {
|
||||||
if (isset($_POST['password'])) {
|
if (isset($_POST['password'])) {
|
||||||
yield $this->web_complete_2fa_login();
|
yield $this->web_complete_2fa_login_async();
|
||||||
} else {
|
} else {
|
||||||
$this->web_echo("You didn't provide the password!");
|
$this->web_echo("You didn't provide the password!");
|
||||||
}
|
}
|
||||||
} elseif ($this->authorized === self::WAITING_SIGNUP) {
|
} elseif ($this->authorized === self::WAITING_SIGNUP) {
|
||||||
if (isset($_POST['first_name'])) {
|
if (isset($_POST['first_name'])) {
|
||||||
yield $this->web_complete_signup();
|
yield $this->web_complete_signup_async();
|
||||||
} else {
|
} else {
|
||||||
$this->web_echo("You didn't provide the first name!");
|
$this->web_echo("You didn't provide the first name!");
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user