diff --git a/.env b/.env index 131b17e4..7a9ba72a 100644 --- a/.env +++ b/.env @@ -1 +1,2 @@ -teamname="wiq_0" \ No newline at end of file +teamname="wiq_0" +WIQ_EXTERNAL_DNS_NAME_OR_IP=$DOCKER_HOST_IP \ No newline at end of file diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index c9265703..3378fda8 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -23,8 +23,8 @@ jobs: - run: npm --prefix users/userservice test -- --coverage - run: npm --prefix gatewayservice test -- --coverage - run: npm --prefix webapp test -- --coverage - - name: Analyze with SonarCloud - uses: sonarsource/sonarcloud-github-action@master - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} \ No newline at end of file +# - name: Analyze with SonarCloud +# uses: sonarsource/sonarcloud-github-action@master +# env: +# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} +# SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} \ No newline at end of file diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 2905c196..b6efb135 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -3,6 +3,8 @@ name: Deploy on release on: release: types: [published] + pull_request: + types: [opened, synchronize, reopened] jobs: unit-tests: @@ -20,11 +22,11 @@ jobs: - run: npm --prefix users/userservice test -- --coverage - run: npm --prefix gatewayservice test -- --coverage - run: npm --prefix webapp test -- --coverage - - name: Analyze with SonarCloud - uses: sonarsource/sonarcloud-github-action@master - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} +# - name: Analyze with SonarCloud +# uses: sonarsource/sonarcloud-github-action@master +# env: +# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} +# SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} e2e-tests: needs: [unit-tests] runs-on: ubuntu-latest diff --git a/README.md b/README.md index fb89a4a1..75939c09 100644 --- a/README.md +++ b/README.md @@ -83,6 +83,19 @@ sudo curl -L "https://github.com/docker/compose/releases/download/1.28.5/docker- sudo chmod +x /usr/local/bin/docker-compose ``` +After installing Docker, we need to set up a global environment variable to configure external container connectivity. This can be done by editing the /etc/environment file: + +```bash +sudo nano /etc/environment +``` + +and adding the following line: + +```bash +DOCKER_HOST_IP=[IP address of the remote machine] +``` + + ### Continuous delivery (GitHub Actions) Once we have our machine ready, we could deploy by hand the application, taking our docker-compose file and executing it in the remote machine. diff --git a/docker-compose.yml b/docker-compose.yml index c105ed50..2cb1ed54 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -13,7 +13,7 @@ services: authservice: container_name: authservice-${teamname:-defaultASW} - image: ghcr.io/arquisoft/wiq_0/authservice:latest + image: ghcr.io/arquisoft/${teamname:-wiq_0}/authservice:latest profiles: ["dev", "prod"] build: ./users/authservice depends_on: @@ -23,11 +23,11 @@ services: networks: - mynetwork environment: - MONGODB_URI: mongodb://mongodb:27017/userdb + MONGODB_URI: mongodb://${WIQ_EXTERNAL_DNS_NAME_OR_IP:-mongodb}:27017/userdb userservice: container_name: userservice-${teamname:-defaultASW} - image: ghcr.io/arquisoft/wiq_0/userservice:latest + image: ghcr.io/arquisoft/${teamname:-wiq_0}/userservice:latest profiles: ["dev", "prod"] build: ./users/userservice depends_on: @@ -37,11 +37,11 @@ services: networks: - mynetwork environment: - MONGODB_URI: mongodb://mongodb:27017/userdb + MONGODB_URI: mongodb://${WIQ_EXTERNAL_DNS_NAME_OR_IP:-mongodb}:27017/userdb gatewayservice: container_name: gatewayservice-${teamname:-defaultASW} - image: ghcr.io/arquisoft/wiq_0/gatewayservice:latest + image: ghcr.io/arquisoft/${teamname:-wiq_0}/gatewayservice:latest profiles: ["dev", "prod"] build: ./gatewayservice depends_on: @@ -53,18 +53,20 @@ services: networks: - mynetwork environment: - AUTH_SERVICE_URL: http://authservice:8002 - USER_SERVICE_URL: http://userservice:8001 + AUTH_SERVICE_URL: http://${WIQ_EXTERNAL_DNS_NAME_OR_IP:-authservice}:8002 + USER_SERVICE_URL: http://${WIQ_EXTERNAL_DNS_NAME_OR_IP:-userservice}:8001 webapp: container_name: webapp-${teamname:-defaultASW} - image: ghcr.io/arquisoft/wiq_0/webapp:latest + image: ghcr.io/arquisoft/${teamname:-wiq_0}/webapp:latest profiles: ["dev", "prod"] build: ./webapp depends_on: - gatewayservice ports: - "3000:3000" + environment: + REACT_APP_API_ENDPOINT: http://${WIQ_EXTERNAL_DNS_NAME_OR_IP:-localhost}:8000 prometheus: image: prom/prometheus diff --git a/gatewayservice/.env b/gatewayservice/.env new file mode 100644 index 00000000..76b9ce5e --- /dev/null +++ b/gatewayservice/.env @@ -0,0 +1,2 @@ +AUTH_SERVICE_URL=http://localhost:8002 +USER_SERVICE_URL=http://localhost:8001 \ No newline at end of file diff --git a/gatewayservice/Dockerfile b/gatewayservice/Dockerfile index 6c340432..20a60150 100644 --- a/gatewayservice/Dockerfile +++ b/gatewayservice/Dockerfile @@ -13,5 +13,8 @@ RUN npm install # Copy the app source code to the working directory COPY . . +#Remove env file (not necesary for docker) +RUN rm -f .env + # Define the command to run your app CMD ["node", "gateway-service.js"] diff --git a/users/authservice/.env b/users/authservice/.env new file mode 100644 index 00000000..b723d16d --- /dev/null +++ b/users/authservice/.env @@ -0,0 +1 @@ +MONGODB_URI=mongodb://localhost:27017/userdb \ No newline at end of file diff --git a/users/authservice/Dockerfile b/users/authservice/Dockerfile index 70648d70..2b6bf142 100644 --- a/users/authservice/Dockerfile +++ b/users/authservice/Dockerfile @@ -13,6 +13,9 @@ RUN npm install # Copy the app source code to the working directory COPY . . +#Remove env file (not necesary for docker) +RUN rm -f .env + # Expose the port the app runs on EXPOSE 8002 diff --git a/users/userservice/.env b/users/userservice/.env new file mode 100644 index 00000000..b723d16d --- /dev/null +++ b/users/userservice/.env @@ -0,0 +1 @@ +MONGODB_URI=mongodb://localhost:27017/userdb \ No newline at end of file diff --git a/users/userservice/Dockerfile b/users/userservice/Dockerfile index f43e2df7..0423a6ea 100644 --- a/users/userservice/Dockerfile +++ b/users/userservice/Dockerfile @@ -13,6 +13,9 @@ RUN npm install # Copy the app source code to the working directory COPY . . +#Remove env file (not necesary for docker) +RUN rm -f .env + # Expose the port the app runs on EXPOSE 8001 diff --git a/webapp/Dockerfile b/webapp/Dockerfile index 3cbad8b7..661282ee 100644 --- a/webapp/Dockerfile +++ b/webapp/Dockerfile @@ -2,13 +2,11 @@ FROM node:20 COPY . /app WORKDIR /app - +#Remove env file (not necesary for docker) +RUN rm -f .env #Install the dependencies RUN npm install -ARG API_URI="http://localhost:8000" -ENV REACT_APP_API_ENDPOINT=$API_URI - #Create an optimized version of the webapp RUN npm run build RUN npm install serve diff --git a/webapp/src/components/AddUser.js b/webapp/src/components/AddUser.js index 00d522a2..ddbcb070 100644 --- a/webapp/src/components/AddUser.js +++ b/webapp/src/components/AddUser.js @@ -3,7 +3,7 @@ import React, { useState } from 'react'; import axios from 'axios'; import { Container, Typography, TextField, Button, Snackbar } from '@mui/material'; -const apiEndpoint = process.env.REACT_APP_API_ENDPOINT || 'http://localhost:8000'; +const apiEndpoint = process.env.REACT_APP_API_ENDPOINT; const AddUser = () => { const [username, setUsername] = useState(''); diff --git a/webapp/src/components/Login.js b/webapp/src/components/Login.js index 0ad6268e..4397a52b 100644 --- a/webapp/src/components/Login.js +++ b/webapp/src/components/Login.js @@ -11,7 +11,7 @@ const Login = () => { const [createdAt, setCreatedAt] = useState(''); const [openSnackbar, setOpenSnackbar] = useState(false); - const apiEndpoint = process.env.REACT_APP_API_ENDPOINT || 'http://localhost:8000'; + const apiEndpoint = process.env.REACT_APP_API_ENDPOINT; const loginUser = async () => { try {