# Features

The framework combines the concepts of event sourcing, CQRS and DDD to provide support for building applications that are scalable, maintainable, can work in distributed environments and are easy to integrate with outside world. As such, it takes some rather opinionated approaches on the design of certain parts of its architecture. Revo also offers other common features and infrastructure that is often necessary for building complete applications – for example, database migrations, event upgrades, authorizations, validations, messaging, integrations, multi-tenancy or testing. Furthermore, its extensions implement other useful features like entity history change-tracking, auditing or user notifications.

[**Domain-Driven Design**](https://docs.revoframework.net/reference-guide/domain-building-blocks)\
Building blocks for rich DDD-style domain models ([aggregates](https://docs.revoframework.net/reference-guide/domain-building-blocks#aggregates), [entities](https://docs.revoframework.net/reference-guide/domain-building-blocks#entities), [value objects](https://docs.revoframework.net/reference-guide/domain-building-blocks#value-objects), [domain events](https://docs.revoframework.net/reference-guide/domain-building-blocks#domain-events), [repositories](https://docs.revoframework.net/reference-guide/data-persistence#aggregate-repository)...)

.

[**Event Sourcing**](https://docs.revoframework.net/reference-guide/events)\
Implementing event-sourced entity persistence with support for multiple event store backends (PostgreSQL, MSSQL, SQLite...).

[**CQRS**](https://docs.revoframework.net/reference-guide/commands-and-queries)\
Segregating command and query responsibilities with:

* [Commands and queries  ](https://docs.revoframework.net/reference-guide/commands-and-queries#commands-queries)
* Command/query [handlers  ](https://docs.revoframework.net/reference-guide/commands-and-queries#command-query-handlers)
* Processing pipeline with filters for cross-cutting concerns ([authorization](https://docs.revoframework.net/reference-guide/authorization), [validation](https://docs.revoframework.net/reference-guide/validation), etc.)
* [Different read/write models](https://docs.revoframework.net/reference-guide/projections)

[**A/synchronous event processing**](https://docs.revoframework.net/reference-guide/events)\
Support for both [synchronous](https://docs.revoframework.net/reference-guide/events#synchronous-event-processing) and [asynchronous](https://docs.revoframework.net/reference-guide/events#asynchronous-event-processing) event processing, guaranteed *at-least-once* delivery, event queues with strict sequence ordering (optionally), event source catch-ups, optional [pseudo-synchronous event dispatch](https://docs.revoframework.net/reference-guide/events#pseudo-synchronous-event-dispatch) for listeners (projectors, for example).

[**Data access**](https://docs.revoframework.net/reference-guide/data-persistence)\
&#x20;Thin abstraction layer for easy data persistence (e.g. querying read models) using *Entity Framework Core*, *Entity Framework 6*, *RavenDB,* testable *in-memory database* or other data providers. Includes support for simple [database migrations](https://docs.revoframework.net/reference-guide/database-migrations).

[**Projections**](https://docs.revoframework.net/reference-guide/projections)\
&#x20;Support for read-model projections with various backends (e.g. *Entity Framework Core* (*PostgreSQL*, *MSSQL*, *SQLite*,...), *Entity Framework 6*, *RavenDB*...), automatic idempotency- and concurrency-handling, etc.

[**SOA, messaging and integration**](https://docs.revoframework.net/reference-guide/integrations)\
Scale and integrate by [publishing and receiving events](https://docs.revoframework.net/reference-guide/integrations#rabbitmq-messaging-with-easynetq), commands and queries using common messaging patterns, e.g. with *RabbitMQ* message queue (using *EasyNetQ* connector or *Rebus* service bus).

[**Sagas**](https://docs.revoframework.net/reference-guide/sagas)\
Coordinating long-running processes or inter-aggregate cooperation with sagas that react to events (a.k.a. *process managers*).

[**Authorization**](https://docs.revoframework.net/reference-guide/authorization)\
Basic permission/role-based ACL for commands and queries, fine-grained row filtering.

**Other minor features:**

* [**Validation**](https://docs.revoframework.net/reference-guide/validation) for commands, queries and other structures
* [**Jobs**](https://docs.revoframework.net/reference-guide/jobs)
* [**Multi-tenancy**](https://docs.revoframework.net/reference-guide/multi-tenancy)
* [**Event message metadata**](https://docs.revoframework.net/reference-guide/events#event-messages-and-metadata)
* [**Event versioning**  ](https://docs.revoframework.net/reference-guide/events#event-versioning)
* [**Event upgrades**](https://docs.revoframework.net/reference-guide/events#event-upgrades)
* [**Database migrations**](https://docs.revoframework.net/reference-guide/database-migrations)
* **History and change-tracking**
* **User notifications:** event-based, with different output channels (mail, etc.), aggregation, buffering, etc.
* **.NET Core 3.0+, .NET Standard 2.0+ & .NET 4.7.2+ support (with integration for ASP.NET Core and ASP.NET)**
