Why not login to Qiita and try out its useful features?

We'll deliver articles that match you.

You can read useful information later.

1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Sinatraで作る中高生向け悩み相談Webサービス「Ballon」- 総括版

Last updated at Posted at 2024-10-11

はじめに

この連載では、Rubyのマイクロフレームワークであるsinatraを使用して、中高生向け悩み相談Webサービス「Ballon」を開発する過程を詳細に解説してきました。この総括版では、5つのパートの主要なポイントをまとめ、全体像を把握しやすくします。

Part 1: アプリケーションの概要と基本設計

主要ポイント:

  1. 技術スタックの選定理由(Ruby、Sinatra、ActiveRecord、SQLite3)
  2. アプリケーションの基本構造とMVCパターンの適用
  3. データベース設計の基本(users、worries、answers、likesテーブル)
  4. Sinatraアプリケーションの基本設定(セッション管理、ヘルパーメソッドなど)

コードハイライト:

app.rb
require 'bundler/setup'
Bundler.require
require 'sinatra/reloader' if development?
require './models'

enable :sessions

helpers do
  def current_user
    User.find_by(id: session[:user])
  end
end

# 以下、各ルーティングの定義

Part 2: ユーザー認証システムの実装

主要ポイント:

  1. ユーザーモデルの設計とhas_secure_passwordの使用
  2. サインアップ、サインイン、サインアウト機能の実装
  3. セッション管理とユーザー認証の仕組み
  4. セキュリティ考慮事項(パスワードのハッシュ化、CSRF対策など)
  5. 中高生向けサービスならではの配慮(年齢確認、保護者の同意プロセスなど)

コードハイライト:

models.rb
class User < ActiveRecord::Base
  has_secure_password
  validates :username, presence: true, uniqueness: true
  validates :email, presence: true, format: { with: /.+@.+/ }, uniqueness: { case_sensitive: false }
  validates :password, length: { in: 8..20 }, if: -> { new_record? || changes[:password_digest] }
  validate :age_validation

  private

  def age_validation
    if birth_date.present? && birth_date > 13.years.ago.to_date
      errors.add(:birth_date, "You must be at least 13 years old to use this service")
    end
  end
end

Part 3: 悩み投稿機能の実装とデータベース設計

主要ポイント:

  1. 悩みモデルの設計とバリデーション
  2. 悩みのCRUD操作の実装
  3. 効率的なデータベースクエリの書き方
  4. N+1問題の解決とインデックスの活用
  5. 中高生の悩みに対する適切な対応(センシティブな内容のモデレーション、専門家への紹介など)

コードハイライト:

models.rb
class Worry < ActiveRecord::Base
  belongs_to :user
  has_many :answers, dependent: :destroy

  validates :title, presence: true, length: { maximum: 100 }
  validates :content, presence: true, length: { maximum: 1000 }
  
  scope :public_worries, -> { where(is_public: true) }
  scope :unresolved, -> { where(resolved_at: nil) }

  before_save :check_sensitive_content

  private

  def check_sensitive_content
    sensitive_words = ['自殺', '薬物', '虐待', # その他センシティブな単語]
    if sensitive_words.any? { |word| self.content.include?(word) }
      self.needs_moderation = true
    end
  end
end

Part 4: 回答機能、「いいね」機能、セキュリティ対策、コンテンツモデレーション

主要ポイント:

  1. 回答機能と「いいね」機能の実装
  2. XSS対策やCSRF対策などの高度なセキュリティ対策
  3. コンテンツモデレーション(キーワードフィルタリング、管理者用モデレーションシステムなど)
  4. 中高生向けサービスならではの配慮(適切な言葉遣い、利用時間制限、ポジティブな表現の奨励など)

コードハイライト:

app.rb
post '/answers/:answer_id/likes' do
  authenticate!
  answer = Answer.find(params[:answer_id])
  like = current_user.likes.new(answer: answer)
  if like.save
    redirect "/worries/#{answer.worry_id}"
  else
    redirect "/worries/#{answer.worry_id}"
  end
end

helpers do
  def user_friendly_message(key)
    messages = {
      welcome: "Ballonへようこそ!みんなで支え合う場所だよ。",
      password_error: "パスワードは8文字以上で、大文字、小文字、数字、記号をそれぞれ1つ以上含めてね。",
      # 他のメッセージ...
    }
    messages[key] || "なにかうまくいかないみたい。もう一度試してみてね。"
  end
end

Part 5: パフォーマンス最適化、アクセシビリティ、多言語対応、アナリティクス

主要ポイント:

  1. パフォーマンス最適化(キャッシング、非同期処理、データベース最適化など)
  2. アクセシビリティ対応(セマンティックなHTML、キーボード操作サポートなど)
  3. 多言語対応(i18nの設定、言語ファイルの作成など)
  4. アナリティクスとレポーティング(ログの記録、管理者用ダッシュボードなど)
  5. 倫理的考慮事項(プライバシー保護、データの取り扱い、安全性の確保など)

コードハイライト:

app.rb
require 'i18n'
I18n.load_path += Dir[File.join(settings.root, 'locales', '*.yml')]
I18n.default_locale = :ja

get '/worries' do
  cache do
    @worries = Worry.includes(:user, :answers).public_worries.paginate(page: params[:page], per_page: 20)
    erb :worries_index
  end
end

get '/admin/dashboard' do
  authenticate_admin!
  @total_users = User.count
  @total_worries = Worry.count
  @recent_signups = User.order(created_at: :desc).limit(10)
  erb :admin_dashboard
end

学んだ主要な教訓

  1. ユーザー中心設計の重要性
  2. セキュリティとプライバシーの最優先
  3. スケーラビリティの考慮
  4. 多様性への配慮
  5. 倫理的配慮の必要性
  6. コミュニティマネジメントの重要性
  7. 継続的な学習と改善の必要性

まとめ

Ballonの開発を通じて、Sinatraを使用したWebアプリケーション開発の技術的スキルだけでなく、中高生向けサービスを提供する上での様々な考慮事項や倫理的責任について学ぶことができました。

特に以下の点が重要であることを認識しました:

  1. ユーザーの安全とプライバシーを最優先すること
  2. 教育的価値と健全な成長を促進する機能を提供すること
  3. 技術的な実装と倫理的配慮のバランスを取ること
  4. 継続的な改善とユーザーフィードバックの重要性

Ballonのような中高生向けサービスの開発は、技術的なチャレンジだけでなく、社会的責任も伴う大きな挑戦です。しかし、適切に設計・実装されたサービスは、若者の健全な成長と問題解決能力の向上に大きく貢献する可能性を秘めています。

この連載が、Sinatraを使用したWebアプリケーション開発の実践的なガイドとなるだけでなく、若者向けサービスの開発に携わる方々にとって、倫理的配慮や社会的責任について考えるきっかけになれば幸いです。

参考リンク

1
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?