Skip to content

Commit

Permalink
Add ability for image to read env from a file by _FILE suffix #175 (#176
Browse files Browse the repository at this point in the history
)

* Add ability for image to read env from a file by _FILE suffix #175

* Fix issue with authSource/replicaSet for mongo typeorm #175
  • Loading branch information
AlekNS authored and hlogeon committed Jul 3, 2018
1 parent 2238fcd commit 4de68c7
Show file tree
Hide file tree
Showing 6 changed files with 52 additions and 14 deletions.
6 changes: 3 additions & 3 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,12 @@ services:
- docker
before_install:
- chmod ugo+x ./scripts/build.sh
script:
- cp -r .env.test .env
- docker-compose build
- docker-compose run -u 0 --no-deps --rm ico sh -c "yarn install"
script:
- docker-compose up -d
- docker-compose exec ico yarn
- docker-compose exec ico yarn test
- docker-compose exec -u 0 ico sh -c "yarn test"
- export TAG=`if [ "$TRAVIS_BRANCH" == "master" ]; then echo "production"; elif [
"$TRAVIS_BRANCH" == "develop" ]; then echo "stage"; else echo "dev-$(git rev-parse
--short HEAD)" ; fi`
Expand Down
16 changes: 13 additions & 3 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,10 +1,20 @@
FROM mhart/alpine-node:8.9.1

RUN apk update && apk upgrade && apk add git && apk add python && apk add make && apk add g++ && npm i -g yarn
WORKDIR /usr/src/app
COPY . .
COPY custom-entrypoint.sh /usr/local/bin/custom-entrypoint.sh

RUN chmod 755 /usr/local/bin/custom-entrypoint.sh && \
addgroup ico && \
adduser -D -H -G ico ico && \
apk add --update --no-cache git python make g++ && \
npm i -g yarn && \
yarn install

VOLUME /usr/src/app
EXPOSE 3000
EXPOSE 4000
WORKDIR /usr/src/app

USER ico

ENTRYPOINT ["/usr/local/bin/custom-entrypoint.sh"]
CMD ["npm", "start"]
22 changes: 16 additions & 6 deletions Dockerfile.prod
Original file line number Diff line number Diff line change
@@ -1,17 +1,27 @@
FROM mhart/alpine-node:8.6

RUN mkdir -p /usr/src/app
ADD . /usr/src/app

WORKDIR /usr/src/app

RUN mkdir -p /usr/src/app/dist
RUN cp -r src/certs dist/
COPY . .
COPY custom-entrypoint.sh /usr/local/bin/custom-entrypoint.sh

RUN chmod 755 /usr/local/bin/custom-entrypoint.sh && \
addgroup ico && \
adduser -D -H -G ico ico && \
mkdir -p /usr/src/app/dist && \
cp -r src/certs dist/
RUN apk add --update --no-cache git python make g++ && \
npm i -g yarn && \
yarn install && \
yarn run build && \
yarn install --prod && \
apk del --purge git python make g++ && \
rm -rf ./src

CMD npm run serve
EXPOSE 3000
EXPOSE 4000

USER ico

ENTRYPOINT ["/usr/local/bin/custom-entrypoint.sh"]
CMD ["npm", "run", "serve"]
14 changes: 14 additions & 0 deletions custom-entrypoint.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
#!/bin/sh

set -eu

for env in $(env); do
key=${env%=*}
[ -n "${key#*_FILE}" ] && continue
val=${env#*=}
key=${key%_FILE}
val=$(cat $val)
export "${key}"="${val}"
done

exec "$@"
4 changes: 2 additions & 2 deletions docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,13 @@ services:
- 80:3000
- 3000:3000
- 443:4000
volumes:
- ./:/usr/src/app
links:
- auth
- redis
- verify
- rpc
volumes:
- ./:/usr/src/app
depends_on:
- rpc
- mongo
Expand Down
4 changes: 4 additions & 0 deletions src/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,8 @@ const {
AUTH_BASE_URL,
VERIFY_BASE_URL,
MONGO_URL,
MONGO_AUTH_SOURCE,
MONGO_REPLICA_SET,
SC_ABI_FOLDER,
ICO_SC_ADDRESS,
ICO_OLD_SC_ADDRESSES,
Expand Down Expand Up @@ -164,6 +166,8 @@ export default {
synchronize: true,
logging: false,
url: MONGO_URL,
authSource: MONGO_AUTH_SOURCE,
replicaSet: MONGO_REPLICA_SET,
entities: [
ORM_ENTITIES_DIR
],
Expand Down

0 comments on commit 4de68c7

Please sign in to comment.