Skip to content

mwindholtz/domain_driven

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

50 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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

About

Domain Driven Design for Rails

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages