0.0
No commit activity in last 3 years
No release in over 3 years
domain_driven provides Rails abstract classes and generators to support for a Domain Driven Design
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.5
~> 4.0.2
>= 0
>= 0

Runtime

 Project Readme

Gem Version Code Climate Build Status

Gem Status

As of April 2014, Project has stalled out... As it turns out, Doing DDD while preserving ActiveRecord goodies, is not so easy.

As of 4 March 2014, Incomplete Extraction.
This gem is in the process of being extracted from a reference architecture RubyOnRails application.

DomainDriven

This gem and set of techniques allow you to use DDD to controll complexity and dependencies as your RubyOnRails application grows. The additional benefit is that since core domain logic is decoupled from the Rails framework and database, automated tests of the core domain logic can run very fast.

Domain Driven Design (DDD)

Domain-driven design (DDD) is an approach to software development for complex needs by connecting the implementation to an evolving model. The premise of domain-driven design is the following:

  • Placing the project's primary focus on the core domain logic.
  • Basing complex designs on a model of the domain.
  • Initiating a creative collaboration between technical and domain experts to iteratively refine a conceptual model that addresses particular domain problems. The term was coined by Eric Evans in his book.

Goals

  • Preserve the goodness of ActiveRecord.
  • Run automated tests fast and without loading Rails.
  • Provide generators to help with the plumbing.
  • Decouple core domain logic from the larger Rails set of libraries.

Installation

Add this line to your application's Gemfile:

gem 'domain_driven'

And then execute:

$ bundle

Or install it yourself as:

$ gem install domain_driven

Usage

Under constuction

Constraints

  • Rails 4+
  • Ruby 2+

Credits

Jim Weirich For conversations explaining to us the ideas inside wyriki

Eric Evans For providing the concept of Domain Driven Design

Contributing

  1. Fork it ( http://github.com/mwindholtz/domain_driven/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request