はじめに
以前書いた以下記事の内容を表にあらわしてみました。
Railsとアーキテクチャ
| Rails | DDD | Clean Architecture |
|---|---|---|
| ActionView | UI層 | Frameworks & Drivers(UI) |
| ActionController | アプリケーション層 | Interface Adapters(Controllers / Presenters) / Application Business Rules(Use Cases / Interactor) |
| ActiveModel::Model | ドメイン層 | Enterprise Business Rules(Entities) |
| ActiveRecord::Persistence | インフラストラクチャ層 | Application Business Rules(Repository) / Interface Adapters(Repository) |
Railsとドメインモデル
| Rails | DDD | Clean Architecture |
|---|---|---|
| ActiveRecord::ActiveModel | Entities | Entities, Repository |
| ActiveRecord::Aggregations | Value Objects | Entities |
| Module::Concerning | Modules | Entities |
| サービスオブジェクト / ActievRecord::Callbacks / ActiveRecord::Validations | Domain Service | Entities |
| ActionController / サービスオブジェクト / フォームオブジェクト / ActiveRecord::Observer(-Rails 4.0) / ActievRecord::Callbacks / ActiveRecord::Validations | Application Service | Use Cases / Interactor |
Railsとドメインオブジェクトのライフサイクル
| Rails | DDD | Clean Architecture |
|---|---|---|
| フォームオブジェクト | Aggregates | - |
| - | Factories | - |
| ActiveRecord::QueryMethods | Repositories | Application Business Rules(Repository) / Interface Adapters(Repository) |
参考
- パーフェクトRails Part5 エキスパートRails
- texta.fm
- Ruby on Railsの正体と向き合い方 / What is Ruby on Rails and how to deal with it?
- Realworld Domain Model on Rails
- 俺が悪かった。素直に間違いを認めるから、もうサービスクラスとか作るのは止めてくれ
- Rails サービスクラス再考 / have a rethink on Rails service class
- Ruby on Rails ガイド
- Ruby on Rails API
- DDD難民に捧げる Domain-Driven Designのエッセンス 第2回 DDDの基礎と実践
- 「IDDD本から理解するドメイン駆動設計」連載一覧
- クリーンアーキテクチャ完全に理解した
最後に
独断と偏見に基づくため、明らかな誤りや異なるご意見についてお気軽にコメントいただけますと幸いです。