aspida と frourio を用いた FullStack TypeScript テンプレート
- Frontend: Next.js
- Backend: Fastify
- ORM: Prisma + PostgreSQL
- Auth: AWS Cognito
- Object Storage: AWS S3 or Cloudflare R2
- RESTではないHTTPリクエスト
- 関数型アーキテクチャ
- 全ての関数に依存性注入が可能
- 3rd Party Cookie なし
- Docker コンテナー1つだけでデプロイ
- ローカル開発は Node.js + Docker Compose で完結
- 最新コミットのデモ: https://catapult.frourio.com
flowchart TB
node_1["Next.js"]
node_2["GET server/api/{path}/controller.ts"]
node_3["server/domain/{kind}/store/xxxQuery.ts"]
node_4[("PostgreSQL")]
node_1 --"Query"--> node_2
node_2 --"Query"--> node_3
node_3 --"Prisma"--> node_4
node_4 =="data"==> node_3
node_3 =="Dto"==> node_2
node_2 =="Dto"==> node_1
flowchart TB
node_1["Next.js"]
node_2["POST server/api/{path}/controller.ts"]
node_3["server/domain/{kind}/xxxUseCase.ts"]
node_4["server/domain/{kind}/model/xxxMethod.ts"]
node_5["server/domain/{kind}/store/xxxCommand.ts"]
node_6["server/domain/{kind}/store/xxxQuery.ts"]
node_7[("PostgreSQL")]
node_1 --"Body"--> node_2
node_2 --"Body"--> node_3
node_4 --"Entity"--> node_5
node_3 --"Body"--> node_6
node_6 --"Dto"--> node_4
node_5 --"Prisma"--> node_7
node_5 =="Dto"==> node_3
node_7 =="data"==> node_5
node_3 =="Dto"==> node_2
node_2 =="Dto"==> node_1
https://nodejs.org/en で v20 以上をインストール
$ git clone https://github.com/frouriojs/catapult.git
$ cd catapult
$ rm -rf .git # 既存のコミット履歴を削除
$ git init
package.json は3つ存在する
$ npm i
$ npm i --prefix client
$ npm i --prefix server
$ cp client/.env.example client/.env
$ cp server/.env.example server/.env
$ docker compose up -d
次回以降は以下のコマンドだけで開発できる
$ npm run notios
Web ブラウザで http://localhost:3000 を開く
開発時のターミナル表示は notios で制御している
Node.js モノレポ開発のターミナルログ混雑解消のための新作 CLI ツール notios
閉じるときは Ctrl + C
を 2 回連続で入力
Docker の Inbucket に仮想メールが届くため任意のメールアドレスでアカウント作成可能
検証コード含めて開発時のメールは全て http://localhost:2501 のヘッダー中央の「Recent Mailboxes」に届く
Dockerfile
でデプロイ可能
PostgreSQL
- AWS Cognito
- AWS S3 or Cloudflare R2
ヘルスチェック用エンドポイント
/api/health
NEXT_PUBLIC_COGNITO_USER_POOL_CLIENT_ID=
NEXT_PUBLIC_COGNITO_USER_POOL_ID=
NEXT_PUBLIC_COGNITO_POOL_ENDPOINT=
COGNITO_ACCESS_KEY=
COGNITO_SECRET_KEY=
COGNITO_REGION=
DATABASE_URL=
S3_ACCESS_KEY=
S3_BUCKET=
S3_ENDPOINT=
S3_REGION=
S3_SECRET_KEY=
PORT= # optional
$ cd server
$ npx prisma studio