- 
                Notifications
    You must be signed in to change notification settings 
- Fork 0
Local Bot API Server
        Hinrich Mahler edited this page Aug 2, 2024 
        ·
        10 revisions
      
    Since Bot API 5.0, Telegram made the Bot API server open source, allowing you to host your own instance. For details on what benefits hosting your own instance has and how it works, please see the official docs.
Bot API 5.0 (and therefore local API server) is supported by PTB since v13.1.
- Before you can move your bot from the official server cloud to a self hosted server, you need to call the log_outmethod.
- Before moving from one self hosted instance to another, you need to use the delete_webhookandclosemethods.
- To make PTB aware that you're not using the official server, pass the following to your ApplicationBuilder(orBot):- base_url='your-bot-api-server.com/bot'
 
- When running the server with the --localflag- you need to set local_mode=True
- 
get_filewill give you the local file path asfile_path. PTB detects that, so thatawait get_file(…).download_to_drive()just returns the local file string instead of downloading it.
- you can send files by passing 'file:///absolute/path/to/file'instead of an URL or a file handle.
- passing relative paths (without prefix) or even passing pathlib.Pathobjects is supported as well, even if you're not running inlocalmode, in which case it will be opened and send via upload as usual.
- To adjust for larger file sizes transmitted between PTB and the local API server, it may be beneficial to extend the timeout values for networking operations. See the wiki pages on handling networking errors as well as on adding defaults. Additionally, it may be beneficial to not read the complete file into memory before sending it, but rather stream it. This can be achieved by setting the parameter read_file_handletoFalse. See also this wiki page.
 
- you need to set 
- When running the server without the --localflag- you need to set base_file_url='your-bot-api-server.com/file/bot'
- the Bot API server does not automatically serve the files obtained by get_file(), see telegram-bot-api/#26. So be aware that you have to run a web server which serves them, otherwise you will run into 404 errors.
 
- you need to set 
- Wiki of python-telegram-bot© Copyright 2015-2025 – Licensed by Creative Commons
- Architecture Overview
- Builder Pattern for Application
- Types of Handlers
- Working with Files and Media
- Exceptions, Warnings and Logging
- Concurrency in PTB
- Advanced Filters
- Storing data
- Making your bot persistent
- Adding Defaults
- Job Queue
- Arbitrary callback_data
- Avoiding flood limits
- Webhooks
- Bot API Forward Compatiblity
- Frequently requested design patterns
- Code snippets
- Performance Optimizations
- Telegram Passport
- Bots built with PTB
- Automated Bot Tests