Skip to content

Commit

Permalink
Run React app in Docker Compose
Browse files Browse the repository at this point in the history
  • Loading branch information
zach-betz-hln committed Oct 25, 2024
1 parent d474071 commit f76b06f
Show file tree
Hide file tree
Showing 7 changed files with 53 additions and 12 deletions.
8 changes: 8 additions & 0 deletions .env.sample
Original file line number Diff line number Diff line change
Expand Up @@ -30,3 +30,11 @@ MH_UI_BIND_ADDR=0.0.0.0:${MH_UI_BIND_ADDR_PORT}
################################################################################
API_PORT=5174
API_JSON_WEB_KEY_SET_URL=http://kc:${KC_HTTP_PORT}/realms/master/protocol/openid-connect/certs

################################################################################
# react
################################################################################
VITE_PORT=5173
VITE_AUTHORITY=http://localhost:8080/realms/master
VITE_CLIENT_ID=react
VITE_API_BASE_URL=http://api:5174
29 changes: 21 additions & 8 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@ Minimal, reproducible example for Keycloak + React.
- [Why](#why)
- [Setup](#setup)
* [Docker Compose](#docker-compose)
* [React app](#react-app)
* [OPTIONAL: Run React app outside of Docker Compose](#optional-run-react-app-outside-of-docker-compose)
- [Config](#config)
- [Links](#links)
* [React app](#react-app-1)
* [React app](#react-app)
* [Keycloak account console](#keycloak-account-console)
* [Keycloak admin console](#keycloak-admin-console)
* [Mailhog UI](#mailhog-ui)
Expand Down Expand Up @@ -44,9 +44,9 @@ So, I thought it'd be cool to make a little project that glues these tools toget
## Setup

In one terminal, run the Postgres database, Keycloak server, Mailhog server, and Express API via Docker Compose.
In one terminal, run the Postgres database, Keycloak server, Mailhog server, Express API, and React app via Docker Compose.

In another terminal, run the React app.
**OPTIONALLY**, in another terminal, you may run the React app outside of Docker Compose.

### Docker Compose

Expand All @@ -63,13 +63,28 @@ In another terminal, run the React app.

docker compose up

### React app
1. Wait until you see a message from the Keycloak server like this: _Running the server in development mode. DO NOT use this configuration in production._

1. See [links](#links) for username and password

### OPTIONAL: Run React app outside of Docker Compose

1. Stop the React app container

docker compose stop react

1. Install [Node.js](https://nodejs.org/en)
1. Change to `react` folder

cd react

1. Create file `.env.local` with contents

VITE_PORT=5173
VITE_AUTHORITY=http://localhost:8080/realms/master
VITE_CLIENT_ID=react
VITE_API_BASE_URL=http://localhost:5174

1. Install packages

npm install
Expand All @@ -82,9 +97,7 @@ In another terminal, run the React app.

## Config

The Docker Compose config should work as-is. If you need to customize it, like changing what port a service runs on, then edit file `.env`

The React config should work as-is as well. If you need to customize it, then edit file `react/.env`
The Docker Compose config should work as-is. If you need to customize it, then edit file `.env`

## Links

Expand Down
15 changes: 15 additions & 0 deletions compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -29,9 +29,24 @@ services:
- .env

api:
depends_on:
- kc
build:
context: ./api
ports:
- ${API_PORT}:${API_PORT}
env_file:
- .env

react:
depends_on:
- kc
- api
build:
context: ./react
ports:
- ${VITE_PORT}:${VITE_PORT}
env_file:
- .env
volumes:
- ./react/src:/app/src:rw
1 change: 1 addition & 0 deletions react/.dockerignore
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
.env.local
.eslintcache
dist
node_modules
3 changes: 0 additions & 3 deletions react/.env

This file was deleted.

6 changes: 6 additions & 0 deletions react/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
FROM node:22-bookworm
WORKDIR /app
COPY package.json package-lock.json ./
RUN npm install
COPY . .
CMD [ "npm", "run", "dev" ]
3 changes: 2 additions & 1 deletion react/vite.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@ export default defineConfig(({ command, mode }) => {
return {
...commonConfig,
server: {
open: true,
open: false,
port: Number(env.VITE_PORT),
strictPort: true,
proxy: {
'/api': {
Expand Down

0 comments on commit f76b06f

Please sign in to comment.