keycloak init
This commit is contained in:
@@ -2,7 +2,9 @@
|
||||
|
||||
The generator must use **official CLI tools** to create base project structures.
|
||||
|
||||
The AI must **not** manually generate the entire project skeleton (e.g. by writing all config files and folder structure by hand). Using the CLI reduces errors and ensures compatibility with current tool versions.
|
||||
The AI must **not** manually generate the entire project skeleton by hand. CLI scaffolding reduces drift and keeps the generated project aligned with current NestJS and Vite conventions.
|
||||
|
||||
Auth is part of the default generated runtime. Scaffolding must therefore install the required frontend and backend auth dependencies during the normal project bootstrap path.
|
||||
|
||||
---
|
||||
|
||||
@@ -19,9 +21,9 @@ npx @nestjs/cli@10.3.2 new server --package-manager npm --skip-git
|
||||
## Rules
|
||||
|
||||
- **Project directory** must be `server`.
|
||||
- **TypeScript** must be used (default for Nest CLI).
|
||||
- **npm** must be the package manager (`--package-manager npm`).
|
||||
- **Git** initialization must be skipped (`--skip-git`).
|
||||
- **TypeScript** must be used.
|
||||
- **npm** must be the package manager.
|
||||
- **Git** initialization must be skipped.
|
||||
|
||||
## After scaffolding — install required dependencies
|
||||
|
||||
@@ -29,10 +31,16 @@ Run from the `server` directory:
|
||||
|
||||
```bash
|
||||
npm install @prisma/client
|
||||
npm install prisma --save-dev
|
||||
npm install @nestjs/config
|
||||
npm install jose
|
||||
npm install prisma --save-dev
|
||||
```
|
||||
|
||||
## Backend auth dependency rules
|
||||
|
||||
- `jose` must be installed by default because JWT verification is part of the default generated backend.
|
||||
- The generator must **not** install deprecated Keycloak-specific Node adapters such as `keycloak-connect`.
|
||||
|
||||
---
|
||||
|
||||
# Frontend Scaffolding
|
||||
@@ -48,7 +56,7 @@ npm create vite@5.2.0 client -- --template react-ts
|
||||
## Rules
|
||||
|
||||
- **Project directory** must be `client`.
|
||||
- **React + TypeScript** template must be used (`--template react-ts`).
|
||||
- **React + TypeScript** template must be used.
|
||||
|
||||
## After scaffolding — install required dependencies
|
||||
|
||||
@@ -58,8 +66,14 @@ Run from the `client` directory:
|
||||
npm install react-admin
|
||||
npm install ra-data-simple-rest
|
||||
npm install @mui/material @emotion/react @emotion/styled
|
||||
npm install keycloak-js
|
||||
```
|
||||
|
||||
## Frontend auth dependency rules
|
||||
|
||||
- `keycloak-js` must be installed by default because redirect-based Keycloak login is part of the default generated frontend.
|
||||
- The generated frontend must use `keycloak-js` for Authorization Code + PKCE and must not generate a custom in-app username/password login form.
|
||||
|
||||
---
|
||||
|
||||
# Scaffolding Strategy
|
||||
@@ -67,12 +81,12 @@ npm install @mui/material @emotion/react @emotion/styled
|
||||
Generation pipeline order:
|
||||
|
||||
1. **Parse DSL** — Read domain, DTO, API, and UI DSL files.
|
||||
2. **Run CLI scaffolding** — Create `server` with NestJS CLI and `client` with Vite CLI; install dependencies as above.
|
||||
3. **Code generation** — Generate Prisma schema, NestJS modules/DTOs/PrismaService, and React Admin resources.
|
||||
4. **Runtime infrastructure** — Generate `.env`, `.env.example`, package lifecycle scripts, and runtime config files.
|
||||
2. **Run CLI scaffolding** — Create `server` with NestJS CLI and `client` with Vite CLI; install runtime and auth dependencies listed above.
|
||||
3. **Code generation** — Generate Prisma schema, NestJS modules/DTOs/PrismaService/auth infrastructure, and React Admin resources/auth integration.
|
||||
4. **Runtime infrastructure** — Generate backend/frontend `.env.example`, runtime config files, lifecycle scripts, and a root-level Keycloak realm import artifact (repository default example filename: `toir-realm.json`).
|
||||
5. **Database runtime** — Generate `docker-compose.yml` in project root with PostgreSQL service (`postgres`, image `postgres:16`, port `5432:5432`).
|
||||
6. **Migration** — Apply schema with `npx prisma migrate dev`.
|
||||
7. **Seed** — Populate minimal development data with `npx prisma db seed`.
|
||||
8. **Validation** — Run checks from `generation/post-generation-validation.md`.
|
||||
8. **Validation** — Run checks from `generation/post-generation-validation.md`, including auth validation and realm-template validation.
|
||||
|
||||
Scaffolding (steps 1–2) must be done with the CLI; steps 3–8 are generated from the DSL and project docs.
|
||||
Scaffolding (steps 1–2) must be done with the CLI. Steps 3–8 must be generated from the DSL and the project context documents, including the auth-specific context in `auth/*.md`.
|
||||
|
||||
Reference in New Issue
Block a user