Compare commits
3 Commits
4ac6be06cf
...
a8f39d4630
| Author | SHA1 | Date | |
|---|---|---|---|
| a8f39d4630 | |||
| b3a1ea1309 | |||
| c309d4975e |
1
.gitignore
vendored
1
.gitignore
vendored
@ -3,5 +3,6 @@ __pycache__/
|
|||||||
venv/
|
venv/
|
||||||
.venv/
|
.venv/
|
||||||
logs/
|
logs/
|
||||||
|
data/
|
||||||
*.env
|
*.env
|
||||||
*.db
|
*.db
|
||||||
|
|||||||
25
Dockerfile
25
Dockerfile
@ -19,20 +19,21 @@ RUN --mount=type=cache,target=/root/.cache/pip \
|
|||||||
--mount=type=bind,source=requirements.txt,target=requirements.txt \
|
--mount=type=bind,source=requirements.txt,target=requirements.txt \
|
||||||
pip install -r requirements.txt
|
pip install -r requirements.txt
|
||||||
|
|
||||||
# copy i18n files
|
# copy sources
|
||||||
COPY --chown=bot i18n.yaml /i18n/i18n.yaml
|
COPY --chown=bot --chmod=774 docker-entrypoint.sh /app/
|
||||||
|
COPY --chown=bot migrations /app/migrations
|
||||||
|
COPY --chown=bot mybot /app/mybot
|
||||||
|
COPY --chown=bot i18n.yaml /app/
|
||||||
|
|
||||||
# copy default configs
|
# prepare environment
|
||||||
WORKDIR /app
|
ENV I18N_PATH=/data/i18n.yaml
|
||||||
COPY --chown=bot mybot mybot
|
ENV DB_URL=sqlite:////data/bot.db
|
||||||
|
|
||||||
# preapre environment
|
RUN mkdir -p /data
|
||||||
ENV SS_TYPE=memory
|
RUN chown bot:bot /data
|
||||||
ENV I18N_PATH=/i18n/i18n.yaml
|
VOLUME /data
|
||||||
|
|
||||||
# set user
|
|
||||||
USER bot
|
USER bot
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
CMD ["python3", "-m", "mybot"]
|
ENTRYPOINT ["./docker-entrypoint.sh"]
|
||||||
|
|
||||||
VOLUME i18n/
|
|
||||||
|
|||||||
17
docker-entrypoint.sh
Normal file
17
docker-entrypoint.sh
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
if [ ! -f ${I18N_PATH} ]; then
|
||||||
|
cp i18n.yaml ${I18N_PATH}
|
||||||
|
fi
|
||||||
|
|
||||||
|
alembic -c migrations/alembic.ini upgrade head
|
||||||
|
|
||||||
|
if [ $# -eq 0 ]; then
|
||||||
|
if [ -z "${USE_WEBHOOK}" ]; then
|
||||||
|
exec python3 -m mybot
|
||||||
|
else
|
||||||
|
exec gunicorn -b 0.0.0.0:8080 "mybot:main()"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
exec $1
|
||||||
|
fi
|
||||||
@ -23,8 +23,8 @@ def create_bot(config: Config, i18n: I18N, engine):
|
|||||||
register_handlers(bot)
|
register_handlers(bot)
|
||||||
setup_middlewares(bot, i18n, engine)
|
setup_middlewares(bot, i18n, engine)
|
||||||
add_custom_filters(bot, config)
|
add_custom_filters(bot, config)
|
||||||
|
bot.delete_webhook()
|
||||||
if config.use_webhook:
|
if config.use_webhook:
|
||||||
bot.delete_webhook()
|
|
||||||
bot.set_webhook(config.webhook.url,
|
bot.set_webhook(config.webhook.url,
|
||||||
drop_pending_updates=config.webhook.drop_pending_updates,
|
drop_pending_updates=config.webhook.drop_pending_updates,
|
||||||
max_connections=config.webhook.max_connections)
|
max_connections=config.webhook.max_connections)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user