Class ClientAnnotationProcessor


  • public class ClientAnnotationProcessor
    extends AnnotationProcessor

    Processes annotations in client-side service objects.

    Service objects must be annotated with Service at class level to be processed by this processor, for example:

     @Service
     public class MyService
     {
         @Listener(Channel.META_CONNECT)
         public void metaConnect(Message message)
         {
             // Do something
         }
     }
     

    The processor is used in this way:

     ClientSession bayeux = ...;
     ClientAnnotationProcessor processor = ClientAnnotationProcessor.get(bayeux);
     MyService s = new MyService();
     processor.process(s);
     
    • Constructor Detail

      • ClientAnnotationProcessor

        public ClientAnnotationProcessor​(ClientSession clientSession)
      • ClientAnnotationProcessor

        public ClientAnnotationProcessor​(ClientSession clientSession,
                                         java.lang.Object... injectables)
    • Method Detail

      • process

        public boolean process​(java.lang.Object bean)
        Processes dependencies annotated with Session, callbacks annotated with Listener and Subscription and lifecycle methods annotated with PostConstruct.
        Parameters:
        bean - the annotated service instance
        Returns:
        true if at least one dependency or callback has been processed, false otherwise
      • processPostConstruct

        public boolean processPostConstruct​(java.lang.Object bean)
        Processes lifecycle methods annotated with PostConstruct.
        Overrides:
        processPostConstruct in class AnnotationProcessor
        Parameters:
        bean - the annotated service instance
        Returns:
        true if at least one lifecycle method has been invoked, false otherwise
      • deprocess

        public boolean deprocess​(java.lang.Object bean)
        Performs the opposite processing done by process(Object) on callbacks methods annotated with Listener and Subscription, and on lifecycle methods annotated with PreDestroy.
        Parameters:
        bean - the annotated service instance
        Returns:
        true if at least one deprocessing has been performed, false otherwise
        See Also:
        process(Object)
      • deprocessCallbacks

        public boolean deprocessCallbacks​(java.lang.Object bean)
        Performs the opposite processing done by processCallbacks(Object) on callback methods annotated with Listener and Subscription.
        Parameters:
        bean - the annotated service instance
        Returns:
        true if the at least one callback has been deprocessed
      • processPreDestroy

        public boolean processPreDestroy​(java.lang.Object bean)
        Processes lifecycle methods annotated with PreDestroy.
        Overrides:
        processPreDestroy in class AnnotationProcessor
        Parameters:
        bean - the annotated service instance
        Returns:
        true if at least one lifecycle method has been invoked, false otherwise