danog/telegram-entities

A library to work with Telegram UTF-16 styled text entities.

Maintainers

๐Ÿ‘ danog

Package info

github.com/danog/telegram-entities

pkg:composer/danog/telegram-entities

Fund package maintenance!

danog

Statistics

Installs: 254โ€‰667

Dependents: 7

Suggesters: 0

Stars: 25

Open Issues: 6

1.0.5 2025-06-22 12:27 UTC

Requires

Suggests

None

Provides

None

Conflicts

None

Replaces

None

Apache-2.0 19ab8a48bc4b9519c4493e2c62eb171fba8b58b4

  • Daniil Gentili <daniil.woop@daniil.it>

This package is auto-updated.

Last update: 2026-06-22 14:28:41 UTC


README

๐Ÿ‘ codecov
๐Ÿ‘ Psalm coverage
๐Ÿ‘ Psalm level 1
๐Ÿ‘ License

A library to work with Telegram UTF-16 styled text entities, created by Daniil Gentili (https://daniil.it).

This library can be used to modify entities returned by the Telegram Bot API, convert entities to HTML or even locally generate them using a custom MarkdownV2 and HTML parser inside of the library.

This library was initially created for MadelineProto, an async PHP client API for the telegram MTProto protocol.

Installation

composer require danog/telegram-entities

Usage

<?php declare(strict_types=1);

use Amp\Http\Client\HttpClientBuilder;
use Amp\Http\Client\Request;
use danog\TelegramEntities\Entities;
use danog\TelegramEntities\EntityTools;

require __DIR__.'/../vendor/autoload.php';

$token = getenv('TOKEN');
if (!$token) {
 throw new AssertionError("A TOKEN environment variable must be specified!");
}

$dest = getenv('DEST');
if (!$dest) {
 throw new AssertionError("A DEST environment variable must be specified!");
}

$client = HttpClientBuilder::buildDefault();

$sm = function (string $message, string $parse_mode = '', array $entities = []) use ($token, $dest, $client): array {
 $res = $client->request(new Request("https://api.telegram.org/bot$token/sendMessage?".http_build_query([
 'text' => $message,
 'parse_mode' => $parse_mode,
 'entities' => json_encode($entities),
 'chat_id' => $dest
 ])));

 return json_decode($res->getBody()->buffer(), true)['result'];
};

$result = $sm("*This is a โค๏ธ test*", parse_mode: "MarkdownV2");

// Convert a message+entities back to HTML
$entities = new Entities($result['text'], $result['entities']);
var_dump($entities->toHTML()); // <b>This is a โค๏ธ test</b>

// Modify $entities as needed
$entities->message = "A message with โค๏ธ emojis";

// EntityTools::mb* methods compute the length in UTF-16 code units, as required by the bot API.
$entities->entities[0]['length'] = EntityTools::mbStrlen($entities->message);

// then resend:
$sm($entities->message, entities: $entities->entities);

// Convert HTML to an array of entities locally
$entities = Entities::fromHtml("<b>This is <i>a โค๏ธ nested</i> test</b>");
$sm($entities->message, entities: $entities->entities);

// Convert markdown to an array of entities locally
$entities = Entities::fromMarkdown("*This is _a โค๏ธ nested_ test*");
$sm($entities->message, entities: $entities->entities);

// Escape text using utility methods
$generic = EntityTools::markdownEscape("Automatically escaped to prevent *markdown injection*!");
$link = EntityTools::markdownUrlEscape("https://google.com");
$code = EntityTools::markdownCodeEscape("test with autoescaped ` test");
$codeBlock = EntityTools::markdownCodeblockEscape("<?php echo 'test with autoescaped ``` test';");

$entities = Entities::fromMarkdown("This is _a โค๏ธ [nested]($link)_ `$code`

\```php
$codeBlock
\```

$generic
");

$sm($entities->message, entities: $entities->entities);

// Escape text for the HTML parser!
$generic = EntityTools::htmlEscape("Automatically escaped to prevent <b>HTML injection</b>!");
$entities = Entities::fromHtml($generic);

$sm($entities->message, entities: $entities->entities);

// See https://github.com/danog/telegram-entities for the full list of available methods!

Many more methods are available, see the API documentation for the full list!

API Documentation

Click here ยป to view the API documentation.