Next.js(フロントエンド)・Nest.js(サーバーサイド)・GraghQLを利用したサンプルアプリケーションです。
- Next.js
- typescript 4
- material-ui
- redux-toolkit
- Apollo Client
- Nest.js
- Prisma
- GraphQL
- ログイン/ログアウト
- 会員登録
- 投稿一覧
- 投稿詳細
- マイページ(一覧・登録・更新・削除)
.
├── docker/
│ ├── mysql/
│ ├── nestjs/
│ │ └── app/ (Nest.js のソースコード)
│ │ ├── prisma/
│ │ ├── src/
│ │ └── test/
│ └── docker-compose.yml
└── frontend/
├── src/ (Next.js のソースコード)
│ ├── @types/
│ ├── auth/
│ ├── common/
│ ├── components/
│ ├── pages/
│ ├── store/
│ ├── styles/
│ └── utilities/
└── test/
# 下準備
$ ./dc.sh init
# Dockerを起動する
$ ./dc.sh start
# データベースとPHPが立ち上がるまで少し待ちます。(初回は5分程度)
# MySQLにログインしてみる
$ ./dc.sh mysql login
# Dockerを停止する場合
$ ./dc.sh stop
$ cd backend
$ cp .env.example .env
$ yarn
$ npx prisma generate
$ npx prisma migrate dev --name post
$ yarn start
# 以下のように必要なフィールドのみを指定してデータを取得できます。
-----
query {
getPosts {
id
title
description
photo
createdAt
updatedAt
authorId
}
}
-----
# Curlで送信する場合は以下のようにJSONにして改行を削除する必要があります。
-----
$ QUERY=$(cat <<EOS
{ "query": "{
getPosts {
id
title
description
photo
createdAt
updatedAt
authorId
}
}"
}
EOS
) && QUERY=$(echo $QUERY | tr -d '\n')
$ curl -X POST -d "${QUERY}" -H 'Content-Type: application/json' http://localhost:9000/graphql
-----
# データを登録する場合はMutationを利用します。
-----
# ユーザ登録
mutation {
signup(
email: "test@test.com"
password: "test1234"
name: "test"
) {
token
}
}
# 投稿
mutation {
createPost(
title:"titleA",
description:"textA",
photo:""
authorId: 1
) {
id
}
}
-----
$ cd backend
$ npx prisma studio
$ cd frontend
$ cp .env.example .env
$ yarn
$ yarn dev
プロジェクト | 概要 |
---|---|
TypeScript + Prisma + NestJSでGraphQLサーバを作ってみる | TypeScript + Prisma + NestJSでGraphQLサーバを作ってみる |