1
0
mirror of https://github.com/danog/MadelineProto.git synced 2024-11-27 00:14:38 +01:00
Go to file
2022-07-26 17:56:46 +02:00
.devcontainer Check output buffering level 2020-09-11 09:30:08 +02:00
.github Switch to woodpecker CI 2022-06-04 17:40:03 +02:00
.woodpecker Small fix 2022-06-23 15:15:29 +02:00
docs@60e196b7ac Update docs 2022-07-16 18:10:58 +02:00
examples Cleanup 2022-05-16 21:04:31 +02:00
schemas@89ec0d2f2b Layer 143 2022-06-25 19:29:01 +02:00
src Update PeerHandler.php 2022-07-18 17:27:57 +02:00
tests Add CI test dockerfiles 2022-07-18 16:07:50 +02:00
ton Update even more typehints 2020-10-03 15:04:35 +02:00
tools Revert 2022-05-02 22:58:55 +02:00
vendor-bin/check PsrLogger fixes 2021-09-15 17:10:38 +02:00
.env.example Improve docs 2018-03-30 16:07:54 +00:00
.gitattributes More fixes 2022-06-04 16:56:59 +02:00
.gitignore Database fixes 2022-06-25 19:15:30 +02:00
.gitmodules Update submodule 2021-09-05 21:06:36 +02:00
.php-cs-fixer.dist.php Another small fix 2021-06-11 17:27:39 +02:00
bot.php Clean up 2019-10-28 22:39:23 +01:00
CODE_OF_CONDUCT.md Clean up 2019-10-28 22:39:23 +01:00
composer.json Lock the composer-bin plugin 2022-07-18 14:41:49 +02:00
CONTRIBUTING.md Bugfixes 2017-02-13 13:27:59 +01:00
LICENSE Reorganized code 2016-08-08 18:10:13 +02:00
psalm.xml Update to layer 140 2022-05-01 19:59:07 +02:00
README.md fix 2022-07-26 17:56:46 +02:00

MadelineProto, a PHP MTProto telegram client

phabel.io - PHP transpiler

Created by Daniil Gentili

#StandWithUkraine 🇺🇦

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

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(false);
$MadelineProto->start();

$me = $MadelineProto->getSelf();

$MadelineProto->logger($me);

if (!$me['bot']) {
    // This example uses PHP 7.1+ syntax with arrays
    $MadelineProto->messages->sendMessage(['peer' => '@danogentili', 'message' => "Hi!\nThanks for creating MadelineProto (PHP 7)! <3"]);

    // This example uses PHP 8.0+ syntax with named arguments
    $MadelineProto->messages->sendMessage(peer: '@danogentili', message: "Hi!\nThanks for creating MadelineProto (PHP 8)! <3");

    $MadelineProto->channels->joinChannel(channel: '@MadelineProto');

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

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

Try running 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