Interface IProjectionBuilder<TModel, TBuilder>
- Namespace
- Cratis.Chronicle.Projections
- Assembly
- Cratis.Chronicle.dll
Defines the based builder for building out projections.
public interface IProjectionBuilder<TModel, TBuilder> where TBuilder : class
Type Parameters
TModel
Type of model.
TBuilder
Type of actual builder.
Methods
AutoMap()
Automatically map event properties to model properties on the events added.
IProjectionBuilder<TModel, TBuilder> AutoMap()
Returns
- IProjectionBuilder<TModel, TBuilder>
Builder continuation.
Children<TChildModel>(Expression<Func<TModel, IEnumerable<TChildModel>>>, Action<IChildrenBuilder<TModel, TChildModel>>)
Start building the children projection for a specific child model.
TBuilder Children<TChildModel>(Expression<Func<TModel, IEnumerable<TChildModel>>> targetProperty, Action<IChildrenBuilder<TModel, TChildModel>> builderCallback)
Parameters
targetProperty
Expression<Func<TModel, IEnumerable<TChildModel>>>Expression for expressing the target property.
builderCallback
Action<IChildrenBuilder<TModel, TChildModel>>Builder callback.
Returns
- TBuilder
Builder continuation.
Type Parameters
TChildModel
Type of nested child model.
FromEvery(Action<IFromEveryBuilder<TModel>>)
Start building property expressions that applies for every events being projected from.
TBuilder FromEvery(Action<IFromEveryBuilder<TModel>> builderCallback)
Parameters
builderCallback
Action<IFromEveryBuilder<TModel>>Callback for building.
Returns
- TBuilder
Builder continuation.
From<TEvent>(Action<IFromBuilder<TModel, TEvent>>?)
Start building the from expressions for a specific event type.
TBuilder From<TEvent>(Action<IFromBuilder<TModel, TEvent>>? builderCallback = null)
Parameters
builderCallback
Action<IFromBuilder<TModel, TEvent>>Optional callback for building.
Returns
- TBuilder
Builder continuation.
Type Parameters
TEvent
Type of event.
Remarks
If using .AutoMap() the properties will be automatically mapped. In many cases you then don't need to provide a builder callback. You can override the mapping by providing a builder callback.
Join<TEvent>(Action<IJoinBuilder<TModel, TEvent>>?)
Start building a join expressions for a specific event type.
TBuilder Join<TEvent>(Action<IJoinBuilder<TModel, TEvent>>? builderCallback = null)
Parameters
builderCallback
Action<IJoinBuilder<TModel, TEvent>>Optional callback for building.
Returns
- TBuilder
Builder continuation.
Type Parameters
TEvent
Type of event.
Remarks
If using .AutoMap() the properties will be automatically mapped. In many cases you then don't need to provide a builder callback. You can override the mapping by providing a builder callback.
RemovedWithJoin<TEvent>(Action<RemovedWithJoinBuilder<TModel, TEvent>>?)
Defines what event removes a child through a join. This is optional, your system can chose to not support removal.
TBuilder RemovedWithJoin<TEvent>(Action<RemovedWithJoinBuilder<TModel, TEvent>>? builderCallback = null)
Parameters
builderCallback
Action<RemovedWithJoinBuilder<TModel, TEvent>>Optional callback for building.
Returns
- TBuilder
Builder continuation.
Type Parameters
TEvent
Type of event.
RemovedWith<TEvent>(Action<RemovedWithBuilder<TModel, TEvent>>?)
Defines what event removes a child. This is optional, your system can chose to not support removal.
TBuilder RemovedWith<TEvent>(Action<RemovedWithBuilder<TModel, TEvent>>? builderCallback = null)
Parameters
builderCallback
Action<RemovedWithBuilder<TModel, TEvent>>Optional callback for building.
Returns
- TBuilder
Builder continuation.
Type Parameters
TEvent
Type of event.
WithInitialValues(Func<TModel>)
Sets the initial values to use for a new model instance.
TBuilder WithInitialValues(Func<TModel> initialValueProviderCallback)
Parameters
initialValueProviderCallback
Func<TModel>Callback for building.
Returns
- TBuilder
Builder continuation.
Remarks
If one does not provide initial values, the projection engine will leave properties out that hasn't been met by an event projection expression. This will effectively render the properties null and might not be desirable when reading instances of the models.