mirror of
https://github.com/cwinfo/powerdns-admin.git
synced 2025-01-07 10:55:40 +00:00
Merge remote-tracking branch 'Jamesits/master'
This commit is contained in:
commit
798362c3c5
32
docker/Production/Dockerfile
Normal file
32
docker/Production/Dockerfile
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
FROM debian:stretch-slim
|
||||||
|
LABEL maintainer="k@ndk.name"
|
||||||
|
|
||||||
|
ENV LC_ALL=en_US.UTF-8 LANG=en_US.UTF-8 LANGUAGE=en_US.UTF-8
|
||||||
|
|
||||||
|
RUN apt-get update -y \
|
||||||
|
&& apt-get install -y --no-install-recommends apt-transport-https locales locales-all python3-pip python3-setuptools python3-dev curl libsasl2-dev libldap2-dev libssl-dev libxml2-dev libxslt1-dev libxmlsec1-dev libffi-dev build-essential libmariadb-dev-compat \
|
||||||
|
&& curl -sL https://deb.nodesource.com/setup_10.x | bash - \
|
||||||
|
&& curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - \
|
||||||
|
&& echo "deb https://dl.yarnpkg.com/debian/ stable main" > /etc/apt/sources.list.d/yarn.list \
|
||||||
|
&& apt-get update -y \
|
||||||
|
&& apt-get install -y nodejs yarn \
|
||||||
|
&& apt-get clean -y \
|
||||||
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
WORKDIR /opt/powerdns-admin
|
||||||
|
|
||||||
|
COPY . .
|
||||||
|
RUN pip3 install -r requirements.txt \
|
||||||
|
&& pip3 install psycopg2-binary \
|
||||||
|
&& yarn install --pure-lockfile \
|
||||||
|
&& cp config_template.py config.py \
|
||||||
|
&& flask assets build \
|
||||||
|
&& rm config.py
|
||||||
|
|
||||||
|
COPY ./docker/Production/entrypoint.sh /usr/local/bin/
|
||||||
|
RUN chmod +x /usr/local/bin/entrypoint.sh
|
||||||
|
|
||||||
|
ENV FLASK_APP=app/__init__.py
|
||||||
|
EXPOSE 80/tcp
|
||||||
|
ENTRYPOINT ["entrypoint.sh"]
|
||||||
|
CMD ["gunicorn","app:app"]
|
70
docker/Production/config_docker.py
Normal file
70
docker/Production/config_docker.py
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
# defaults for Docker image
|
||||||
|
BIND_ADDRESS='0.0.0.0'
|
||||||
|
PORT=80
|
||||||
|
|
||||||
|
legal_envvars = (
|
||||||
|
'SECRET_KEY',
|
||||||
|
'BIND_ADDRESS',
|
||||||
|
'PORT',
|
||||||
|
'TIMEOUT',
|
||||||
|
'LOG_LEVEL',
|
||||||
|
'LOG_FILE',
|
||||||
|
'SALT',
|
||||||
|
'UPLOAD_DIR',
|
||||||
|
'SQLALCHEMY_TRACK_MODIFICATIONS',
|
||||||
|
'SQLALCHEMY_DATABASE_URI',
|
||||||
|
'SAML_ENABLED',
|
||||||
|
'SAML_DEBUG',
|
||||||
|
'SAML_PATH',
|
||||||
|
'SAML_METADATA_URL',
|
||||||
|
'SAML_METADATA_CACHE_LIFETIME',
|
||||||
|
'SAML_IDP_SSO_BINDING',
|
||||||
|
'SAML_IDP_ENTITY_ID',
|
||||||
|
'SAML_NAMEID_FORMAT',
|
||||||
|
'SAML_ATTRIBUTE_EMAIL',
|
||||||
|
'SAML_ATTRIBUTE_GIVENNAME',
|
||||||
|
'SAML_ATTRIBUTE_SURNAME',
|
||||||
|
'SAML_ATTRIBUTE_NAME',
|
||||||
|
'SAML_ATTRIBUTE_USERNAME',
|
||||||
|
'SAML_ATTRIBUTE_ADMIN',
|
||||||
|
'SAML_ATTRIBUTE_GROUP',
|
||||||
|
'SAML_GROUP_ADMIN_NAME',
|
||||||
|
'SAML_GROUP_TO_ACCOUNT_MAPPING',
|
||||||
|
'SAML_ATTRIBUTE_ACCOUNT',
|
||||||
|
'SAML_SP_ENTITY_ID',
|
||||||
|
'SAML_SP_CONTACT_NAME',
|
||||||
|
'SAML_SP_CONTACT_MAIL',
|
||||||
|
'SAML_SIGN_REQUEST',
|
||||||
|
'SAML_WANT_MESSAGE_SIGNED',
|
||||||
|
'SAML_LOGOUT',
|
||||||
|
'SAML_LOGOUT_URL',
|
||||||
|
)
|
||||||
|
|
||||||
|
legal_envvars_int = (
|
||||||
|
'PORT',
|
||||||
|
'TIMEOUT',
|
||||||
|
'SAML_METADATA_CACHE_LIFETIME',
|
||||||
|
)
|
||||||
|
|
||||||
|
legal_envvars_bool = (
|
||||||
|
'SQLALCHEMY_TRACK_MODIFICATIONS',
|
||||||
|
'SAML_ENABLED',
|
||||||
|
'SAML_DEBUG',
|
||||||
|
'SAML_SIGN_REQUEST',
|
||||||
|
'SAML_WANT_MESSAGE_SIGNED',
|
||||||
|
'SAML_LOGOUT',
|
||||||
|
)
|
||||||
|
|
||||||
|
# import everything from environment variables
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
for v in legal_envvars:
|
||||||
|
if v in os.environ:
|
||||||
|
ret = os.environ[v]
|
||||||
|
if v in legal_envvars_bool:
|
||||||
|
ret = bool(ret)
|
||||||
|
if v in legal_envvars_int:
|
||||||
|
ret = int(ret)
|
||||||
|
sys.modules[__name__].__dict__[v] = ret
|
||||||
|
|
||||||
|
|
20
docker/Production/entrypoint.sh
Normal file
20
docker/Production/entrypoint.sh
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -Eeuo pipefail
|
||||||
|
cd /opt/powerdns-admin
|
||||||
|
|
||||||
|
GUNICORN_TIMEOUT="${GUINCORN_TIMEOUT:-120}"
|
||||||
|
GUNICORN_WORKERS="${GUNICORN_WORKERS:-4}"
|
||||||
|
GUNICORN_LOGLEVEL="${GUNICORN_LOGLEVEL:-info}"
|
||||||
|
|
||||||
|
if [ ! -f ./config.py ]; then
|
||||||
|
cat ./config_template.py ./docker/Production/config_docker.py > ./config.py
|
||||||
|
fi
|
||||||
|
|
||||||
|
GUNICORN_ARGS="-t ${GUNICORN_TIMEOUT} --workers ${GUNICORN_WORKERS} --bind 0.0.0.0:80 --log-level ${GUNICORN_LOGLEVEL}"
|
||||||
|
if [ "$1" == gunicorn ]; then
|
||||||
|
flask db upgrade
|
||||||
|
exec "$@" $GUNICORN_ARGS
|
||||||
|
|
||||||
|
else
|
||||||
|
exec "$@"
|
||||||
|
fi
|
Loading…
Reference in New Issue
Block a user