################## ### Build CKAN ### ################## FROM alpine:3.17.2 as ckanbuild # Used by Github Actions to tag the image with ENV IMAGE_TAG=2.10.4-xloader # Set CKAN version to build ENV GIT_URL=https://github.com/ckan/ckan.git ENV GIT_BRANCH=ckan-2.10.4 # Set src dirs ENV SRC_DIR=/srv/app/src ENV PIP_SRC=${SRC_DIR} WORKDIR ${SRC_DIR} # Packages to build CKAN requirements and plugins RUN apk add --no-cache \ python3 \ python3-dev \ git \ curl \ postgresql-dev \ linux-headers \ gcc \ make \ g++ \ autoconf \ automake \ libtool \ patch \ musl-dev \ pcre-dev \ pcre \ libffi-dev \ libxml2-dev \ libxslt-dev # Create the src directory RUN mkdir -p ${SRC_DIR} # Install pip RUN curl -o ${SRC_DIR}/get-pip.py https://bootstrap.pypa.io/get-pip.py && \ python ${SRC_DIR}/get-pip.py # Downgrade setuptools so that CKAN requirements can be built RUN pip install setuptools==44.1.0 # Fetch and build CKAN and requirements RUN pip install -e git+${GIT_URL}@${GIT_BRANCH}#egg=ckan # Copy patches and apply patches script COPY ./patches ${SRC_DIR}/patches COPY ./scripts/apply_ckan_patches.sh ${SRC_DIR}/apply_ckan_patches.sh # Apply patches # RUN ${SRC_DIR}/apply_ckan_patches.sh RUN rm -rf /srv/app/src/ckan/.git RUN pip wheel --wheel-dir=/wheels -r ckan/requirements.txt RUN pip wheel --wheel-dir=/wheels uWSGI==2.0.20 gevent==22.10.2 greenlet==2.0.2 ########################### ### Default-Extensions #### ########################### FROM alpine:3.17.2 as extbuild # Set src dirs ENV SRC_DIR=/srv/app/src ENV PIP_SRC=${SRC_DIR} # List of default extensions ENV DEFAULT_EXTENSIONS envvars # Locations and tags, please use specific tags or revisions ENV ENVVARS_GIT_URL=https://github.com/okfn/ckanext-envvars ENV ENVVARS_GIT_BRANCH=0.0.2 RUN apk add --no-cache \ python3 \ python3-dev \ git \ curl # Create the src directory RUN mkdir -p ${SRC_DIR} # Install pip RUN curl -o ${SRC_DIR}/get-pip.py https://bootstrap.pypa.io/get-pip.py && \ python ${SRC_DIR}/get-pip.py # Fetch and build the default CKAN extensions RUN pip wheel --wheel-dir=/wheels git+${ENVVARS_GIT_URL}@${ENVVARS_GIT_BRANCH}#egg=ckanext-envvars ############ ### MAIN ### ############ FROM alpine:3.17.2 LABEL maintainer="Keitaro Inc " LABEL org.opencontainers.image.source https://github.com/keitaroinc/docker-ckan ENV APP_DIR=/srv/app ENV SRC_DIR=/srv/app/src ENV CKAN_DIR=${SRC_DIR}/ckan ENV DATA_DIR=/srv/app/data ENV PIP_SRC=${SRC_DIR} ENV CKAN_SITE_URL=http://localhost:5000 ENV CKAN__PLUGINS envvars image_view text_view recline_view datastore xloader # Install necessary packages to run CKAN RUN apk add --no-cache \ supervisor \ python3 \ bash \ git \ gettext \ curl \ postgresql-client \ libmagic \ pcre \ libxslt \ libxml2 \ tzdata \ apache2-utils && \ # Create SRC_DIR mkdir -p ${SRC_DIR} # Install pip RUN curl -o ${SRC_DIR}/get-pip.py https://bootstrap.pypa.io/get-pip.py && \ python ${SRC_DIR}/get-pip.py ### XLoader ### RUN pip3 install -e 'git+https://github.com/keitaroinc/ckanext-xloader.git@master#egg=ckanext-xloader' && \ pip3 install -r ${SRC_DIR}/ckanext-xloader/requirements.txt && \ pip3 install -U requests[security] # Get artifacts from build stages COPY --from=ckanbuild /wheels /srv/app/wheels COPY --from=extbuild /wheels /srv/app/ext_wheels COPY --from=ckanbuild /srv/app/src/ckan ${CKAN_DIR} # Additional install steps for build stages artifacts RUN pip install --no-index --find-links=/srv/app/wheels uWSGI==2.0.20 gevent==22.10.2 # Create a local user and group to run the app RUN addgroup -g 92 -S ckan && \ adduser -u 92 -h /srv/app -H -D -S -G ckan ckan WORKDIR ${CKAN_DIR} # Install CKAN RUN pip install -e /srv/app/src/ckan && \ cp who.ini ${APP_DIR} && \ pip install --no-index --find-links=/srv/app/wheels -r requirements.txt && \ # Install default CKAN extensions pip install --no-index --find-links=/srv/app/ext_wheels ckanext-envvars && \ # Create and update CKAN config # Set timezone echo "UTC" > /etc/timezone && \ # Generate CKAN config ckan generate config ${APP_DIR}/production.ini && \ ckan config-tool ${APP_DIR}/production.ini "beaker.session.secret = " && \ # Configure plugins ckan config-tool ${APP_DIR}/production.ini "ckan.plugins = ${CKAN__PLUGINS}" && \ # Create the data directory mkdir ${DATA_DIR} && \ # Webassets can't be loaded from env variables at runtime, it needs to be in the config so that it is created ckan config-tool ${APP_DIR}/production.ini "ckan.webassets.path = ${DATA_DIR}/webassets" && \ # Set the default level for extensions to INFO ckan config-tool ${APP_DIR}/production.ini -s logger_ckanext -e level=INFO && \ # Change ownership to app user chown -R ckan:ckan /srv/app # Remove wheels RUN rm -rf /srv/app/wheels /srv/app/ext_wheels # Copy necessary scripts COPY setup/app ${APP_DIR} WORKDIR ${APP_DIR} # Create entrypoint directory for children image scripts RUN mkdir docker-entrypoint.d # Create afterinit directory for children image scripts RUN mkdir docker-afterinit.d RUN pip install supervisor RUN mkdir /var/supervisor RUN mkdir /var/log/ckan RUN mkdir /etc/supervisor/conf.d/ -p COPY supervisorvalidation.conf /etc/supervisor/conf.d/supervisor-ckan-worker.conf COPY supervisord.conf /etc/supervisord.conf COPY supervisorstart.sh /srv/app/docker-afterinit.d # Change ownership to app user RUN chown -R ckan:ckan ${APP_DIR} /var/supervisor /var/log/ckan /etc/supervisor/conf.d/ EXPOSE 5000 HEALTHCHECK --interval=10s --timeout=5s --retries=5 CMD curl --fail http://localhost:5000/api/3/action/status_show || exit 1 USER ckan CMD ["/srv/app/start_ckan.sh"]