Async PHP client/server API for the telegram MTProto protocol https://docs.madelineproto.xyz
Go to file
Daniil Gentili 444d55355a
Switch to external loop
2020-07-28 20:39:32 +02:00
.github Funding 2020-06-16 18:00:15 +02:00
.phan Clean up 2020-06-15 20:06:48 +02:00
docs@d119b3d80d Misc fixes 2020-06-20 13:03:15 +02:00
examples IPC fixes 2020-07-12 00:17:47 +02:00
legacy/danog/MadelineProto Clean up 2020-06-15 20:06:48 +02:00
schemas@03fe872f15 Fix CDN DCs 2020-07-23 18:08:14 +02:00
src Switch to external loop 2020-07-28 20:39:32 +02:00
tests Update to layer 110 2020-03-06 13:09:52 +01:00
ton Adding getUrl command in the downloadbot 2020-02-09 17:29:39 +01:00
tools Switch to external loop 2020-07-28 20:39:32 +02:00
.env.example Improve docs 2018-03-30 16:07:54 +00:00
.gitignore Clean up 2020-06-15 20:06:48 +02:00
.gitmodules Allow git modules install without ssh key (#810) 2020-05-10 19:17:15 +02:00
.php_cs.dist cs-fix 2019-10-29 22:00:21 +01:00
.travis.yml Provide DNS fallback 2020-02-26 00:11:06 +01:00
CODE_OF_CONDUCT.md Clean up 2019-10-28 22:39:23 +01:00
CONTRIBUTING.md Bugfixes 2017-02-13 13:27:59 +01:00
LICENSE Reorganized code 2016-08-08 18:10:13 +02:00
README.md Layer 113 2020-06-16 17:52:55 +02:00
bot.php Clean up 2019-10-28 22:39:23 +01:00
composer.json Switch to external loop 2020-07-28 20:39:32 +02:00
psalm.xml Clean up 2020-06-15 20:06:48 +02:00

README.md

MadelineProto, a PHP MTProto telegram client

Created by Daniil Gentili

Do join the official channel, @MadelineProto and the support groups!

Now with Telegram TON blockchain integration!

Approved by Telegram!

What's this?

This library can be used to easily interact with Telegram without the bot API, just like the official apps.

It can login with a phone number (MTProto API), or with a bot token (MTProto API, no bot API involved!).

It is now fully async!

Getting started (now fully async!)

<?php

if (!file_exists('madeline.php')) {
    copy('https://phar.madelineproto.xyz/madeline.php', 'madeline.php');
}
include 'madeline.php';

$MadelineProto = new \danog\MadelineProto\API('session.madeline');
$MadelineProto->async(true);
$MadelineProto->loop(function () use ($MadelineProto) {
    yield $MadelineProto->start();

    $me = yield $MadelineProto->getSelf();

    $MadelineProto->logger($me);

    if (!$me['bot']) {
        yield $MadelineProto->messages->sendMessage(['peer' => '@danogentili', 'message' => "Hi!\nThanks for creating MadelineProto! <3"]);
        yield $MadelineProto->channels->joinChannel(['channel' => '@MadelineProto']);

        try {
            yield $MadelineProto->messages->importChatInvite(['hash' => 'https://t.me/joinchat/Bgrajz6K-aJKu0IpGsLpBg']);
        } catch (\danog\MadelineProto\RPCErrorException $e) {
            $MadelineProto->logger($e);
        }

        yield $MadelineProto->messages->sendMessage(['peer' => 'https://t.me/joinchat/Bgrajz6K-aJKu0IpGsLpBg', 'message' => 'Testing MadelineProto!']);
    }
    yield $MadelineProto->echo('OK, done!');
});

Try this code now! or run this code in a browser or in a console.

Tip: if you receive an error (or nothing), send us the error message and the MadelineProto.log file that was created in the same directory (if running from a browser).

Examples

You can find examples for nearly every MadelineProto function in

  • magnaluna webradio - Multifeatured Telegram VoIP webradio
  • downloadRenameBot.php - download files by URL and rename Telegram files using this async parallelized bot!
  • bot.php - examples for sending normal messages, downloading any media
  • secret_bot.php - secret chat bot
  • pipesbot.php - examples for creating inline bots and using other inline bots via a userbot

Documentation