Coder Social home page Coder Social logo

roadtoagility / dflow Goto Github PK

View Code? Open in Web Editor NEW
15.0 4.0 6.0 1.37 MB

DFlow is a Domain-Driven Design platform that provides the infrastructure to organize business logic, design your domain model, deliver domain events and store in different formats.

License: Mozilla Public License 2.0

C# 100.00%
ddd domainevents event-sourcing eventdriven aggregates dflow dflow-nuget cqrs persistence

dflow's Introduction

DFlow - Domain Flow

It is a set of framework to learn, organize and accelerate development of the heart of software.

Package source

<repository url="https://github.com/roadtoagility/dflow" />

Project Informations

GitHub issues GitHub stars GitHub forks GitHub license

Code Quality

codecov Codacy Badge CodeQL

CI Status

Build and Testing

Breaking Changes in 0.6.3 -> v0.8.0

That is a major refactoring of DFlow to be more "friendly" and have consistent programming model.

  • DFlow.Business will be maintained any more
  • DFlow.Business.Cqrs will be maintained any more
  • DFlow.Domain become DFlow (back to origins :)
  • DFlow.Specifications become a separated assembly
  • BaseEntity -> EntityBase
  • All Events must inherits from DomainEvent abstract class
  • There a new interface to raise events, so events can be raised from Entities or via Aggregates as you need.
  • DFlow.Domain.Events merged with DFlow and had several APIs changes

About Project

Domain Flow aka DFlow is a very light and opnionated set of frameworks to help implement the hearth of applications based on Domain-Driven Design. There are 3 assemblys organized as described bellow:

  • DFlow: Core assembly providing objets to implement Entities, ValueObjects, Validations and Aggregates;
  • DFlow.Specifications: It is a Specification Design Pattern implementation;
  • DFlow.Persistence: This project depends on DFlow because it is responsible to translate from/to domain objects representation. It is a set os interfaces to materialize domain layer to be persisted in any format that you want. The 3 major patterns implemented are Unity Of Work and Repository.

Addon: DFlow.Persistence. DFlow as based on clean architecture principles, so domain layer aka Entities are first class citizen.

Usage

Referencing DFlow

Creating Domain objects

  1. The most basic DFlow business object is the Value Object implementation that allows you follow the principle of non-primitive obsession for the objects you want.
// Value Object
public sealed class Email : ValueOf<string,Email>
{

}
  1. Defining and Entity
// Entity
public class User : EntityBase<UserId>
{
    public User(UserId identity, Email mail, VersionId version)
        : base(identity, version)
    {
        Mail = mail;

        AppendValidationResult(identity.ValidationStatus.Failures);
        AppendValidationResult(mail.Failures);
    }

    public Email Mail { get; private set; }

    protected override IEnumerable<object> GetEqualityComponents()
    {
        yield return Identity;
        yield return Mail;
    }

    // DOmain objects can have static contualized api based on factory methods
    public static PrimaryEntity From(PrimaryEntityId id, SecondaryEntity secondary, SimpleValueObject simpleObject,
        VersionId version)
    {
        return new PrimaryEntity(id, secondary, simpleObject, version);
    }

    // Domain Objects can have instance business methods
    // Entities can raise events
    public void Update(Email mail)
    {
        if (!mail.ValidationStatus.IsValid)
        {
            AppendValidationResult(mail.ValidationStatus.Failures);
        }

        Mail = mail;
        RaisedEvent(UserMailUpdatedEvent.For(this));
    }

}

Contributors

Supporters

Supporter Description
./img/ All Products Pack License for Open Source under program Free License Programs

Thanks

A special thank you to Jetbrains for donating licenses to the project.

License

This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0. If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.

dflow's People

Contributors

dependabot[bot] avatar douglasjramalho avatar dougramalho avatar drr00t avatar zamabraga avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar

dflow's Issues

Creation of Business Objects are expensive

DFlow has two different types of business object:

  • Entities
  • Value Objects

Both are responsible for:

  • Enforce the existing rules for the concept that they represent, like:

Money internally is a numeric type, and has rules like least value is 0, and maybe a top limit value.

So, for those do we use:

  • read-only object rule enforced by private constructors and supported by factory methods
  • Existential validations rely on Validator object implement with FluentValidator
  • Transport validation error to parent object like Entity via property ValidationResults

We really would like to remove FluentValidator dependency and to have our own implementation of Chain of Responsibility desing pattern but we can't lose factory method object building style.

One thing that could be nice is to concepts like ValueOf library and implement validation integrated to Object construction.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.