This project was built to demonstrate how we at @baivaru structures - our async pyrogram projects. I could have written a skeleton (directory structures, modules showing where plugins are loaded from and etc) which you could simply clone and build upon. However, doing that could have left you halfway through the whole purpose of “making it easier” and having a skeleton. Therefore, the following project is a fully functional bot that demonstrates most of the common methods, functionalities that pyrogram offers you to start programing a simple telegram bot and some clean practices that we at @baivaru follow which you could refer and imply with your projects.
git clone https://github.com/eyaadh/pyro-sekeleton-async.git
, to clone the repository.cd pyro-sekeleton-async
, to enter the directory.pip3 install -U https://github.com/pyrogram/pyrogram/archive/asyncio.zip
, to install pyrogram-asyncio.pip3 install -r requirements.txt
, to install rest of the dependencies/requirements.- Create a new
config.ini
using the sample available atpyro-sekeleton-async\working_dir
. - Run with
python3.8 -m pyro
, stop with CTRL+C.
It is recommended to use virtual environments while running the app, this is a good practice you can use at any of your python projects as virtualenv creates an isolated Python environment which is specific to your project.
pyro-sekeleton-async/
└── pyro/
├── plugins/
├── utils/
│ └── helpers/
└── working_dir/
This directory consists of Pyrogram's a smart, lightweight yet powerful plugin's which enables us to simplify and organize large projects with modular base components. More in regards to smart plugins can be found here.
The name utils define exactly what this directory is for. All the 3rd party utilities that helps the application to work through is kept in this directory, such as DB module (if that exists), a module called common which loads the required external variables(mostly configurations from configs.ini) and etc.
Helpers directory consists of modules that connects to 3rd party APIs to help the application gather the data it requires.
This directory basically consists of the config.ini file/s, the session file/s generated by the application. Also if there are temporary files that are generated by the application we tend to leave them within this directory at the course of their existence.
As explained on the pyrogram configuration, the library allows us to make
use of a config.ini
file: in which we could specify the credentials, api keys and other variables that we do not want
to share within our source code.
The configuration file consists of sections, each led by a [section]
header, followed by
key/value entries separated by a specific string (= or : by default). By default, section names are case sensitive
but keys are not. Leading and trailing whitespace is removed from keys and values. Values can be omitted, in which
case the key/value delimiter may also be left out. Values can also span multiple lines, as long as they are indented
deeper than the first line of the value. The values mentioned on configuration files are parse using the pyro/utils/common.py
module.
More details on config files and configparser can be found here.