|
1 | | -# USMILE Telegram Bot |
| 1 | +<a href="https://usmileclinic.ru/"> |
| 2 | + <img src="./media/site_logo.jpg" alt="Usmile logo" title="Usmile" align="right" height="60" /> |
| 3 | +</a> |
| 4 | + |
| 5 | +# 🦷 USMILE Telegram Bot |
| 6 | + |
| 7 | +<p align="center"> |
| 8 | + <a href="https://t.me/usmile_cert_bot"> |
| 9 | + <img alt="telegram-bot" src="./media/bot_logo_small.png"> |
| 10 | + </a> |
| 11 | +</p> |
2 | 12 |
|
3 | 13 | Телеграм бот для создания партнерских сертификатов стоматологии usmile |
4 | 14 |
|
| 15 | +⭐️ Поставьте звездочку - это очень мотивирует) |
| 16 | + |
| 17 | +## Функции |
| 18 | + |
| 19 | +- Администраторы могут создавать особые ссылки для партнеров |
| 20 | +- Пройдя по ссылке, партнер пополняет свой баланс |
| 21 | +- Партнер может создавать сертификаты, используя свой баланс |
| 22 | +- Администраторы могут проверить статус сертификата по его номеру |
| 23 | +- Администраторы могут пометить сертификат как использованный |
| 24 | + |
5 | 25 | ## Техническая информация |
6 | 26 |
|
7 | 27 | ### Стек |
8 | 28 |
|
9 | 29 | - [Python3](https://www.python.org/) |
10 | | -- [Aiogram3](https://aiogram.dev/) |
11 | | -- [Peewee](https://github.com/coleifer/peewee) |
12 | | -- [Docker](https://www.docker.com/) |
13 | | -- [Docker Compose](https://docs.docker.com/compose/) |
14 | | -- [PostgreSQL](https://www.postgresql.org/) |
| 30 | +- [Aiogram3](https://aiogram.dev/) - библиотека для создания телеграм-ботов |
| 31 | +- [Peewee](https://github.com/coleifer/peewee) - легковесная ORM |
| 32 | +- [Docker](https://www.docker.com/) - контейнеризация |
| 33 | +- [Docker Compose](https://docs.docker.com/compose/) - удобный запуск нескольких контейнеров |
| 34 | +- [PostgreSQL](https://www.postgresql.org/) - база данных |
| 35 | +- [Redis](https://redis.io/) - быстрое хранилище типа ключ-значение |
| 36 | + |
| 37 | +### Разработка |
15 | 38 |
|
16 | | -### Запуск |
| 39 | +#### Установка зависимостей |
17 | 40 |
|
18 | | -#### Продакшен |
| 41 | +Зависимости устанавливаются во время сборки Docker контейнера. Но чтобы в вашем редакторе кода работало автодополнение, рекомендуется также установить зависимости в виртуальную среду: |
19 | 42 |
|
20 | 43 | ```bash |
21 | | -docker compose --profile prod up --build -d |
| 44 | +python3 -m venv .venv |
| 45 | +source ./.venv/bin/activate |
| 46 | +pip install -r requirements.txt |
22 | 47 | ``` |
23 | 48 |
|
24 | | -#### Разработка |
| 49 | +#### Запуск |
25 | 50 |
|
26 | 51 | ```bash |
27 | 52 | docker compose --profile dev up --build |
28 | 53 | ``` |
| 54 | + |
| 55 | +- `--profile dev` - использует параметры docker для разработки |
| 56 | +- `up` - запускает проект |
| 57 | +- `--build` - пересобирает контейнеры |
| 58 | + |
| 59 | +При внесении изменений в файлы на диске бот перепускается. Реализовано с помощью [volumes](https://docs.docker.com/engine/storage/volumes/) и [watchdog](https://pypi.org/project/watchdog/) |
| 60 | + |
| 61 | +#### Добавление новых пакетов |
| 62 | + |
| 63 | +Все пакеты, использующиеся проектом (даже во время разработки) должны быть добавлены в `requirements.txt` |
| 64 | + |
| 65 | +Команды ниже предполагают, чтовы уже [установили зависимости](#установка-зависимостей) |
| 66 | + |
| 67 | +```bash |
| 68 | +pip install package # package - ваш пакет |
| 69 | +pip freeze > requirements.txt # обновляет requirements.txt |
| 70 | +``` |
| 71 | + |
| 72 | +### Продакшен |
| 73 | + |
| 74 | +_Сборка и деплой автоматизированы с помощью [github-actions](https://github.com/coder8080/usmile/actions)_ |
| 75 | + |
| 76 | +**Команда запуска** |
| 77 | + |
| 78 | +```bash |
| 79 | +docker compose --profile prod up -d |
| 80 | +``` |
| 81 | + |
| 82 | +- `--profile prod` - использует параметры docker для продакшена |
| 83 | +- `up` - запускает проект |
| 84 | +- `-d` - фоновый режим и запуск при загрузке системы |
0 commit comments