Annotation Interface ActivationCondition


@Retention(RUNTIME) @Target(METHOD) public @interface ActivationCondition
Marks a method as an activation condition for one or more sub-agents of a conditional agent. The method must be static and return a boolean indicating whether the sub-agent(s) should be activated.

Example:


    public interface ExpertsAgent {

        @ConditionalAgent(outputKey = "response", subAgents = {
                @SubAgent(type = MedicalExpert.class, outputKey = "response"),
                @SubAgent(type = TechnicalExpert.class, outputKey = "response"),
                @SubAgent(type = LegalExpert.class, outputKey = "response")
        })
        String askExpert(@V("request") String request);

        @ActivationCondition(MedicalExpert.class)
        static boolean activateMedical(@V("category") RequestCategory category) {
            return category == RequestCategory.MEDICAL;
        }

        @ActivationCondition(TechnicalExpert.class)
        static boolean activateTechnical(@V("category") RequestCategory category) {
            return category == RequestCategory.TECHNICAL;
        }

        @ActivationCondition(LegalExpert.class)
        static boolean activateLegal(AgenticScope agenticScope) {
            return agenticScope.readState("category", RequestCategory.UNKNOWN) == RequestCategory.LEGAL;
        }
    }

  • Required Element Summary

    Required Elements
    Modifier and Type
    Required Element
    Description
    Class<?>[]
     
  • Element Details

    • value

      Class<?>[] value