Skip to content

ismailian/contexto-bot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

46 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

bot-web-handler

This little project is designed specifically for Telegram bots.

Steps

  1. git clone https://github.com/ismailian/bot-web-handler
  2. mv bot-web-handler /var/www/
  3. cd /var/www/bot-web-handler/
  4. composer install
  5. cp .env.sample .env

[Configurations]

1. Set the following properties in the .env file

  • domain url APP_DOMAIN
  • bot token BOT_TOKEN
  • webhook secret TG_BOT_SIGNATURE (Optional)
  • Telegram source IP TG_SOURCE_IP (Optional)

2. Set the following properties in the config.php file

  • routes - routes to accept requests from (Optional)
  • whitelist - list of allowed user ids (Optional)
  • blacklist - list of disallowed user ids (Optional)

Examples

Photos

    /**
     * handle all incoming photos
     * 
     * @param IncomingPhoto $photo
     * @return void
     */
    #[Photo]
    public function photos(IncomingPhoto $photo): void
    {
        echo '[+] File ID: ' . $photo->getFileId(0);
    }

Videos

    /**
     * handle all incoming videos
     * 
     * @param IncomingVideo $video
     * @return void
     */
    #[Video]
    public function videos(IncomingVideo $video): void
    {
        echo '[+] File ID: ' . $video->getFileId();
    }

Commands

    /**
     * handle all incoming commands
     *
     * @return void
     */
    #[Command('start')]
    public function onStart(): void
    {
        $this->telegram->sendMessage('welcome!');
    }

Callback Queries

    /**
     * handle incoming callback query
     *
     * @param IncomingCallbackQuery $query
     * @return void
     */
    #[CallbackQuery('game:type')]
    public function callbacks(IncomingCallbackQuery $query): void
    {
        echo '[+] response: ' . $query('game:type');
    }

Releases

No releases published

Packages

No packages published

Languages