diff --git a/cypress.config.js b/cypress.config.js index c5ba7ea9..009f5fc9 100644 --- a/cypress.config.js +++ b/cypress.config.js @@ -1,32 +1,31 @@ -const { defineConfig } = require("cypress"); -const allureWriter = require('@shelex/cypress-allure-plugin/writer'); +const {defineConfig} = require("cypress"); module.exports = defineConfig({ - viewportHeight: 1080, - viewportWidth: 1920, - "video": false, - "retries": { - "runMode": 2, - "openMode": 0 - }, + viewportHeight: 1080, + viewportWidth: 1920, + "video": false, + "retries": { + "runMode": 2, + "openMode": 0 + }, - e2e: { - setupNodeEvents(on, config) { - if (config.env.master) { - return { - baseUrl: "http://regions-service.us-east-2.elasticbeanstalk.com/", - env: { - env: "master" - }, - }; - } else - return { - baseUrl: "http://localhost:8080", - env: { - env: "qa" - }, - }; + e2e: { + setupNodeEvents(on, config) { + if (config.env.master) { + return { + baseUrl: "http://regions-service.us-east-2.elasticbeanstalk.com/", + env: { + env: "master" + }, + }; + } else + return { + baseUrl: "http://localhost", + env: { + env: "qa" + }, + }; + }, }, - }, }); diff --git a/docker-compose.yml b/docker-compose.yml index 326494e1..6583dcc4 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -43,7 +43,6 @@ services: args: REACT_APP_TOKEN: abc123 ports: - - "8080:8080" - "8090:8090" healthcheck: @@ -55,4 +54,23 @@ services: depends_on: mysqldb: - condition: service_healthy \ No newline at end of file + condition: service_healthy + + nginx: + hostname: nginx-regions + container_name: nginx-regions + image: nginx:alpine + restart: always + ports: + - "80:80" + volumes: + - ./nginx_config/nginx.conf:/etc/nginx/nginx.conf:ro + depends_on: + server: + condition: service_healthy + logging: + # limit logs to 200MB (4 rotations of 50M each) + driver: "json-file" + options: + max-size: "50m" + max-file: "4" \ No newline at end of file diff --git a/nginx_config/nginx.conf b/nginx_config/nginx.conf new file mode 100644 index 00000000..12de890e --- /dev/null +++ b/nginx_config/nginx.conf @@ -0,0 +1,37 @@ +worker_processes auto; +events { + worker_connections 1024; +} + +http { + include /etc/nginx/mime.types; + default_type application/octet-stream; + + # Rate limiting to prevent brute force attacks + limit_req_zone $binary_remote_addr zone=one:10m rate=1r/s; + + server { + listen 80; + server_name localhost; + + # Rate limiting + limit_req zone=one burst=20 nodelay; + limit_req_status 429; + + location / { + proxy_pass http://server-regions:8080; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + + location /backend { + proxy_pass http://server-regions:8090; + proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + } + } +} \ No newline at end of file