NOW THE NAME OF THE PROJECT IS EVO.AUTH
This commit is contained in:
parent
68fc67913f
commit
43126e3425
9
.env
9
.env
@ -1,5 +1,9 @@
|
|||||||
COMPOSE_PROJECT_NAME=
|
COMPOSE_PROJECT_NAME=
|
||||||
NETWORK_NAME=
|
NETWORK_NAME=
|
||||||
|
TRAEFIK_APP_NAME=
|
||||||
|
TRAEFIK_ENTRYPOINTS=web-secure
|
||||||
|
# TRAEFIK_ENTRYPOINTS=web-secure-ext
|
||||||
|
WEB_HOST=
|
||||||
|
|
||||||
# WEB
|
# WEB
|
||||||
APP_BASE_PATH=/login
|
APP_BASE_PATH=/login
|
||||||
@ -16,7 +20,4 @@ LDAP_ATTRIBUTE=
|
|||||||
|
|
||||||
API_SECRET=
|
API_SECRET=
|
||||||
API_TOKEN_TTL=
|
API_TOKEN_TTL=
|
||||||
API_CACHE_TTL=
|
API_CACHE_TTL=
|
||||||
|
|
||||||
REDIS_HOST=redis
|
|
||||||
REDIS_PORT=
|
|
||||||
93
config/nginx.conf
Normal file
93
config/nginx.conf
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
|
||||||
|
worker_processes auto;
|
||||||
|
|
||||||
|
events {
|
||||||
|
worker_connections 1024;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
http {
|
||||||
|
|
||||||
|
upstream web {
|
||||||
|
server web:3000;
|
||||||
|
}
|
||||||
|
|
||||||
|
upstream api {
|
||||||
|
server api:3001;
|
||||||
|
}
|
||||||
|
|
||||||
|
upstream app {
|
||||||
|
server application:80;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
include /etc/nginx/mime.types;
|
||||||
|
|
||||||
|
gzip on;
|
||||||
|
gzip_min_length 1000;
|
||||||
|
gzip_proxied any;
|
||||||
|
gzip_comp_level 1;
|
||||||
|
gzip_types text/css text/javascript text/xml text/plain text/x-component application/javascript application/json application/xml application/rss+xml font/truetype font/opentype application/vnd.ms-fontobject image/svg+xml;
|
||||||
|
gzip_vary on;
|
||||||
|
gzip_disable "msie6";
|
||||||
|
|
||||||
|
|
||||||
|
error_page 401 /login;
|
||||||
|
|
||||||
|
|
||||||
|
location = /auth {
|
||||||
|
internal;
|
||||||
|
|
||||||
|
proxy_pass http://api;
|
||||||
|
|
||||||
|
proxy_pass_request_body off;
|
||||||
|
proxy_set_header Content-Length "";
|
||||||
|
proxy_set_header X-Original-URI $request_uri;
|
||||||
|
proxy_set_header X-Original-Remote-Addr $remote_addr;
|
||||||
|
proxy_set_header X-Original-Host $host;
|
||||||
|
proxy_intercept_errors on;
|
||||||
|
}
|
||||||
|
|
||||||
|
location ~ ^/(signin|logout|get-user) {
|
||||||
|
proxy_pass http://api;
|
||||||
|
|
||||||
|
proxy_redirect off;
|
||||||
|
proxy_set_header X-Original-URI $request_uri;
|
||||||
|
proxy_set_header X-Original-Remote-Addr $remote_addr;
|
||||||
|
proxy_set_header X-Original-Host $host;
|
||||||
|
}
|
||||||
|
|
||||||
|
location ~ ^/login {
|
||||||
|
proxy_pass http://web;
|
||||||
|
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection 'upgrade';
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_cache_bypass $http_upgrade;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
location / {
|
||||||
|
proxy_pass http://app;
|
||||||
|
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection 'upgrade';
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_cache_bypass $http_upgrade;
|
||||||
|
|
||||||
|
auth_request /auth;
|
||||||
|
auth_request_set $auth_cookie $upstream_http_set_cookie;
|
||||||
|
add_header Set-Cookie $auth_cookie;
|
||||||
|
}
|
||||||
|
|
||||||
|
location = /health {
|
||||||
|
access_log off;
|
||||||
|
add_header 'Content-Type' 'application/json';
|
||||||
|
return 200 'UP';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
15
docker-compose.traefik.yml
Normal file
15
docker-compose.traefik.yml
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
version: '3'
|
||||||
|
|
||||||
|
services:
|
||||||
|
server:
|
||||||
|
container_name: ${TRAEFIK_APP_NAME}
|
||||||
|
labels:
|
||||||
|
- 'traefik.enable=true'
|
||||||
|
- 'traefik.backend=${TRAEFIK_APP_NAME}'
|
||||||
|
- 'traefik.docker.network=web'
|
||||||
|
- 'traefik.http.routers.${TRAEFIK_APP_NAME}.rule=Host(`${WEB_HOST}`)'
|
||||||
|
- 'traefik.http.routers.${TRAEFIK_APP_NAME}.entrypoints=${TRAEFIK_ENTRYPOINTS}'
|
||||||
|
- 'traefik.http.routers.${TRAEFIK_APP_NAME}.tls.certresolver=le'
|
||||||
|
- 'traefik.port=80'
|
||||||
|
networks:
|
||||||
|
- web
|
||||||
@ -8,6 +8,7 @@ services:
|
|||||||
restart: always
|
restart: always
|
||||||
networks:
|
networks:
|
||||||
- auth_network
|
- auth_network
|
||||||
|
|
||||||
api:
|
api:
|
||||||
build:
|
build:
|
||||||
context: .
|
context: .
|
||||||
@ -33,11 +34,19 @@ services:
|
|||||||
ALLOW_EMPTY_PASSWORD: 'yes'
|
ALLOW_EMPTY_PASSWORD: 'yes'
|
||||||
networks:
|
networks:
|
||||||
- auth_network
|
- auth_network
|
||||||
auth_server:
|
|
||||||
image: nginx
|
server:
|
||||||
|
extends:
|
||||||
|
file: docker-compose.traefik.yml
|
||||||
|
service: server
|
||||||
|
image: nginx:alpine
|
||||||
volumes:
|
volumes:
|
||||||
- ./nginx.conf:/etc/nginx/nginx.conf
|
- ./config/nginx.conf:/etc/nginx/templates/default.conf.template
|
||||||
restart: always
|
restart: always
|
||||||
|
depends_on:
|
||||||
|
- web
|
||||||
|
- api
|
||||||
|
- redis
|
||||||
networks:
|
networks:
|
||||||
- auth_network
|
- auth_network
|
||||||
- app_network
|
- app_network
|
||||||
@ -47,3 +56,5 @@ networks:
|
|||||||
app_network:
|
app_network:
|
||||||
external: true
|
external: true
|
||||||
name: ${NETWORK_NAME}
|
name: ${NETWORK_NAME}
|
||||||
|
web:
|
||||||
|
external: true
|
||||||
|
|||||||
@ -1,58 +0,0 @@
|
|||||||
|
|
||||||
worker_processes auto;
|
|
||||||
|
|
||||||
events {
|
|
||||||
worker_connections 1024;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
http {
|
|
||||||
|
|
||||||
upstream auth_server {
|
|
||||||
server auth_server:80;
|
|
||||||
}
|
|
||||||
|
|
||||||
upstream application {
|
|
||||||
server application:3000;
|
|
||||||
}
|
|
||||||
|
|
||||||
server {
|
|
||||||
listen 80;
|
|
||||||
include /etc/nginx/mime.types;
|
|
||||||
|
|
||||||
error_page 401 /login;
|
|
||||||
|
|
||||||
|
|
||||||
location = /auth {
|
|
||||||
internal;
|
|
||||||
|
|
||||||
proxy_pass http://auth_server;
|
|
||||||
|
|
||||||
proxy_pass_request_body off;
|
|
||||||
proxy_set_header Content-Length "";
|
|
||||||
proxy_set_header X-Original-URI $request_uri;
|
|
||||||
proxy_set_header X-Original-Remote-Addr $remote_addr;
|
|
||||||
proxy_set_header X-Original-Host $host;
|
|
||||||
proxy_intercept_errors on;
|
|
||||||
}
|
|
||||||
|
|
||||||
location ~ ^/(login|signin|logout|get-user) {
|
|
||||||
proxy_pass http://auth_server;
|
|
||||||
|
|
||||||
proxy_redirect off;
|
|
||||||
proxy_set_header X-Original-URI $request_uri;
|
|
||||||
proxy_set_header X-Original-Remote-Addr $remote_addr;
|
|
||||||
proxy_set_header X-Original-Host $host;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
location / {
|
|
||||||
proxy_pass http://application/;
|
|
||||||
|
|
||||||
auth_request /auth;
|
|
||||||
auth_request_set $auth_cookie $upstream_http_set_cookie;
|
|
||||||
add_header Set-Cookie $auth_cookie;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
41
nginx.conf
41
nginx.conf
@ -1,41 +0,0 @@
|
|||||||
|
|
||||||
worker_processes 4;
|
|
||||||
|
|
||||||
events {
|
|
||||||
worker_connections 1024;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
http {
|
|
||||||
upstream web {
|
|
||||||
server web:3000;
|
|
||||||
}
|
|
||||||
|
|
||||||
upstream api {
|
|
||||||
server api:3001;
|
|
||||||
}
|
|
||||||
|
|
||||||
server {
|
|
||||||
listen 80;
|
|
||||||
include /etc/nginx/mime.types;
|
|
||||||
|
|
||||||
|
|
||||||
proxy_http_version 1.1;
|
|
||||||
proxy_set_header Upgrade $http_upgrade;
|
|
||||||
proxy_set_header Connection 'upgrade';
|
|
||||||
proxy_set_header Host $host;
|
|
||||||
proxy_cache_bypass $http_upgrade;
|
|
||||||
|
|
||||||
location / {
|
|
||||||
proxy_pass http://api/;
|
|
||||||
}
|
|
||||||
|
|
||||||
location /login {
|
|
||||||
proxy_pass http://web;
|
|
||||||
|
|
||||||
limit_except GET {
|
|
||||||
deny all;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Loading…
x
Reference in New Issue
Block a user