/coderdojo.jp

CoderDojo Japan official website developed by Ruby on Rails. 💎

Primary LanguageRubyMIT LicenseMIT

カバー画像

CoderDojo Japan

Build Status

一般社団法人 CoderDojo Japan の公式サイトです。Ruby on Rails で実装されています。本ページでは、トップページに掲載されている Dojo 情報を更新する方法や、開発環境のセットアップ方法などをまとめています。


🔰 Dojo を掲載するには?

CoderDojo を立ち上げ、承認されたら、CoderDojo Kata にある支援プログラムをご利用することができます。coderdojo.jp への掲載方法も載っていますので、詳細は CoderDojo Kata をご確認ください。

CoderDojo Kata - 支援


🔧 開発に参加するには?

coderdojo.jp の開発には以下のいずれかの方法で参加できます。Dojo 情報の修正やドキュメントの追加・執筆であれば、ブラウザだけで参加できます。

  1. Dojo 情報を更新する場合 (» 詳細を見る)
    • 必要なもの: ブラウザ + GitHub アカウント
  2. CoderDojo Kata を更新する場合 (» 詳細を見る)
    • 必要なもの: ブラウザ + GitHub アカウント
  3. 新機能の開発やデザインを改善する場合 (» 詳細を見る)
    • 必要なもの: Ruby on Rails + PostgreSQL などの各種開発環境

ちょっとした情報更新や文言修正であればブラウザだけで参加できるのが特徴で、それぞれの手順は以下の通りです ✨📝💨


1. Dojo 情報を更新する

Dojo 情報は次の手順で簡単に更新できます。

  1. db/dojos.yaml を開く
  2. 画面右にある ✎ アイコン (Fork this project and edit this file) をクリックする
  3. 気になる箇所を修正し、修正内容にタイトルと説明文を付け、Propose file change をクリックする
  4. 修正内容を確認し、問題なければ Create pull request をクリックする
    • ☯️ Dojo のロゴ画像を追加/変更したい場合は Pull Request のコメント欄に画像を添付して頂けると助かります 😌 (対応例1 / 対応例2)

以上で完了です。提案された修正はメンテナーによってチェックされ、問題なければ提案された内容が反映されます。もし問題があってもメンテナー側で気付いて修正できるので、まずはお気軽に提案してみてください 😉

https://coderdojo.jp/docs にあるドキュメントの編集方法も同様です。db/docsディレクトリをブラウザで開き、修正したいファイルをクリックして、修正内容を提案してください。同ディレクトページの右上にある Create new file ボタンをクリックすると、新しいドキュメントの追記を提案することもできます。


2. Kata 情報を更新する

Kata 情報も、Dojo 情報と同様の方法で更新できます。

  1. kata.html.erb を開く
  2. 画面右にある ✎ アイコン (Fork this project and edit this file) をクリックする
  3. 気になる箇所を修正し、修正内容にタイトルと説明文を付け、Propose file change をクリックする
  4. 修正内容を確認し、問題なければ Create pull request をクリックする (対応例)

以上で完了です。提案された修正はメンテナーによってチェックされ、問題なければ提案された内容が反映されます。もし問題があってもメンテナー側で気付いて修正できるので、まずはお気軽に提案してみてください 😉


3. 新機能の開発やデザインを改善する

本サイトでは以下の技術が使われているので、それぞれのツールをセットアップします。

セットアップ方法の方法は次の通りです。

  1. 本リポジトリを fork 後、clone します
  2. ターミナルから $ bin/setup を実行します
  3. $ rails server でローカルサーバーを立ち上げます
  4. ブラウザから localhost:3000 にアクセスします
  5. coderdojo.jp と同様のサイトが表示できれば完了です

🐳 Docker を利用したセットアップ方法

上記の他、Docker を使ったセットアップ方法もあります。Docker をインストールし、下記の手順でセットアップしてください 🛠💨

  1. 本リポジトリを fork 後、clone します
  2. .env.sample をコピーして .env にリネームします
  3. ターミナルから $ docker-compose up を実行します
  4. ターミナルから $ docker-compose exec rails bin/setup を実行します
  5. ブラウザから localhost:3000 にアクセスします
  6. coderdojo.jp と同様のサイトが表示できれば完了です

🚀 CI/Deploy 構成

coderdojo.jp は現在、次の構成でテスト・デプロイされています。

各コミットが push される度に CI が動きます。本家ブランチにコミットされ、CI が pass すると、Heroku 側でデプロイ前/デプロイ後の各種スクリプトが実行されます

GitHub Actions に deploy workflow を入れることもできましたが、次の2つの目的から現在は分離しています。

  1. CI フローと Deploy フローの責務を分離し、本番環境のログの機密性を高める
    • 例: デプロイ関連のログは Heroku Activity Logs に集約させ、誰でもアクセスできる状態にしない
  2. Heroku Release Phase を使い、本番環境の安定性を高める
    • 例: Heroku デプロイ後に実行するスクリプトが失敗したとき、デプロイ自体がロールバックするようにし、本番環境が落ちる可能性を小さくする

💎 CI で実行される各種 Ruby スクリプト (Rake タスク)

最新版は scripts/release.sh からご確認いただけます。

# データベースのマイグレーション
bundle exec rails db:migrate

# 開発用データの流し込み(seeding)
bundle exec rails db:seed

# db/dojos.yaml の内容をDBに反映するタスク
bundle exec rails dojos:update_db_by_yaml

# DBの内容を db/dojos.yaml に反映するタスク
bundle exec rails dojos:migrate_adding_id_to_yaml

# 近日開催の道場を更新するタスク
bundle exec rails dojo_event_services:upsert

# ポッドキャスト「DojoCast」のデータを反映するタスク
bundle exec rails podcasts:upsert

☁️ Development with Scrivito

(:warning: NOTE: Scrivito チームと相談し、今後別の仕組みに置き換わる予定です)

Some pages require Scrivito, Professional Cloud-Based Rails CMS, such as:

  • /kata
  • /news/* (Outdated)
  • /sotechsha/*

CMS enables wider people to contribute to editing contents, but on the other hand, this requires Scrivito API Keys for engineers to join developing Scrivito-used pages like above.

We use SCRIVITO_TENANT and SCRIVITO_API_KEY keys in production, but they are not required in development. If you find any problem that needs them report it to GitHub Issues.


4. 他、開発に関する資料

開発に関する資料は /docs や下記サイトにまとめてあります (最新順)。必要に応じて適宜ご参照ください。

🚧 API (開発中)

現在提供中の API です。互換性を破壊する変更が今後起こる可能性もあるため、本番環境で利用したい場合は一度ローカルファイルなどに退避させて使うのがオススメです! (利用例: 🗾 DojoMap - GitHub)

📜 Development History & Contributors


5. License

Check out each license

This web application is developed with many other brilliant works!
Check out the followings if you are interested in. 😉

🎨 Libraries & Icons

The libraries like RubyGems used in this web application have their own licenses. Say, this website uses Bootstrap, created by Twitter licensed under the MIT License.

Also this website uses icons created by Font Awesome, licensed under SIL OFL 1.1, and Twemoji, created by Twitter, licensed under the MIT License.

Thanks for their great works to make this app published! 💖

📝 Texts in Kata

The texts in Kata page are published under CC BY-NC-SA 4.0 license. But the texts do NOT include images, slides, and external websites. Please make sure to check their licenses and/or contact its owner before using them.

☯️ Logos & Photos

The images, such as logos and photos of each dojo, are NOT published under the following License. Contact its owner, like the maintainer of linked external website, before using them. 😌

💎 Codes, Scrivito gem, and Others

The source codes, such as HTML/CSS/JavaScript and Ruby codes not declared before, are published under The MIT License. Feel free to refer, copy, or share them. And contact info@coderdojo.jp if you find something unclear.

Also Scrivito gem is publishd under LGPL-3.0, but the author allows us to put MIT license. 😆✨

Sorry for the late reply, I wanted to confer with our team.
There is no conflict in the licenses and you are welcome to use the MIT license.

So, this application's code can be simply forked, copied, and modified under the MIT License below! 🆗


The MIT License

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Copyright © 一般社団法人 CoderDojo Japan