All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.axonframework.eventsourcing.EventSourcingHandler Maven / Gradle / Ivy

Go to download

Module containing all necessary infrastructure components to support Event Sourcing Command and Query models.

The newest version!
/*
 * Copyright (c) 2010-2018. Axon Framework
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.axonframework.eventsourcing;

import org.axonframework.eventhandling.EventHandler;
import org.axonframework.messaging.Message;
import org.axonframework.messaging.MetaData;

import java.lang.annotation.*;

/**
 * Annotation that marks a method in an Aggregate (either the root, or an entity) as a handler for Events generated by
 * that aggregate. The parameters of the annotated method are resolved using parameter resolvers.
 * 

* Axon provides a number of parameter resolvers that allow you to use the following parameter types:

    *
  • The first parameter is always the payload of the Event message, unless the {@code payloadType} parameter is * provided. In that case, the first parameter any other type of parameter described below.
  • *
  • Parameters annotated with {@code @MetaDataValue} will resolve to the Meta Data value with the key as indicated * on the annotation. If required is false (default), null is passed when the meta data value is not present. If * required is true, the resolver will not match and prevent the method from being invoked when the meta data value is * not present.
  • *
  • Parameters of type {@link MetaData} will have the entire Meta Data of an Event Message * injected.
  • *
  • Parameters of type {@link java.time.Instant} will resolve to the timestamp of the EventMessage. This is the * time at which the Event was generated.
  • *
  • Parameters assignable to {@link Message} will have the entire {@link * org.axonframework.eventhandling.EventMessage} injected (if the message is assignable to that parameter). If the first * parameter is of type message, it effectively matches an Event of any type, even if generic parameters would suggest * otherwise. Due to type erasure, Axon cannot detect what parameter is expected. In such case, it is best to declare a * parameter of the payload type, followed by a parameter of type Message.
  • *
  • When using Spring and {@code <axon:annotation-config/>} is declared, any other parameters will * resolve to autowired beans, if exactly one autowire candidate is available in the application context. This allows * you to inject resources directly into {@code @EventSourcingHandler} annotated methods.
  • *
*

* For each event, only a single method will be invoked per object instance with annotated methods. This method is * resolved in the following order:

  1. First, the event handler methods of the actual class (at runtime) are * searched
  2. If a method is found with a parameter that the domain event can be assigned to, it is marked as * eligible *
  3. After a class has been evaluated (but before any super class), the most specific event handler method is * called. That means that if an event handler for a class A and one for a class B are eligible, and B is a subclass of * A, then the method with a parameter of type B will be chosen
  4. If no method is found in the actual class, its super * class is evaluated.
  5. If still no method is found, the event listener ignores the event
*

* If you do not want any events to be ignored, but rather have some logging of the fact that an unhandled event came * by, make an abstract superclass that contains an event handler method that accepts any {@code Object}. *

* Note: if there are two event handler methods accepting the same argument, the behavior is undefined. * * @author Allard Buijze * @since 2.1 */ @EventHandler @Documented @Retention(RetentionPolicy.RUNTIME) @Target({ElementType.METHOD, ElementType.ANNOTATION_TYPE}) public @interface EventSourcingHandler { /** * The type of event this method handles. If specified, this handler will only be invoked for message that have a * payload assignable to the given payload type. *

* Optional. If unspecified, the first parameter of the method defines the type of supported event. * * @return The type of the event this method handles. */ Class payloadType() default Object.class; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy