2017-02-11 15:16:57 +01:00
#!/usr/bin/env php
< ? php
2017-02-11 15:30:37 +01:00
/*
2018-02-20 12:13:43 +01:00
Copyright 2016 - 2018 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 />.
*/
2017-02-11 15:16:57 +01:00
2017-02-22 20:45:20 +01:00
require '../vendor/autoload.php' ;
2018-05-08 21:08:09 +02:00
$settings = [];
2017-02-11 15:16:57 +01:00
$MadelineProto = false ;
2017-05-03 12:03:51 +02:00
$uMadelineProto = false ;
2017-08-13 18:52:32 +02:00
2017-02-11 15:16:57 +01:00
try {
2017-11-03 13:02:01 +01:00
$MadelineProto = new \danog\MadelineProto\API ( 'pipesbot.madeline' );
2017-02-11 15:16:57 +01:00
} catch ( \danog\MadelineProto\Exception $e ) {
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $e -> getMessage ());
2017-05-03 12:03:51 +02:00
}
2017-08-13 18:52:32 +02:00
2017-05-03 12:03:51 +02:00
try {
2017-11-03 13:02:01 +01:00
$uMadelineProto = new \danog\MadelineProto\API ( 'pwr.madeline' );
2017-05-03 12:03:51 +02:00
} catch ( \danog\MadelineProto\Exception $e ) {
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $e -> getMessage ());
2017-02-11 15:16:57 +01:00
}
if ( file_exists ( 'token.php' ) && $MadelineProto === false ) {
include_once 'token.php' ;
$MadelineProto = new \danog\MadelineProto\API ( $settings );
2017-02-22 20:45:20 +01:00
$authorization = $MadelineProto -> bot_login ( $pipes_token );
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $authorization , \danog\MadelineProto\Logger :: NOTICE );
2017-02-11 15:16:57 +01:00
}
if ( $uMadelineProto === false ) {
echo 'Loading MadelineProto...' . PHP_EOL ;
2017-05-03 12:03:51 +02:00
$uMadelineProto = new \danog\MadelineProto\API ( array_merge ( $settings , [ 'updates' => [ 'handle_updates' => false ]]));
2017-02-11 15:18:18 +01:00
$sentCode = $uMadelineProto -> phone_login ( readline ());
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $sentCode , \danog\MadelineProto\Logger :: NOTICE );
2017-02-11 15:18:18 +01:00
echo 'Enter the code you received: ' ;
$code = fgets ( STDIN , ( isset ( $sentCode [ 'type' ][ 'length' ]) ? $sentCode [ 'type' ][ 'length' ] : 5 ) + 1 );
$authorization = $uMadelineProto -> complete_phone_login ( $code );
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $authorization , \danog\MadelineProto\Logger :: NOTICE );
2017-02-11 15:18:18 +01: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 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( '2FA is enabled' , \danog\MadelineProto\Logger :: NOTICE );
2017-02-11 15:18:18 +01:00
$authorization = $uMadelineProto -> complete_2fa_login ( readline ( 'Please enter your password (hint ' . $authorization [ 'hint' ] . '): ' ));
}
echo 'Serializing MadelineProto to session.madeline...' . PHP_EOL ;
echo 'Wrote ' . \danog\MadelineProto\Serialization :: serialize ( 'session.madeline' , $uMadelineProto ) . ' bytes' . PHP_EOL ;
2017-02-11 15:16:57 +01:00
}
2017-02-11 15:18:18 +01:00
function inputify ( & $stuff )
{
2017-02-11 15:16:57 +01:00
$stuff [ '_' ] = 'input' . ucfirst ( $stuff [ '_' ]);
2017-02-11 15:18:18 +01:00
2017-02-11 15:16:57 +01:00
return $stuff ;
}
2017-02-11 15:18:18 +01:00
function translatetext ( & $value )
{
2017-02-11 15:16:57 +01:00
inputify ( $value );
if ( isset ( $value [ 'entities' ])) {
foreach ( $value [ 'entities' ] as & $entity ) {
2017-02-11 15:18:18 +01:00
if ( $entity [ '_' ] === 'messageEntityMentionName' ) {
inputify ( $entity );
}
2017-02-11 15:16:57 +01:00
}
}
if ( isset ( $value [ 'geo' ])) {
$value [ 'geo_point' ] = inputify ( $value [ 'geo' ]);
}
}
2017-02-11 15:18:18 +01:00
function translate ( & $value , $key )
{
2017-02-11 15:16:57 +01:00
switch ( $value [ '_' ]) {
case 'botInlineResult' :
$value [ '_' ] = 'inputBotInlineResult' ;
translatetext ( $value [ 'send_message' ]);
2017-02-11 15:18:18 +01:00
2017-02-11 15:16:57 +01:00
return $value ;
case 'botInlineMediaResult' :
2017-02-11 15:18:18 +01: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' ;
}
2017-02-11 15:16:57 +01:00
translatetext ( $value [ 'send_message' ]);
2017-02-11 15:18:18 +01:00
2017-02-11 15:16:57 +01: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 19:04:37 +01:00
@ pipesbot Hey I ' m writing this using the leet filter of @ filtersbot w / @ lolcatzbot | @ filtersbot : eleet | @ lolcatzbot \ $
2017-02-11 15:16:57 +01:00
2017-02-21 19:04:37 +01: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.
2017-02-11 15:16:57 +01:00
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
2017-02-11 15:16:57 +01:00
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 15:46:05 +02:00
try {
2017-05-20 15:46:46 +02:00
switch ( $update [ 'update' ][ '_' ]) {
2017-02-11 15:16:57 +01:00
case 'updateNewMessage' :
if ( isset ( $update [ 'update' ][ 'message' ][ 'out' ]) && $update [ 'update' ][ 'message' ][ 'out' ]) {
continue ;
}
2017-08-13 18:52:32 +02:00
2017-02-11 15:16:57 +01:00
try {
2017-02-11 15:18:18 +01:00
if ( preg_match ( '|/start|' , $update [ 'update' ][ 'message' ][ 'message' ])) {
2017-02-11 15:16:57 +01:00
$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 18:52:32 +02:00
2017-02-11 15:16:57 +01:00
try {
2017-02-11 15:18:18 +01:00
if ( preg_match ( '|/start|' , $update [ 'update' ][ 'message' ][ 'message' ])) {
2017-02-11 15:16:57 +01:00
$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 15:18:18 +01: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 ];
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 );
});
$query = array_shift ( $exploded );
foreach ( $exploded as $current => $botq ) {
$bot = preg_replace ( '|:.*|' , '' , $botq );
2017-05-03 12:03:51 +02:00
if ( $bot === '' || $uMadelineProto -> get_info ( $bot )[ 'bot_api_id' ] === $MadelineProto -> API -> authorization [ 'user' ][ 'id' ]) {
2017-02-11 15:18:18 +01:00
$toset [ 'switch_pm' ] = $sswitch ;
break ;
}
$select = preg_replace ( '|' . $bot . ':|' , '' , $botq );
$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 15:16:57 +01:00
}
2017-02-11 15:18:18 +01:00
$toset [ 'gallery' ] = $results [ 'gallery' ];
$toset [ 'results' ] = [];
if ( is_numeric ( $select )) {
$toset [ 'results' ][ 0 ] = $results [ 'results' ][ $select - 1 ];
} elseif ( $select === '' ) {
$toset [ 'results' ] = $results [ 'results' ];
} else {
foreach ( $results [ 'results' ] as $result ) {
if ( isset ( $result [ 'send_message' ][ 'message' ]) && preg_match ( '|' . $select . '|' , $result [ 'send_message' ][ 'message' ])) {
$toset [ 'results' ][ 0 ] = $result ;
}
}
}
if ( ! isset ( $toset [ 'results' ][ 0 ])) {
$toset [ 'results' ] = $results [ 'results' ];
}
if ( count ( $exploded ) - 1 === $current || ! isset ( $toset [ 'results' ][ 0 ][ 'send_message' ][ 'message' ])) {
break ;
}
$query = $toset [ 'results' ][ 0 ][ 'send_message' ][ 'message' ];
2017-02-11 15:16:57 +01:00
}
}
2017-02-11 15:18:18 +01:00
if ( empty ( $toset [ 'results' ])) {
$toset [ 'switch_pm' ] = $sswitch ;
} else {
array_walk ( $toset [ 'results' ], 'translate' );
}
$MadelineProto -> messages -> setInlineBotResults ( $toset );
2017-02-11 15:16:57 +01:00
}
} catch ( \danog\MadelineProto\RPCErrorException $e ) {
try {
2017-03-11 19:54:51 +01:00
$MadelineProto -> messages -> sendMessage ([ 'peer' => '@danogentili' , 'message' => $e -> getCode () . ': ' . $e -> getMessage () . PHP_EOL . $e -> getTraceAsString ()]);
2017-02-11 15:18:18 +01:00
$MadelineProto -> messages -> sendMessage ([ 'peer' => $update [ 'update' ][ 'user_id' ], 'message' => $e -> getCode () . ': ' . $e -> getMessage () . PHP_EOL . $e -> getTraceAsString ()]);
2017-02-11 15:16:57 +01:00
} catch ( \danog\MadelineProto\RPCErrorException $e ) {
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $e -> getMessage ());
2017-02-11 15:18:18 +01:00
} catch ( \danog\MadelineProto\Exception $e ) {
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $e -> getMessage ());
2017-02-11 15:18:18 +01:00
}
2017-08-13 18:52:32 +02:00
2017-02-11 15:16:57 +01:00
try {
2017-02-11 15:18:18 +01:00
$toset [ 'switch_pm' ] = $sswitch ;
$MadelineProto -> messages -> setInlineBotResults ( $toset );
2017-02-11 15:16:57 +01:00
} catch ( \danog\MadelineProto\RPCErrorException $e ) {
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $e -> getMessage ());
2017-02-11 15:18:18 +01:00
} catch ( \danog\MadelineProto\Exception $e ) {
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $e -> getMessage ());
2017-02-11 15:18:18 +01:00
}
2017-02-11 15:16:57 +01:00
} catch ( \danog\MadelineProto\Exception $e ) {
try {
2017-03-11 19:54:51 +01:00
$MadelineProto -> messages -> sendMessage ([ 'peer' => '@danogentili' , 'message' => $e -> getCode () . ': ' . $e -> getMessage () . PHP_EOL . $e -> getTraceAsString ()]);
2017-02-11 15:18:18 +01:00
$MadelineProto -> messages -> sendMessage ([ 'peer' => $update [ 'update' ][ 'user_id' ], 'message' => $e -> getCode () . ': ' . $e -> getMessage () . PHP_EOL . $e -> getTraceAsString ()]);
2017-02-11 15:16:57 +01:00
} catch ( \danog\MadelineProto\RPCErrorException $e ) {
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $e -> getMessage ());
2017-02-11 15:18:18 +01:00
} catch ( \danog\MadelineProto\Exception $e ) {
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $e -> getMessage ());
2017-02-11 15:18:18 +01:00
}
2017-08-13 18:52:32 +02:00
2017-02-11 15:16:57 +01:00
try {
2017-02-11 15:18:18 +01:00
$toset [ 'switch_pm' ] = $sswitch ;
$MadelineProto -> messages -> setInlineBotResults ( $toset );
2017-02-11 15:16:57 +01:00
} catch ( \danog\MadelineProto\RPCErrorException $e ) {
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $e -> getMessage ());
2017-02-11 15:18:18 +01:00
} catch ( \danog\MadelineProto\Exception $e ) {
2018-03-02 01:38:10 +01:00
\danog\MadelineProto\Logger :: log ( $e -> getMessage ());
2017-02-11 15:18:18 +01:00
}
2017-02-11 15:16:57 +01:00
}
}
2017-05-20 15:46:46 +02:00
} catch ( \danog\MadelineProto\RPCErrorException $e ) {
}
2017-02-11 15:16:57 +01:00
}
2017-05-03 12:03:51 +02:00
\danog\MadelineProto\Serialization :: serialize ( 'pipesbot.madeline' , $MadelineProto );
2017-02-11 15:16:57 +01:00
\danog\MadelineProto\Serialization :: serialize ( 'pwr.madeline' , $uMadelineProto );
}