Skip to content

Commit

Permalink
build: Extend Jenkinsfile to cover homepage build
Browse files Browse the repository at this point in the history
* Add Dockerfiles
  * backend (restapi)
  * frontend (website)
* Build restapi doc via Dockerfile.doc + test_doc stage
* Build frontend and backend and push to registry
* Deploy docker images on target node

Also includes changes to rest-backend so it runs with the correct PID.
  • Loading branch information
ingwinlu committed May 16, 2018
1 parent 5c97e8e commit f2659df
Show file tree
Hide file tree
Showing 5 changed files with 292 additions and 19 deletions.
3 changes: 3 additions & 0 deletions scripts/docker/debian/stretch/Dockerfile.doc
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,15 @@ RUN apt-get update && apt-get -y install \
RUN apt-get -y install \
doxygen \
graphviz \
ruby \
ruby-dev \
ruby-ronn \
sloccount \
texlive-latex-base \
texlive-latex-recommended \
texlive-latex-extra \
texlive-fonts-recommended \
&& gem install apiaryio \
&& rm -rf /var/lib/apt/lists/*

# Create User:Group
Expand Down
112 changes: 112 additions & 0 deletions scripts/docker/homepage/backend/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,112 @@
FROM debian:stretch
ENV LANG C.UTF-8
ENV LANGUAGE C.UTF-8
ENV LC_ALL C.UTF-8

RUN apt-get update && apt-get -y install \
cmake git build-essential curl \
libboost-all-dev \
libpcre3-dev \
zlib1g-dev \
libgcrypt11-dev \
libicu-dev \
python \
libssl-dev \
libyajl-dev \
autoconf \
automake \
pkg-config \
net-tools \
&& rm -rf /var/lib/apt/lists/*

ARG PARALLEL=2
WORKDIR /app/deps
ARG CPPCMS_VERSION="1.2.0"
RUN curl -o cppcms-${CPPCMS_VERSION}.tar.bz -L \
"https://sourceforge.net/projects/cppcms/files/cppcms/${CPPCMS_VERSION}/cppcms-${CPPCMS_VERSION}.tar.bz2/download" \
&& tar -xjvf cppcms-${CPPCMS_VERSION}.tar.bz \
&& mkdir cppcms-${CPPCMS_VERSION}/build \
&& cd cppcms-${CPPCMS_VERSION}/build \
&& cmake .. \
&& make -j ${PARALLEL} \
&& make install \
&& cd /app/deps \
&& rm -Rf cppcms-${CPPCMS_VERSION}
ARG JANSSON_VERSION="2.11"
RUN curl -O http://www.digip.org/jansson/releases/jansson-${JANSSON_VERSION}.tar.gz \
&& tar -xvzf jansson-${JANSSON_VERSION}.tar.gz \
&& cd jansson-${JANSSON_VERSION} \
&& mkdir build && cd build \
&& cmake .. \
&& make -j ${PARALLEL} \
&& make check \
&& make install \
&& cd /app/deps \
&& rm -Rf jansson-${JANSSON_VERSION}
ARG LIBJWT_VERSION="1.9.0"
RUN curl -o libjwt-v${LIBJWT_VERSION}.tar.gz -L \
"https://github.com/benmcollins/libjwt/archive/v${LIBJWT_VERSION}.tar.gz" \
&& tar -xvzf libjwt-v${LIBJWT_VERSION}.tar.gz \
&& cd libjwt-${LIBJWT_VERSION} \
&& autoreconf -i \
&& ./configure \
&& make -j ${PARALLEL} all \
&& make install \
&& cd /app/deps \
&& rm -Rf libjwt-${LIBJWT_VERSION}

# start build of kdb
ENV C_FLAGS="-D_FORTIFY_SOURCE=2 -Wformat -Werror=format-security -fstack-protector-strong -Wstack-protector -fPIE -pie"
WORKDIR /app/kdb
ADD . /app/kdb/
RUN ldconfig \
&& mkdir build \
&& cd build \
&& cmake -DENABLE_ASAN=ON -DBUILD_FULL=OFF -DBUILD_SHARED=ON \
-DBUILD_STATIC=OFF -DBUILD_DOCUMENTATION=OFF \
-DINSTALL_SYSTEM_FILES=OFF \
-DPLUGINS="ALL;-EXPERIMENTAL;-fstab;-semlock;-ruby;-lua;-python;-xerces;-yamlcpp;-python2;file;camel;yajl" \
-DTOOLS="kdb;rest-backend" \
-DCMAKE_C_FLAGS="$C_FLAGS" \
-DCMAKE_CXX_FLAGS="$C_FLAGS" \
-DCMAKE_EXE_LINKER_FLAGS="-Wl,-z,now -Wl,-z,relro" \
.. \
&& make -j ${PARALLEL} \
&& ctest -T Test --output-on-failure -j ${PARALLEL} -LE kdbtests \
&& make install


FROM debian:stretch
ENV LANG C.UTF-8
ENV LANGUAGE C.UTF-8
ENV LC_ALL C.UTF-8

COPY --from=0 /usr/local /usr/local
RUN echo '/usr/local/lib/elektra/' > /etc/ld.so.conf.d/elektra.conf \
&& ldconfig
RUN apt-get update && apt-get install -y \
libasan3 \
libubsan0 \
libboost-system1.62.0 \
libboost-filesystem1.62.0 \
libboost-thread1.62.0 \
libssl1.1 \
libicu57 \
pwgen \
&& rm -rf /var/lib/apt/lists/*

# prepare
# asan errors in mount-rest-backend-config and run-rest-backend
RUN kdb global-mount \
&& kdb mount-rest-backend-config || /bin/true \
&& kdb set -N system /sw/elektra/restbackend/#0/current/backend/jwt/encryption/secret `pwgen -1cns 30` \
&& kdb set -N system /sw/elektra/restbackend/#0/current/cppcms/service/api "http" \
&& kdb set -N system /sw/elektra/restbackend/#0/current/cppcms/service/ip "0.0.0.0" \
&& kdb set -N system /sw/elektra/restbackend/#0/current/cppcms/service/port 8080 \
&& kdb set -N system /sw/elektra/restbackend/#0/current/cppcms/http/script_names/#0 "/" \
&& kdb set '/sw/elektra/restbackend/#0/current/cppcms/daemon/enable' '0'\
&& kdb set '/sw/elektra/restbackend/#0/current/cppcms/logging/level' 'debug'

ENTRYPOINT ["kdb"]
CMD ["run-rest-backend"]
EXPOSE 8080
46 changes: 46 additions & 0 deletions scripts/docker/homepage/frontend/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
FROM debian:stretch

ENV LANG C.UTF-8
ENV LANGUAGE C.UTF-8
ENV LC_ALL C.UTF-8

RUN apt-get update && apt-get -y install \
cmake git build-essential curl \
libyajl-dev \
&& curl -sL https://deb.nodesource.com/setup_9.x | bash - \
&& apt-get install -y nodejs \
&& rm -rf /var/lib/apt/lists/*

ARG PARALLEL=2
# start build of kdb
ENV C_FLAGS="-D_FORTIFY_SOURCE=2 -Wformat -Werror=format-security -fstack-protector-strong -Wstack-protector -fPIE -pie"
WORKDIR /app/kdb
ADD . /app/kdb/
RUN mkdir build \
&& cd build \
&& cmake -DENABLE_ASAN=ON -DBUILD_FULL=OFF -DBUILD_SHARED=ON \
-DBUILD_STATIC=OFF -DBUILD_DOCUMENTATION=OFF \
-DINSTALL_SYSTEM_FILES=OFF \
-DPLUGINS="ALL;-EXPERIMENTAL;-fstab;-semlock;-ruby;-lua;-python;-xerces;-yamlcpp;-python2;file;camel;yajl" \
-DTOOLS="kdb;rest-frontend" \
-DCMAKE_C_FLAGS="$C_FLAGS" \
-DCMAKE_CXX_FLAGS="$C_FLAGS" \
-DCMAKE_EXE_LINKER_FLAGS="-Wl,-z,now -Wl,-z,relro" \
.. \
&& make -j ${PARALLEL} \
&& ctest -T Test --output-on-failure -j ${PARALLEL} -LE kdbtests \
&& make install \
&& echo '/usr/local/lib/elektra/' > /etc/ld.so.conf.d/elektra.conf \
&& ldconfig

ARG BACKEND=https://restapi.libelektra.org/
ARG FRONTEND=https://libelektra.org/
RUN kdb global-mount \
&& kdb mount-rest-frontend-config \
&& kdb set -N system /sw/elektra/restfrontend/#0/current/backend/root "${BACKEND}" \
&& kdb set -N system /sw/elektra/restfrontend/#0/current/website/url "${URL}" \
&& kdb build-rest-frontend

FROM nginx:alpine
COPY --from=0 /usr/local/share/elektra/tool_data/rest-frontend/public \
/usr/share/nginx/html
Loading

0 comments on commit f2659df

Please sign in to comment.