Skip to main content

No-code Telegram bot constructor

Project description

telebot-constructor

Free & open-source no-code constructor of Telegram bots for grass-roots activist initiatives and human rights organizations. Focused on privacy both for bot users and admins. Developed by bots against war team.

How to use

:warning: Under construction

Development

Basic dev setup

  1. Install Poetry (tested with versions 1.5 - 1.7). Then, install backend dependencies with
poetry install

# start new shell with poetry-created virtual env activated
poetry shell

If you have problems with poetry, you can manually create everything and install dependencies using pip from requirements.txt generated from poetry dependencies:

# example of virtual env creation and activation for unix systems
python3.12 -m venv venv
source venv/bin/activate

pip install -r requirements.txt
  1. Start backend/API
# set environment variables (example for unix-like systems)
export TELEBOT_CONSTRUCTOR_USE_REDIS_EMULATION=1
export SECRETS_ENCRYPTION_KEY=if-wLoSw7gEbQgY1xLHrEgI4E357PRUAeGfZudnaYu0=  # dummy value

# run the web app
python run_polling.py
  1. With npm v18+ install frontend and start dev server
npm install
npm run dev
  1. Visit http://localhost:8081 in the browser.

Generate TS interfaces from backend data model

On any update to Pydantic data types on backend, run

npm run pydantic:to:ts

Check that JSON schema and Typescript types are updated accordingly.

Backend

Running tests with coverage check

coverage run -m pytest tests -vv
coverage html

Then you can review htmlcov/index.html in browser.

Running linters and code checks

black .
isort .
flake8
mypy

Adding/updating backend dependencies

We keep two versions of the same dependency list:

  • poetry format (pyproject.toml + poetry.lock)
  • regular pip's requirements.txt

To modify dependency list, use poetry add depdendency@contraint.

Then, re-generate requirements.txt with (there is a github action to check it)

poetry export -f requirements.txt --output requirements.txt 

Frontend

We use:

  • Tailwind CSS
  • flowbite component library, see docs
  • svelvet (nodes/connections engine), see docs
  • flowbite-icons-svelte for icons, see catalog

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

telebot_constructor-0.1.8.tar.gz (459.2 kB view details)

Uploaded Source

Built Distribution

telebot_constructor-0.1.8-py3-none-any.whl (479.8 kB view details)

Uploaded Python 3

File details

Details for the file telebot_constructor-0.1.8.tar.gz.

File metadata

  • Download URL: telebot_constructor-0.1.8.tar.gz
  • Upload date:
  • Size: 459.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for telebot_constructor-0.1.8.tar.gz
Algorithm Hash digest
SHA256 649751dd432c57472af400fa5c5b66efee54c12e96eb056fb1c455b26a93d18c
MD5 f41b43ec8e7fcf4b8ad173d11d78e13b
BLAKE2b-256 4909eade0ccd467a068b3c2ac0887b6af28bec8f6d086eaf8d94668e93b708bc

See more details on using hashes here.

File details

Details for the file telebot_constructor-0.1.8-py3-none-any.whl.

File metadata

File hashes

Hashes for telebot_constructor-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 671553c40bbfc52725ae9b6fddfe5415bc0d8ef32efd48274f4857a19ae934d7
MD5 34db5b1f67b9bbc0e6517c2399dc9785
BLAKE2b-256 c9d3926370b44e5d022db02e8344bfca2ed65b3246f6e2def036b0f0bc828eba

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page