MadelineProto/userbots/pipesbot.php

250 lines
14 KiB
PHP
Raw Normal View History

#!/usr/bin/env php
<?php
2017-02-11 15:30:37 +01:00
/*
2019-05-31 12:18:10 +02:00
Copyright 2016-2019 Daniil Gentili
2017-02-11 15:30:37 +01:00
(https://daniil.it)
This file is part of MadelineProto.
MadelineProto is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
MadelineProto is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU Affero General Public License for more details.
You should have received a copy of the GNU General Public License along with MadelineProto.
If not, see <http://www.gnu.org/licenses/>.
*/
2019-09-02 17:08:36 +02:00
if (!\file_exists(__DIR__.'/../vendor/autoload.php')) {
2018-10-13 15:16:10 +00:00
echo 'You did not run composer update, using madeline.php'.PHP_EOL;
2019-09-02 17:08:36 +02:00
if (!\file_exists('madeline.php')) {
\copy('https://phar.madelineproto.xyz/madeline.php', 'madeline.php');
2018-10-13 15:16:10 +00:00
}
include 'madeline.php';
} else {
require_once 'vendor/autoload.php';
}
2018-05-08 19:08:09 +00:00
$settings = [];
$MadelineProto = false;
2017-05-03 10:03:51 +00:00
$uMadelineProto = false;
2017-08-13 16:52:32 +00:00
try {
$MadelineProto = new \danog\MadelineProto\API('pipesbot.madeline');
} catch (\danog\MadelineProto\Exception $e) {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($e->getMessage());
2017-05-03 10:03:51 +00:00
}
2017-08-13 16:52:32 +00:00
2017-05-03 10:03:51 +00:00
try {
$uMadelineProto = new \danog\MadelineProto\API('pwr.madeline');
2017-05-03 10:03:51 +00:00
} catch (\danog\MadelineProto\Exception $e) {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($e->getMessage());
}
2019-09-02 17:08:36 +02:00
if (\file_exists('token.php') && $MadelineProto === false) {
include_once 'token.php';
$MadelineProto = new \danog\MadelineProto\API($settings);
$authorization = $MadelineProto->bot_login($pipes_token);
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($authorization, \danog\MadelineProto\Logger::NOTICE);
}
if ($uMadelineProto === false) {
echo 'Loading MadelineProto...'.PHP_EOL;
2019-09-02 17:08:36 +02:00
$uMadelineProto = new \danog\MadelineProto\API(\array_merge($settings, ['updates' => ['handle_updates' => false]]));
$sentCode = $uMadelineProto->phone_login(\readline());
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($sentCode, \danog\MadelineProto\Logger::NOTICE);
2017-02-11 14:18:18 +00:00
echo 'Enter the code you received: ';
2019-09-02 17:08:36 +02:00
$code = \fgets(STDIN, (isset($sentCode['type']['length']) ? $sentCode['type']['length'] : 5) + 1);
2017-02-11 14:18:18 +00:00
$authorization = $uMadelineProto->complete_phone_login($code);
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($authorization, \danog\MadelineProto\Logger::NOTICE);
2017-02-11 14:18:18 +00:00
if ($authorization['_'] === 'account.noPassword') {
throw new \danog\MadelineProto\Exception('2FA is enabled but no password is set!');
}
if ($authorization['_'] === 'account.password') {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log('2FA is enabled', \danog\MadelineProto\Logger::NOTICE);
2019-09-02 17:08:36 +02:00
$authorization = $uMadelineProto->complete_2fa_login(\readline('Please enter your password (hint '.$authorization['hint'].'): '));
2017-02-11 14:18:18 +00:00
}
echo 'Serializing MadelineProto to session.madeline...'.PHP_EOL;
echo 'Wrote '.\danog\MadelineProto\Serialization::serialize('session.madeline', $uMadelineProto).' bytes'.PHP_EOL;
}
2017-02-11 14:18:18 +00:00
function inputify(&$stuff)
{
2019-09-02 17:08:36 +02:00
$stuff['_'] = 'input'.\ucfirst($stuff['_']);
2017-02-11 14:18:18 +00:00
return $stuff;
}
2017-02-11 14:18:18 +00:00
function translatetext(&$value)
{
inputify($value);
if (isset($value['entities'])) {
foreach ($value['entities'] as &$entity) {
2017-02-11 14:18:18 +00:00
if ($entity['_'] === 'messageEntityMentionName') {
inputify($entity);
}
}
}
if (isset($value['geo'])) {
$value['geo_point'] = inputify($value['geo']);
}
}
2017-02-11 14:18:18 +00:00
function translate(&$value, $key)
{
switch ($value['_']) {
case 'botInlineResult':
$value['_'] = 'inputBotInlineResult';
translatetext($value['send_message']);
2017-02-11 14:18:18 +00:00
return $value;
case 'botInlineMediaResult':
2017-02-11 14:18:18 +00:00
if (isset($value['game'])) {
throw new \danog\MadelineProto\RPCErrorException('Games are not supported.');
}
if (isset($value['photo'])) {
$value['_'] = 'inputBotInlineResultPhoto';
}
if (isset($value['document'])) {
$value['_'] = 'inputBotInlineResultDocument';
}
translatetext($value['send_message']);
2017-02-11 14:18:18 +00:00
return $value;
}
}
$offset = 0;
$start = "This bot can create a pipeline between inline bots.
To use it, simply type an inline query with the following syntax:
2017-02-21 21:04:37 +03:00
@pipesbot Hey I'm writing this using the leet filter of @filtersbot w/ @lolcatzbot | @filtersbot:eleet | @lolcatzbot \$
2017-02-21 21:04:37 +03:00
This will make an inline query with text \"Hey I'm writing this using the leet filter of @filtersbot w/ @lolcatzbot\" to @filtersbot, take the result that has the word \"eleet\" (regexes are supported. you can specify just the username to select the first result), in the title, if it's a text message (entities will be ignored, if it's a media message you will be redirected here), then it will make an inline query to @lolcatzbot with the text received out of the first bot fetch all results and return them to you.
Note that the query must be terminated by a \$
Created by @danogentili (@daniilgentili) using the daniil.it/MadelineProto PHP MTProto client.";
while (true) {
2018-03-04 17:42:48 +01:00
$updates = $MadelineProto->get_updates(['offset' => $offset, 'limit' => 50, 'timeout' => 0]); // Just like in the bot API, you can specify an offset, a limit and a timeout
foreach ($updates as $update) {
$offset = $update['update_id'] + 1; // Just like in the bot API, the offset must be set to the last update_id
2017-05-20 14:46:05 +01:00
try {
2017-05-20 13:46:46 +00:00
switch ($update['update']['_']) {
case 'updateNewMessage':
if (isset($update['update']['message']['out']) && $update['update']['message']['out']) {
continue;
}
2017-08-13 16:52:32 +00:00
try {
2019-09-02 17:08:36 +02:00
if (\preg_match('|/start|', $update['update']['message']['message'])) {
$MadelineProto->messages->sendMessage(['peer' => $update['update']['message']['from_id'], 'message' => $start, 'reply_to_msg_id' => $update['update']['message']['id']]);
}
} catch (\danog\MadelineProto\RPCErrorException $e) {
$MadelineProto->messages->sendMessage(['peer' => '@danogentili', 'message' => $e->getCode().': '.$e->getMessage().PHP_EOL.$e->getTraceAsString()]);
}
break;
case 'updateNewChannelMessage':
if (isset($update['update']['message']['out']) && $update['update']['message']['out']) {
continue;
}
2017-08-13 16:52:32 +00:00
try {
2019-09-02 17:08:36 +02:00
if (\preg_match('|/start|', $update['update']['message']['message'])) {
$MadelineProto->messages->sendMessage(['peer' => $update['update']['message']['to_id'], 'message' => $start, 'reply_to_msg_id' => $update['update']['message']['id']]);
}
} catch (\danog\MadelineProto\RPCErrorException $e) {
$MadelineProto->messages->sendMessage(['peer' => '@danogentili', 'message' => $e->getCode().': '.$e->getMessage().PHP_EOL.$e->getTraceAsString()]);
} catch (\danog\MadelineProto\Exception $e) {
$MadelineProto->messages->sendMessage(['peer' => '@danogentili', 'message' => $e->getCode().': '.$e->getMessage().PHP_EOL.$e->getTraceAsString()]);
}
break;
case 'updateBotInlineQuery':
try {
2017-02-11 14:18:18 +00:00
$sswitch = ['_' => 'inlineBotSwitchPM', 'text' => 'FAQ', 'start_param' => 'lel'];
if ($update['update']['query'] === '') {
$MadelineProto->messages->setInlineBotResults(['query_id' => $update['update']['query_id'], 'results' => [], 'cache_time' => 0, 'switch_pm' => $sswitch]);
} else {
$toset = ['query_id' => $update['update']['query_id'], 'results' => [], 'cache_time' => 0, 'private' => true];
2019-09-02 17:08:36 +02:00
if (\preg_match('|\$\s*$|', $update['update']['query'])) {
$exploded = \explode('|', \preg_replace('/\$\s*$/', '', $update['update']['query']));
\array_walk($exploded, function (&$value, $key) {
$value = \preg_replace(['/^\s+/', '/\s+$/'], '', $value);
2017-02-11 14:18:18 +00:00
});
2019-09-02 17:08:36 +02:00
$query = \array_shift($exploded);
2017-02-11 14:18:18 +00:00
foreach ($exploded as $current => $botq) {
2019-09-02 17:08:36 +02:00
$bot = \preg_replace('|:.*|', '', $botq);
2017-05-03 10:03:51 +00:00
if ($bot === '' || $uMadelineProto->get_info($bot)['bot_api_id'] === $MadelineProto->API->authorization['user']['id']) {
2017-02-11 14:18:18 +00:00
$toset['switch_pm'] = $sswitch;
break;
}
2019-09-02 17:08:36 +02:00
$select = \preg_replace('|'.$bot.':|', '', $botq);
2017-02-11 14:18:18 +00:00
$results = $uMadelineProto->messages->getInlineBotResults(['bot' => $bot, 'peer' => $update['update']['user_id'], 'query' => $query, 'offset' => $offset]);
if (isset($results['switch_pm'])) {
$toset['switch_pm'] = $results['switch_pm'];
break;
}
2017-02-11 14:18:18 +00:00
$toset['gallery'] = $results['gallery'];
$toset['results'] = [];
2019-09-02 17:08:36 +02:00
if (\is_numeric($select)) {
2017-02-11 14:18:18 +00:00
$toset['results'][0] = $results['results'][$select - 1];
} elseif ($select === '') {
$toset['results'] = $results['results'];
} else {
foreach ($results['results'] as $result) {
2019-09-02 17:08:36 +02:00
if (isset($result['send_message']['message']) && \preg_match('|'.$select.'|', $result['send_message']['message'])) {
2017-02-11 14:18:18 +00:00
$toset['results'][0] = $result;
}
}
}
if (!isset($toset['results'][0])) {
$toset['results'] = $results['results'];
}
2019-09-02 17:08:36 +02:00
if (\count($exploded) - 1 === $current || !isset($toset['results'][0]['send_message']['message'])) {
2017-02-11 14:18:18 +00:00
break;
}
$query = $toset['results'][0]['send_message']['message'];
}
}
2017-02-11 14:18:18 +00:00
if (empty($toset['results'])) {
$toset['switch_pm'] = $sswitch;
} else {
2019-09-02 17:08:36 +02:00
\array_walk($toset['results'], 'translate');
2017-02-11 14:18:18 +00:00
}
$MadelineProto->messages->setInlineBotResults($toset);
}
} catch (\danog\MadelineProto\RPCErrorException $e) {
try {
$MadelineProto->messages->sendMessage(['peer' => '@danogentili', 'message' => $e->getCode().': '.$e->getMessage().PHP_EOL.$e->getTraceAsString()]);
2017-02-11 14:18:18 +00:00
$MadelineProto->messages->sendMessage(['peer' => $update['update']['user_id'], 'message' => $e->getCode().': '.$e->getMessage().PHP_EOL.$e->getTraceAsString()]);
} catch (\danog\MadelineProto\RPCErrorException $e) {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($e->getMessage());
2017-02-11 14:18:18 +00:00
} catch (\danog\MadelineProto\Exception $e) {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($e->getMessage());
2017-02-11 14:18:18 +00:00
}
2017-08-13 16:52:32 +00:00
try {
2017-02-11 14:18:18 +00:00
$toset['switch_pm'] = $sswitch;
$MadelineProto->messages->setInlineBotResults($toset);
} catch (\danog\MadelineProto\RPCErrorException $e) {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($e->getMessage());
2017-02-11 14:18:18 +00:00
} catch (\danog\MadelineProto\Exception $e) {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($e->getMessage());
2017-02-11 14:18:18 +00:00
}
} catch (\danog\MadelineProto\Exception $e) {
try {
$MadelineProto->messages->sendMessage(['peer' => '@danogentili', 'message' => $e->getCode().': '.$e->getMessage().PHP_EOL.$e->getTraceAsString()]);
2017-02-11 14:18:18 +00:00
$MadelineProto->messages->sendMessage(['peer' => $update['update']['user_id'], 'message' => $e->getCode().': '.$e->getMessage().PHP_EOL.$e->getTraceAsString()]);
} catch (\danog\MadelineProto\RPCErrorException $e) {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($e->getMessage());
2017-02-11 14:18:18 +00:00
} catch (\danog\MadelineProto\Exception $e) {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($e->getMessage());
2017-02-11 14:18:18 +00:00
}
2017-08-13 16:52:32 +00:00
try {
2017-02-11 14:18:18 +00:00
$toset['switch_pm'] = $sswitch;
$MadelineProto->messages->setInlineBotResults($toset);
} catch (\danog\MadelineProto\RPCErrorException $e) {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($e->getMessage());
2017-02-11 14:18:18 +00:00
} catch (\danog\MadelineProto\Exception $e) {
2018-03-02 00:38:10 +00:00
\danog\MadelineProto\Logger::log($e->getMessage());
2017-02-11 14:18:18 +00:00
}
}
}
2017-05-20 13:46:46 +00:00
} catch (\danog\MadelineProto\RPCErrorException $e) {
}
}
2017-05-03 10:03:51 +00:00
\danog\MadelineProto\Serialization::serialize('pipesbot.madeline', $MadelineProto);
\danog\MadelineProto\Serialization::serialize('pwr.madeline', $uMadelineProto);
}