Skip to content
Nova edited this page Nov 29, 2023 · 3 revisions

Delphi Telegram Bot Library v1.1.0

Delphi Telegram Bot Component

Changelog:

  • Added Inline Keyboards

Introduction

This is a Delphi Component for interacting with the Telegram Bot API. It provides a set of functions to perform various actions using the Telegram Bot platform.

  • Compatibility: VCL, FMX
  • Tested on Delphi: 11 Alexandria CE
  • Version: 1.1.0
  • Developer: Silas AÏKO

Getting Started

To use this component in your Delphi project, follow these steps:

Clone or Download the Library Source Code:

  1. Clone the component repository or download the source code as a ZIP file from the GitHub repository.
  2. Unzip the files into a directory of your choice.

Configure RAD Studio Library Paths:

  1. Open RAD Studio and navigate to "Tools > Options... > Language > Delphi."
  2. Under the "Library" section, add the "\Sources" path from the library source code to the library paths for each platform you want to compile.

Compile and Install the Package:

  1. Open the DTelegram.dproj file located in the "Package" folder of the component source code.
  2. Compile and install the package DTelegram.bpl. This step may involve right-clicking on the project file and selecting "Compile" and then "Install."

Available Functions

Function Description Example Usage
GetMe Get information about the bot. BotInfo := TelegramBot.GetMe;
LogOut Log out from the bot. LoggedOut := TelegramBot.LogOut;
Close Close the bot connection. Closed := TelegramBot.Close;
SendMessage Send a text message. Message := TelegramBot.SendMessage(ChatId, 'Hello, Telegram!');
ForwardMessage Forward a message. ForwardedMessage := TelegramBot.ForwardMessage(TargetChatId, SourceChatId, MessageId);
CopyMessage Copy a message. CopiedMessageId := TelegramBot.CopyMessage(TargetChatId, SourceChatId, MessageId);
SendPhoto Send a photo. PhotoMessage := TelegramBot.SendPhoto(ChatId, 'path/to/photo.jpg', 'Check this out!');
SendAudio Send an audio file. AudioMessage := TelegramBot.SendAudio(ChatId, 'path/to/audio.mp3', 'Listen to this!');
SendDocument Send a document. DocumentMessage := TelegramBot.SendDocument(ChatId, 'path/to/document.pdf');
SendVideo Send a video. VideoMessage := TelegramBot.SendVideo(ChatId, 'path/to/video.mp4');
SendAnimation Send an animation (GIF). AnimationMessage := TelegramBot.SendAnimation(ChatId, 'path/to/animation.gif');
SendVoice Send a voice message. VoiceMessage := TelegramBot.SendVoice(ChatId, 'path/to/voice.ogg');
SendVideoNote Send a video note. VideoNoteMessage := TelegramBot.SendVideoNote(ChatId, 'path/to/videonote.mp4');
SendLocation Send a location. LocationMessage := TelegramBot.SendLocation(ChatId, Latitude, Longitude);
SendVenue Send a venue. VenueMessage := TelegramBot.SendVenue(ChatId, Latitude, Longitude, 'Venue Title', 'Venue Address');
SendContact Send a contact. ContactMessage := TelegramBot.SendContact(ChatId, '123456789', 'John Doe');
SendPoll Send a poll. PollMessage := TelegramBot.SendPoll(ChatId, 'Which is your favorite color?', ['Red', 'Green', 'Blue']);
SendDice Send a dice. DiceMessage := TelegramBot.SendDice(ChatId, '🎲');
GetUpdates Get updates from the server. Updates := TelegramBot.GetUpdates(100, -1, 0);
GetFile Get information about a file. FileInfo := TelegramBot.GetFile(FileId);
BanChatMember Ban a chat member. Banned := TelegramBot.BanChatMember(ChatId, UserId);
UnBanChatMember Unban a chat member. UnBanned := TelegramBot.UnBanChatMember(ChatId, UserId);
CreateChatInviteLink Create a chat invite link. InviteLink := TelegramBot.CreateChatInviteLink(ChatId);
RevokeChatInviteLink Revoke a chat invite link. RevokedLink := TelegramBot.RevokeChatInviteLink(ChatId, 'your_invite_link');
ExportChatInviteLink Export a chat invite link. ExportedLink := TelegramBot.ExportChatInviteLink(ChatId);
ApproveChatJoinRequest Approve a chat join request. Approved := TelegramBot.ApproveChatJoinRequest(ChatId, UserId);
DeclineChatJoinRequest Decline a chat join request. Declined := TelegramBot.DeclineChatJoinRequest(ChatId, UserId);
DeleteChatPhoto Delete the chat photo. PhotoDeleted := TelegramBot.DeleteChatPhoto(ChatId);
SetChatTitle Set the chat title. TitleSet := TelegramBot.SetChatTitle(ChatId, 'New Title');
SetChatDescription Set the chat description. DescriptionSet := TelegramBot.SetChatDescription(ChatId, 'New Description');
LeaveChat Leave the chat. LeftChat := TelegramBot.LeaveChat(ChatId);
GetChat Get information about the chat. ChatInfo := TelegramBot.GetChat(ChatId);
SetMyName Set the bot's name. NameSet := TelegramBot.SetMyName('New Bot Name');
GetMyName Get the bot's name. BotName := TelegramBot.GetMyName();
SetMyDescription Set the bot's description. DescriptionSet := TelegramBot.SetMyDescription('New Bot Description');
GetMyDescription Get the bot's description. BotDescription := TelegramBot.GetMyDescription();
GenInlineKeyBoard A reply keyboards Response := TelegramBot.GenInlineKeyBoard(AButtonList,NumberOfButtonPerRow);

Examples for Available Functions

Set up your Bot

You need to create a bot before using this component.

Public Channel ChatId

For Public channel is super easy to find its ChatId.

   Ex : https://t.me/abcdefg   ->  ChatId := @abcdefg;

GetMe

Get information about the bot.

var BotInfo := TelegramBot.GetMe;

LogOut

Log out from the bot.

var LoggedOut := TelegramBot.LogOut;

Close

Close the bot connection.

var Closed := TelegramBot.Close;

SendMessage

Send a text message.

var Message := TelegramBot.SendMessage(ChatId, 'Hello, Telegram!');

ForwardMessage

Forward a message.

var ForwardedMessage := TelegramBot.ForwardMessage(TargetChatId, SourceChatId, MessageId);

CopyMessage

Copy a message.

var CopiedMessageId := TelegramBot.CopyMessage(TargetChatId, SourceChatId, MessageId);

SendPhoto

Send a photo.

// How use AOptions
 var AOption : TTelegramDic;   // TDictionary<string,string>;
     AOption := TTelegramDic.Create;
     AOption.Add('protect_content','1');  // Example 
 var PhotoMessage := TelegramBot.SendPhoto(ChatId, 'path/to/photo.jpg', 'Check this out!',AOption);

SendAudio

Send an audio file.

var AudioMessage := TelegramBot.SendAudio(ChatId, 'path/to/audio.mp3', 'Listen to this!');

SendDocument

Send a document.

var DocumentMessage := TelegramBot.SendDocument(ChatId, 'path/to/document.pdf');

SendVideo

Send a video.

var VideoMessage := TelegramBot.SendVideo(ChatId, 'path/to/video.mp4');

SendAnimation

Send an animation (GIF).

var AnimationMessage := TelegramBot.SendAnimation(ChatId, 'path/to/animation.gif');

SendVoice

Send a voice message.

var VoiceMessage := TelegramBot.SendVoice(ChatId, 'path/to/voice.ogg');

SendVideoNote

Send a video note.

var VideoNoteMessage := TelegramBot.SendVideoNote(ChatId, 'path/to/videonote.mp4');

SendLocation

Send a location.

var LocationMessage := TelegramBot.SendLocation(ChatId, Latitude, Longitude);

SendVenue

Send a venue.

var VenueMessage := TelegramBot.SendVenue(ChatId, Latitude, Longitude, 'Venue Title', 'Venue Address');

SendContact

Send a contact.

var ContactMessage := TelegramBot.SendContact(ChatId, '123456789', 'John Doe');

SendPoll

Send a poll.

var ListAnswers := TStringList.Create;
    ListAnswers.Add('Red');
    ListAnswers.Add('Green');
    ListAnswers.Add('Blue');

//How use Option Argument 
var Option := TStringList.Create;
    Option.Add('allows_multiple_answers=1');
    Option.Add('protect_content=true');

var PollMessage := TelegramBot.SendPoll(ChatId, 'Which is your favorite color?', ListAnswers,Option);

SendDice

Send a dice.

MyEmoji := TEmojiDice.Basketball;
var DiceMessage := TelegramBot.SendDice(ChatId, MyEmoji);

GetUpdates

Get updates from the server.

//By Default : Limit = 100;  OffSet = -1; TimeOut = 0

var Updates := TelegramBot.GetUpdates(limit,AOffSet,ATimeOut);

GetFile

Get information about a file.

var FileInfo := TelegramBot.GetFile(FileId);

BanChatMember

Ban a chat member.

var Banned := TelegramBot.BanChatMember(ChatId, UserId);

UnBanChatMember

Unban a chat member.

var UnBanned := TelegramBot.UnBanChatMember(ChatId, UserId);

CreateChatInviteLink

Create a chat invite link.

var InviteLink := TelegramBot.CreateChatInviteLink(ChatId);

RevokeChatInviteLink

Revoke a chat invite link.

var RevokedLink := TelegramBot.RevokeChatInviteLink(ChatId, 'your_invite_link');

ExportChatInviteLink

Export a chat invite link.

var ExportedLink := TelegramBot.ExportChatInviteLink(ChatId);

ApproveChatJoinRequest

Approve a chat join request.

var Approved := TelegramBot.ApproveChatJoinRequest(ChatId, UserId);

DeclineChatJoinRequest

Decline a chat join request.

var Declined := TelegramBot.DeclineChatJoinRequest(ChatId, UserId);

DeleteChatPhoto

Delete the chat photo.

var PhotoDeleted := TelegramBot.DeleteChatPhoto(ChatId);

SetChatTitle

Set the chat title.

var TitleSet := TelegramBot.SetChatTitle(ChatId, 'New Title');

SetChatDescription

Set the chat description.

var DescriptionSet := TelegramBot.SetChatDescription(ChatId, 'New Description');

LeaveChat

Leave the chat.

var LeftChat := TelegramBot.LeaveChat(ChatId);

GetChat

Get information about the chat.

var ChatInfo := TelegramBot.GetChat(ChatId);

SetMyName

Set the bot's name.

var NameSet := TelegramBot.SetMyName('New Bot Name');

GetMyName

Get the bot's name.

var BotName := TelegramBot.GetMyName();

SetMyDescription

Set the bot's description.

var DescriptionSet := TelegramBot.SetMyDescription('New Bot Description');

GetMyDescription

Get the bot's description.

var BotDescription := TelegramBot.GetMyDescription();

InlineKeyboards

Enable Inline Keyboards for interactive actions. Inline keyboards support buttons that can work behind the scenes or open different interfaces, including URL buttons.

  • Add this Unit Telegram.Api.Types;
  • Add this Unit System.Generics.Collections;

Using TEmojiConstants need a third part unit https://github.com/aso14/Delphi-Unicode-Emoji

// Example usage of Inline Keyboards
var
 LButtonList : TList <TTelegramInlineKeyBoardButton>;
begin

  LButtonList := TList<TTelegramInlineKeyBoardButton>.Create;

  // Create Button without Emoji
  var LButton1  := TTelegramInlineKeyBoardButton.Create;
      LButton1.text := 'Delphi Telegram';
      LButton1.url  := 'https://github.com/aso14/DTelegram';

  // Create Button with Emoji

  var LButton2      := TTelegramInlineKeyBoardButton.Create;
      LButton2.text := 'Delphi UI ' + TEmojiConstants.UpsideDownFace;
      LButton2.url  := 'https://t.me/delphui';

  var LButton3      := TTelegramInlineKeyBoardButton.Create;
      LButton3.text := 'Youtube '+TEmojiConstants.WinkingFace;
      LButton3.url  := 'https://www.youtube.com/@uidelphi';


  LButtonList.Add(LButton1);
  LButtonList.Add(LButton2);
  LButtonList.Add(LButton3);

  // If ALimitValue = 3, the maximun number of Button per row will be 3

  var Response := TelegramBot.GenInlineKeyBoard(LButtonList,3);

  var Option := TStringList.Create;
      Option.Add('reply_markup='+Response);

  TelegramBot.SendMessage('@chatId','Text',Option);

end;

License

This library is released under the MIT License.

Feel free to contribute, open issues, or provide feedback!