Compare commits

...

3 Commits

5 changed files with 32 additions and 13 deletions

1
.gitignore vendored
View File

@ -3,5 +3,6 @@ __pycache__/
venv/
.venv/
logs/
data/
*.env
*.db

View File

@ -19,20 +19,21 @@ RUN --mount=type=cache,target=/root/.cache/pip \
--mount=type=bind,source=requirements.txt,target=requirements.txt \
pip install -r requirements.txt
# copy i18n files
COPY --chown=bot i18n.yaml /i18n/i18n.yaml
# copy sources
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
WORKDIR /app
COPY --chown=bot mybot mybot
# prepare environment
ENV I18N_PATH=/data/i18n.yaml
ENV DB_URL=sqlite:////data/bot.db
# preapre environment
ENV SS_TYPE=memory
ENV I18N_PATH=/i18n/i18n.yaml
RUN mkdir -p /data
RUN chown bot:bot /data
VOLUME /data
# set user
USER bot
WORKDIR /app
CMD ["python3", "-m", "mybot"]
VOLUME i18n/
ENTRYPOINT ["./docker-entrypoint.sh"]

17
docker-entrypoint.sh Normal file
View 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

View File

@ -23,8 +23,8 @@ def create_bot(config: Config, i18n: I18N, engine):
register_handlers(bot)
setup_middlewares(bot, i18n, engine)
add_custom_filters(bot, config)
bot.delete_webhook()
if config.use_webhook:
bot.delete_webhook()
bot.set_webhook(config.webhook.url,
drop_pending_updates=config.webhook.drop_pending_updates,
max_connections=config.webhook.max_connections)