Releases: eventflow/EventFlow
Releases · eventflow/EventFlow
v0.23.1470
- Breaking: EventFlow no longer ignores columns named
Id
in MSSQL read models.
If you were dependent on this, use theMsSqlReadModelIgnoreColumn
attribute - Fixed: Instead of using
MethodInfo.Invoke
to call methods on reflected
types, e.g. when a command is published, EventFlow now compiles an expression
tree instead. This has a slight initial overhead, but provides a significant
performance improvement for subsequent calls - Fixed: Read model stores are only invoked if there's any read model updates
- Fixed: EventFlow now correctly throws an
ArgumentException
if EventFlow has
been incorrectly configure with known versioned types, e.g. an event
is emitted that hasn't been added during EventFlow initialization. EventFlow
would handle the save operation correctly, but if EventFlow was reinitialized
and the event was loaded before it being emitted again, an exception would
be thrown as EventFlow would know which type to use. Please make sure to
correctly load all event, command and job types before use - Fixed:
IReadModelFactory<>.CreateAsync(...)
is now correctly used in
read store mangers - Fixed: Versioned type naming convention now allows numbers
v0.22.1393
- New: To customize how a specific read model is initially created, implement
a specificIReadModelFactory<>
that can bootstrap that read model - New: How EventFlow handles MSSQL read models has been refactored to allow
significantly more freedom to developers. MSSQL read models are no longer
required to implementIMssqlReadModel
, only the emptyIReadModel
interface. Effectively, this means that no specific columns are required,
meaning that the following columns are no longer enforced on MSSQL read
models. Use the new requiredMsSqlReadModelIdentityColumn
attribute to mark
the identity column and the optional (but recommended)
MsSqlReadModelVersionColumn
to mark the version column.string AggregateId
DateTimeOffset CreateTime
DateTimeOffset UpdatedTime
int LastAggregateSequenceNumber
- Obsolete:
IMssqlReadModel
andMssqlReadModel
. Developers should instead
use theMsSqlReadModelIdentityColumn
andMsSqlReadModelVersionColumn
attributes to mark the identity and version columns (read above).
EventFlow will continue to supportIMssqlReadModel
, but it will be
removed at some point in the future - Fixed: Added missing
UseElasticsearchReadModel<TReadModel, TReadModelLocator>()
extension
v0.21.1312
- New: Added
Identity<>.NewComb()
that creates sequential unique IDs which can
be used to minimize database fragmentation - New: Added
IReadModelContext.Resolver
to allow read models to fetch
additional resources when events are applied - New: The
PrettyPrint()
type extension method, mostly used for verbose
logging, now prints even prettier type names, e.g.
KeyValuePair<Boolean,Int64>
instead of merelyKeyValuePair'2
, making log
messages slightly more readable
v0.20.1274
- Breaking:
Entity<T>
now inherits fromValueObject
but uses only theId
field as equality component. OverrideGetEqualityComponents()
if you have
a different notion of equality for a specific entity - Breaking:
Entity<T>
will now throw anArgumentNullException
if theid
passed to its constructor isnull
- Breaking: Fixed method spelling. Renamed
ISpecification<T>.WhyIsNotStatisfiedBy
toWhyIsNotSatisfiedBy
and
Specification<T>.IsNotStatisfiedBecause
toIsNotSatisfiedBecause
- New: Read model support for Elasticsearch via the new NuGet package
EventFlow.ReadStores.Elasticsearch
v0.19.1225
- Breaking:
AddDefaults
now also adds the job type definition to the
IJobsDefinitonService
- New: Implemented a basic specification pattern by providing
ISpecification<T>
, an easy-to-useSpecificaion<T>
and a set of extension
methods. Look at the EventFlow specification tests to get started - Fixed:
IEventDefinitionService
,ICommandDefinitonService
and
IJobsDefinitonService
now longer throw an exception if an existing
event is loaded, i.e., multiple calls toAddEvents(...)
,AddCommand(...)
andAddJobs(...)
no longer throws an exception - Fixed:
DomainError.With(...)
no longer executesstring.format
if only
one argument is parsed
v0.18.1181
- POTENTIAL DATA LOSS for the files event store: The EventFlow
internal functionality regarding event stores has been refactored resulting
in information regarding aggregate names being removed from the event
persistence layer. The files based event store no longer stores its events in
the path[STORE PATH]\[AGGREGATE NAME]\[AGGREGATE ID]\[SEQUENCE].json
, but
in the path[STORE PATH]\[AGGREGATE ID]\[SEQUENCE].json
. Thus if you are
using the files event store for tests, you should move the events into the
new file structure. Alternatively, implement the newIFilesEventLocator
and
provide your own custom event file layout. - Breaking: Event stores have been split into two parts, the
IEventStore
and the newIEventPersistence
.IEventStore
has the same interface before
but the implementation is now no longer responsible for persisting the events,
only converting and serializing the persisted events.IEventPersistence
handles the actual storing of events and thus if any custom event stores have
been implemented, they should implement to the newIEventPersistence
instead. - New: Added
IEntity
,IEntity<>
and an optionalEntity<>
that developers
can use to implement DDD entities.
v0.17.1134
- Fixed: Using NuGet package
EventFlow.Autofac
causes an exception with the
messageThe type 'EventFlow.Configuration.Registrations.AutofacStartable' is not assignable to service 'Autofac.IStartable
during EventFlow setup
v0.16.1120
- Breaking: Removed
HasRegistrationFor<>
andGetRegisteredServices()
fromIServiceRegistration
and added them toIResolver
instead. The
methods required that all service registrations went through EventFlow,
which in most cases they will not - Obsolete: Marked
IServiceRegistration.RegisterIfNotRegistered(...)
, use
thekeepDefault = true
on the otherRegister(...)
methods instead - New: Major changes have been done to how EventFlow handles service
registration and bootstrapping in order for developers to skip calling
CreateResolver()
(orCreateContainer()
if using theEventFlow.Autofac
package) completely. EventFlow will register its bootstrap services in the
IoC container and configure itself whenever the container is created - New: Introduced
IBootstrap
interface that you can register. It has a
singleBootAsync(...)
method that will be called as soon as the IoC
container is ready (similar to that ofIStartable
of Autofac) - Fixed: Correct order of service registration decorators. They are now
applied in the same order they are applied, e.g., the last registered
service decorator will be the "outer" service - Fixed: Added missing
ICommand<,>
interface to abstractCommand<,>
class in
EventFlow.Commands
.
v0.15.1057
- Fixed: Added
UseHangfireJobScheduler()
and markedUseHandfireJobScheduler()
obsolete, fixing method spelling mistake
v0.14.1051
- Breaking: All
EventFlowOptions
extensions are nowIEventFlowOptions
instead andEventFlowOptions
implements this interface. If you have made
your own extensions, you will need to use the newly created interface
instead. Changed in order to make testing of extensions and classes
dependent on the EventFlow options easier to test - New: You can now bundle your configuration of EventFlow into modules that
implementIModule
and register these by calling
EventFlowOptions.RegisterModule(...)
- New: EventFlow now supports scheduled job execution via e.g. Hangfire. You
can create your own scheduler or install the newEventFlow.Hangfire
NuGet
package. Read the jobs documentation for more details - New: Created the OWIN
CommandPublishMiddleware
middleware that can
handle publishing of commands by posting a JSON serialized command to
e.g./commands/ping/1
in whichping
is the command name and1
its
version. Remember to add authentication - New: Created a new interface
ICommand<TAggregate,TIdentity,TSourceIdentity>
to allow developers to control the type ofICommand.SourceId
. Using the
ICommand<TAggregate,TIdentity>
(or Command<TAggregate,TIdentity>)
will still yield the same result as before, i.e.,ICommand.SourceId
being
of typeISourceId
- New: The
AddDefaults(...)
now also adds the command type definition to the
newICommandDefinitonService