前提
Rails & Nuxt.jsのDocker環境をalpineイメージで構築する
こちらのポストの環境をもとに進めるので、Dockerのサービス名等は適宜読み替えていただくようにお願いします。
ディレクトリ構成
後述のコマンドでは、Railsは backend
、Nuxtは frontend
がDockerのサービス名になっています。
.
├── backend <- Ruby on Rails
│ ├── Dockerfile
│ ├── Gemfile
│ ├── Gemfile.lock
│ (中略)
│
├── frontend <- Nuxt.js
│ ├── Dockerfile
│ ├── README.md
│ ├── nuxt.config.js
│ ├── package-lock.json
│ ├── package.json
│ (中略)
│
├── docker-compose.yml
└── .env
ライブラリ追加
Rails
- graphql-ruby ... RubyでGraphQLを導入するならコレ
- graphiql-rails ... GraphQL IDE のRails版。ブラウザから
./backend/Gemfile
を修正し、 bundle install
します。
## (中略) ##
gem 'graphql' #added
group :development do
gem 'listen', '>= 3.0.5', '< 3.2'
# Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring
gem 'spring'
gem 'spring-watcher-listen', '~> 2.0.0'
gem 'graphiql-rails' #added
end
## (中略) ##
$ docker-compose exec backend bundle install
Nuxt
こちらのライブラリをインストールします。
本記事では graphql-tag は使いません。
$ docker-compose exec frontend yarn add @nuxtjs/apollo
実装
Rails
generator で雛形を作成します。
$ docker-compose exec backend rails g graphql:install
graphiql-railsの Readme にしたがって、Railsのconfigファイルを修正します。
./backend/config/routes.rb
GraphiQLエンジンをマウントし、ブラウザからアクセスできるようにします。
Rails.application.routes.draw do
post "/graphql", to: "graphql#execute" #generatorでinsertされる
# For details on the DSL available within this file, see http://guides.rubyonrails.org/routing.html
#added
if Rails.env.development?
mount GraphiQL::Rails::Engine, at: '/graphiql', graphql_path: '/graphql'
end
end
./backend/config/application.rb
APIモードの場合に必要な修正です。
## (中略) ##
- # require "sprockets/railtie"
+ require "sprockets/railtie"
## (中略) ##
GraphiQLで動作確認
dockerコンテナを再起動後、ブラウザで http://localhost:3000/graphiql にアクセスし、GraphiQLを開きます。
./backend/app/graphql/types/query_type.rb
のサンプルを利用して、下記のようにqueryの結果が返ってくればOKです。
$ docker-compose restart backend
Nuxt
Nuxtアプリのルートに、下記のディレクトリ、ファイルを追加、編集します。
今回はmutationは使いませんが、あわせて作成しておきます。
.
└── frontend
├── nuxt.config.js
│
├── pages
│ └── index.vue
│
└── apollo
├── client-configs
│ └── default.js
└── gqls
├── mutations
└── queries
└── testField.gql
./frontend/nuxt.config.js
Nuxtでapolloクライアントを使用するための設定を追加します。
default.js
を読み込まず、nuxt.config.jsに直書きしてもOKです。
export default {
/* (中略) */
modules: [
'@nuxtjs/apollo', //added
],
/* (中略) */
apollo: {
clientConfigs: {
default: '~/apollo/client-configs/default.js'
}
}
}
./frontend/apollo/client-configs/default.js
apolloには様々なオプションありますがが、今回はqueryの実行が確認できればよいので最低限です。
uriのホスト名は、DockerのRailsアプリのサービス名 backend
になります。
import { HttpLink } from 'apollo-link-http'
export default () => {
const httpLink = new HttpLink({ uri: 'http://backend:3000/graphql' })
return {
link: httpLink
}
}
./frontend/apollo/gqls/queries/testField.gql
GraphiQLで実行したものです。
query {
testField
}
./frontend/pages/index.vue
queryを実行した結果を表示します。
<template>
<p>{{ testField }}</p>
</template>
<script>
import testField from '~/apollo/gqls/queries/testField';
export default {
data() {
return {
testField: {}
}
},
apollo: {
testField: {
query: testField
}
}
}
</script>
お疲れさまでした。
(簡略化シすぎた感)