2019-09-16 12:48:11 +00:00
|
|
|
########################################################################
|
|
|
|
#
|
|
|
|
# pgAdmin 4 - PostgreSQL Tools
|
|
|
|
#
|
|
|
|
# Copyright (C) 2013 - 2018, The pgAdmin Development Team
|
|
|
|
# This software is released under the PostgreSQL Licence
|
|
|
|
#
|
|
|
|
#########################################################################
|
|
|
|
|
|
|
|
#########################################################################
|
|
|
|
# Create a Node container which will be used to build the JS components
|
|
|
|
# and clean up the web/ source code
|
|
|
|
#########################################################################
|
|
|
|
|
2021-01-20 13:17:21 +00:00
|
|
|
FROM node:14-alpine3.12 AS app-builder
|
2019-09-16 12:48:11 +00:00
|
|
|
|
|
|
|
RUN apk add --no-cache \
|
|
|
|
autoconf \
|
|
|
|
automake \
|
|
|
|
bash \
|
|
|
|
g++ \
|
|
|
|
libc6-compat \
|
|
|
|
libjpeg-turbo-dev \
|
|
|
|
libpng-dev \
|
|
|
|
make \
|
|
|
|
nasm \
|
|
|
|
git \
|
|
|
|
zlib-dev
|
|
|
|
|
|
|
|
# Create the /pgadmin4 directory and copy the source into it. Explicitly
|
|
|
|
# remove the node_modules directory as we'll recreate a clean version, as well
|
|
|
|
# as various other files we don't want
|
|
|
|
COPY web /pgadmin4/web
|
|
|
|
RUN rm -rf /pgadmin4/web/*.log \
|
|
|
|
/pgadmin4/web/config_*.py \
|
|
|
|
/pgadmin4/web/node_modules \
|
|
|
|
/pgadmin4/web/regression \
|
|
|
|
`find /pgadmin4/web -type d -name tests` \
|
|
|
|
`find /pgadmin4/web -type f -name .DS_Store`
|
|
|
|
|
|
|
|
WORKDIR /pgadmin4/web
|
|
|
|
|
|
|
|
# Build the JS vendor code in the app-builder, and then remove the vendor source.
|
|
|
|
RUN npm install && \
|
|
|
|
npm audit fix && \
|
|
|
|
rm -f yarn.lock && \
|
|
|
|
yarn import && \
|
2020-07-02 10:51:00 +00:00
|
|
|
# Commented the below line to avoid vulnerability in lodash package.
|
|
|
|
# Refer https://www.npmjs.com/advisories/1523.
|
|
|
|
# Once fixed we will uncomment it.
|
2020-02-28 11:59:32 +00:00
|
|
|
# yarn audit && \
|
2019-09-16 12:48:11 +00:00
|
|
|
rm -f package-lock.json && \
|
|
|
|
yarn run bundle && \
|
|
|
|
rm -rf node_modules \
|
|
|
|
yarn.lock \
|
|
|
|
package.json \
|
|
|
|
.[^.]* \
|
|
|
|
babel.cfg \
|
|
|
|
webpack.* \
|
|
|
|
karma.conf.js \
|
|
|
|
./pgadmin/static/js/generated/.cache
|
|
|
|
|
|
|
|
#########################################################################
|
|
|
|
# Now, create a documentation build container for the Sphinx docs
|
|
|
|
#########################################################################
|
|
|
|
|
2021-02-08 11:00:41 +00:00
|
|
|
FROM python:3.9-alpine3.13 as docs-builder
|
2019-09-16 12:48:11 +00:00
|
|
|
|
2021-02-01 10:52:41 +00:00
|
|
|
# Install dependencies
|
|
|
|
COPY requirements.txt /
|
2019-09-16 12:48:11 +00:00
|
|
|
RUN apk add --no-cache \
|
|
|
|
make \
|
|
|
|
build-base \
|
|
|
|
openssl-dev \
|
2021-02-01 10:52:41 +00:00
|
|
|
libffi-dev \
|
|
|
|
postgresql-dev \
|
2021-02-08 11:00:41 +00:00
|
|
|
krb5-dev \
|
|
|
|
rust \
|
|
|
|
cargo && \
|
2019-09-16 12:48:11 +00:00
|
|
|
pip install --no-cache-dir \
|
2021-02-01 10:52:41 +00:00
|
|
|
sphinx && \
|
|
|
|
pip install --no-cache-dir -r requirements.txt
|
2019-09-16 12:48:11 +00:00
|
|
|
|
|
|
|
# Copy the docs from the local tree. Explicitly remove any existing builds that
|
|
|
|
# may be present
|
|
|
|
COPY docs /pgadmin4/docs
|
|
|
|
COPY web /pgadmin4/web
|
|
|
|
RUN rm -rf /pgadmin4/docs/en_US/_build
|
|
|
|
|
|
|
|
# Build the docs
|
|
|
|
RUN LC_ALL=en_US.UTF-8 LANG=en_US.UTF-8 make -C /pgadmin4/docs/en_US -f Makefile.sphinx html
|
|
|
|
|
2021-02-01 16:55:03 +00:00
|
|
|
# Cleanup unwanted files
|
|
|
|
RUN rm -rf /pgadmin4/docs/en_US/_build/html/_sources
|
|
|
|
RUN rm -rf /pgadmin4/docs/en_US/_build/html/_static/*.png
|
|
|
|
|
2019-09-16 12:48:11 +00:00
|
|
|
#########################################################################
|
|
|
|
# Create additional builders to get all of the PostgreSQL utilities
|
|
|
|
#########################################################################
|
|
|
|
|
|
|
|
FROM postgres:9.6-alpine as pg96-builder
|
|
|
|
FROM postgres:10-alpine as pg10-builder
|
|
|
|
FROM postgres:11-alpine as pg11-builder
|
2019-10-11 10:13:06 +00:00
|
|
|
FROM postgres:12-alpine as pg12-builder
|
2021-01-20 13:17:21 +00:00
|
|
|
FROM postgres:13-alpine as pg13-builder
|
2019-09-16 12:48:11 +00:00
|
|
|
|
2021-02-08 11:00:41 +00:00
|
|
|
FROM alpine:3.13 as tool-builder
|
2019-09-16 12:48:11 +00:00
|
|
|
|
|
|
|
# Copy the PG binaries
|
|
|
|
|
|
|
|
COPY --from=pg96-builder /usr/local/bin/pg_dump /usr/local/pgsql/pgsql-9.6/
|
|
|
|
COPY --from=pg96-builder /usr/local/bin/pg_dumpall /usr/local/pgsql/pgsql-9.6/
|
|
|
|
COPY --from=pg96-builder /usr/local/bin/pg_restore /usr/local/pgsql/pgsql-9.6/
|
|
|
|
COPY --from=pg96-builder /usr/local/bin/psql /usr/local/pgsql/pgsql-9.6/
|
|
|
|
|
|
|
|
COPY --from=pg10-builder /usr/local/bin/pg_dump /usr/local/pgsql/pgsql-10/
|
|
|
|
COPY --from=pg10-builder /usr/local/bin/pg_dumpall /usr/local/pgsql/pgsql-10/
|
|
|
|
COPY --from=pg10-builder /usr/local/bin/pg_restore /usr/local/pgsql/pgsql-10/
|
|
|
|
COPY --from=pg10-builder /usr/local/bin/psql /usr/local/pgsql/pgsql-10/
|
|
|
|
|
|
|
|
COPY --from=pg11-builder /usr/local/bin/pg_dump /usr/local/pgsql/pgsql-11/
|
|
|
|
COPY --from=pg11-builder /usr/local/bin/pg_dumpall /usr/local/pgsql/pgsql-11/
|
|
|
|
COPY --from=pg11-builder /usr/local/bin/pg_restore /usr/local/pgsql/pgsql-11/
|
|
|
|
COPY --from=pg11-builder /usr/local/bin/psql /usr/local/pgsql/pgsql-11/
|
|
|
|
|
2019-10-11 10:13:06 +00:00
|
|
|
COPY --from=pg12-builder /usr/local/bin/pg_dump /usr/local/pgsql/pgsql-12/
|
|
|
|
COPY --from=pg12-builder /usr/local/bin/pg_dumpall /usr/local/pgsql/pgsql-12/
|
|
|
|
COPY --from=pg12-builder /usr/local/bin/pg_restore /usr/local/pgsql/pgsql-12/
|
|
|
|
COPY --from=pg12-builder /usr/local/bin/psql /usr/local/pgsql/pgsql-12/
|
|
|
|
|
2021-01-20 13:17:21 +00:00
|
|
|
COPY --from=pg13-builder /usr/local/bin/pg_dump /usr/local/pgsql/pgsql-13/
|
|
|
|
COPY --from=pg13-builder /usr/local/bin/pg_dumpall /usr/local/pgsql/pgsql-13/
|
|
|
|
COPY --from=pg13-builder /usr/local/bin/pg_restore /usr/local/pgsql/pgsql-13/
|
|
|
|
COPY --from=pg13-builder /usr/local/bin/psql /usr/local/pgsql/pgsql-13/
|
|
|
|
|
2019-09-16 12:48:11 +00:00
|
|
|
#########################################################################
|
|
|
|
# Assemble everything into the final container.
|
|
|
|
#########################################################################
|
|
|
|
|
2021-02-08 11:00:41 +00:00
|
|
|
FROM python:3.9-alpine3.13
|
2019-09-16 12:48:11 +00:00
|
|
|
|
|
|
|
COPY --from=tool-builder /usr/local/pgsql /usr/local/
|
|
|
|
|
|
|
|
WORKDIR /pgadmin4
|
|
|
|
ENV PYTHONPATH=/pgadmin4
|
|
|
|
|
|
|
|
# Copy in the code and docs
|
|
|
|
COPY --from=app-builder /pgadmin4/web /pgadmin4
|
|
|
|
COPY --from=docs-builder /pgadmin4/docs/en_US/_build/html/ /pgadmin4/docs
|
|
|
|
COPY requirements.txt /pgadmin4/requirements.txt
|
|
|
|
|
2020-07-17 16:06:16 +00:00
|
|
|
# License files
|
|
|
|
COPY LICENSE /pgadmin4/LICENSE
|
|
|
|
COPY DEPENDENCIES /pgadmin4/DEPENDENCIES
|
|
|
|
|
2019-09-16 12:48:11 +00:00
|
|
|
# Install build-dependencies, build & install C extensions and purge deps in
|
|
|
|
# one RUN step
|
|
|
|
RUN apk add --no-cache --virtual \
|
|
|
|
build-deps \
|
|
|
|
build-base \
|
|
|
|
postgresql-dev \
|
|
|
|
libffi-dev \
|
2021-01-18 11:02:10 +00:00
|
|
|
krb5-dev \
|
|
|
|
e2fsprogs-dev \
|
|
|
|
krb5-server-ldap \
|
2021-02-08 11:00:41 +00:00
|
|
|
linux-headers \
|
|
|
|
rust \
|
|
|
|
cargo && \
|
2019-09-16 12:48:11 +00:00
|
|
|
apk add \
|
|
|
|
postfix \
|
|
|
|
postgresql-client \
|
2019-12-09 05:39:46 +00:00
|
|
|
postgresql-libs \
|
2021-01-18 11:02:10 +00:00
|
|
|
krb5-libs \
|
2019-12-09 05:39:46 +00:00
|
|
|
shadow \
|
2020-01-20 10:41:27 +00:00
|
|
|
sudo \
|
2019-12-09 05:39:46 +00:00
|
|
|
libcap && \
|
2019-09-16 12:48:11 +00:00
|
|
|
pip install --upgrade pip && \
|
|
|
|
pip install --no-cache-dir -r requirements.txt && \
|
2021-02-01 17:29:06 +00:00
|
|
|
pip install --no-cache-dir gunicorn && \
|
2020-01-20 10:41:27 +00:00
|
|
|
apk del --no-cache build-deps && \
|
|
|
|
echo "pgadmin ALL = NOPASSWD: /usr/sbin/postfix start" > /etc/sudoers.d/postfix
|
2019-09-16 12:48:11 +00:00
|
|
|
|
2021-01-20 13:17:21 +00:00
|
|
|
# We need the v13 libpq
|
|
|
|
COPY --from=pg13-builder /usr/local/lib/libpq.so.5.13 /usr/lib/
|
|
|
|
RUN ln -sf /usr/lib/libpq.so.5.13 /usr/lib/libpq.so.5
|
2019-11-07 06:42:43 +00:00
|
|
|
|
2021-02-01 17:35:23 +00:00
|
|
|
# Copy the various scripts
|
2019-09-16 12:48:11 +00:00
|
|
|
COPY pkg/docker/run_pgadmin.py /pgadmin4
|
2020-10-20 11:44:45 +00:00
|
|
|
COPY pkg/docker/gunicorn_config.py /pgadmin4
|
2019-09-16 12:48:11 +00:00
|
|
|
COPY pkg/docker/entrypoint.sh /entrypoint.sh
|
|
|
|
|
|
|
|
# Precompile and optimize python code to save time and space on startup
|
|
|
|
RUN python -O -m compileall -x node_modules /pgadmin4
|
|
|
|
|
2019-12-09 05:39:46 +00:00
|
|
|
RUN groupadd -g 5050 pgadmin && \
|
|
|
|
useradd -r -u 5050 -g pgadmin pgadmin && \
|
|
|
|
mkdir -p /var/lib/pgadmin && \
|
|
|
|
chown pgadmin:pgadmin /var/lib/pgadmin && \
|
|
|
|
touch /pgadmin4/config_distro.py && \
|
|
|
|
chown pgadmin:pgadmin /pgadmin4/config_distro.py && \
|
2021-01-20 13:17:21 +00:00
|
|
|
setcap CAP_NET_BIND_SERVICE=+eip /usr/local/bin/python3.9
|
2019-12-09 05:39:46 +00:00
|
|
|
USER pgadmin
|
|
|
|
|
2019-09-16 12:48:11 +00:00
|
|
|
# Finish up
|
|
|
|
VOLUME /var/lib/pgadmin
|
|
|
|
EXPOSE 80 443
|
|
|
|
|
|
|
|
ENTRYPOINT ["/entrypoint.sh"]
|