Details

    • Type: Feature Request
    • Status: Open (View Workflow)
    • Priority: Optional
    • Resolution: Unresolved
    • Affects Version/s: None
    • Fix Version/s: 2.1 (Discussion)
    • Component/s: Beans
    • Labels:
      None

      Description

      We should allow ordering of bean instance injection using the Instance<MyBeanInterface> when an instance injection is used.

      Use case:

      Developer always define a kind of chain of processor beans, which may need to run in specific order.

      Current scenario:

      Using the Instance injection mechanism, a developer can inject multiple beans implementing the same interface and iterate of them. In order to ensure ordering, the developer could do one of the following:

      #1

      private Iterable<MyBeanInterface> myBeans;
      
      @Inject
      void injectBeans(@Any Instance<MyBeanInterface> myBeans) {
        //the create order does some kind of ordering on the beans.
         this.myBeans = createOrder(myBeans);
      }
      

      #2
      This second option may be expensive if we have to order the beans everytime we execute the logic, and if this bean is applicationscoped, it wont make sense to do the ordering in the method call.

      
      @Any
      @Inject
      private Instance<MyBeanInterface> myBeans;
      
      public void doSomething() {
        Iterable<MyBeanInterface> orderedbeans = createOrder(myBeans.select(someQualifier));
      }
      

      Our Proposal

      We already have javax.annotation.Priority or any cdi specific annotation which we can add to MyBeanInterfaceImpl so that on injection of an Instance<MyBeanInterface>, all possible injection values are sorted based on the Priority.value() and if no annotation is defined, defaults to Priority.value = Integer.MAX_VALUE

      public interface MyBeanInterface {}
      
      @MyQualifier
      @Priority(0)
      public class MyFirstBean implements MyBeanInterface{
      }
      
      @MyQualifier
      @Priority(2)
      public class MySecondBean implements MyBeanInterface{
      }
      
      @ApplicationScoped
      public class MyBeanProcessor {
      
        //We expect that this injected instances shall be in order based on the @Priority annotation
        @Any
        @Inject
        private Instance<MyBeanInterface> myBeans;
      }
      

        Gliffy Diagrams

          Attachments

            Issue Links

              Activity

                People

                • Assignee:
                  Unassigned
                  Reporter:
                  marembo2008 Ochieng Marembo
                • Votes:
                  2 Vote for this issue
                  Watchers:
                  6 Start watching this issue

                  Dates

                  • Created:
                    Updated: