Query Builder의 사용자 지정 설명 평가기 구현 implementing-a-custom-predicate-evaluator-for-the-query-builder

이 섹션에서는 를 확장하는 방법을 설명합니다. Query Builder 사용자 지정 술어 평가기를 구현합니다.

개요 overview

다음 Query Builder 는 콘텐츠 저장소를 손쉽게 쿼리할 수 있는 방법을 제공합니다. CQ에는 데이터를 처리하는 데 도움이 되는 술어 평가기 세트가 포함되어 있습니다.

그러나 일부 복잡성을 숨기고 더 나은 의미 체계를 보장하는 사용자 지정 술어 평가기를 구현하여 쿼리를 단순화할 수 있습니다.

사용자 지정 조건자는 XPath를 사용하여 직접 수행할 수 없는 다른 작업을 수행할 수도 있습니다. 예를 들면 다음과 같습니다.

  • 일부 서비스에서 데이터 조회
  • 계산을 기반으로 한 사용자 정의 필터링
NOTE
사용자 지정 술어를 구현할 때는 성능 문제를 고려해야 합니다.
NOTE
다음에서 쿼리의 예를 찾을 수 있습니다. Query Builder 섹션.

GITHUB의 코드

이 페이지의 코드는 GitHub에서 확인할 수 있습니다.

술어 평가기 세부 정보 predicate-evaluator-in-detail

술어 평가기는 쿼리의 정의 제약 조건인 특정 술어의 평가를 처리합니다.

실제 콘텐츠 모델에 맞는 특정 JCR 쿼리(예: 메타데이터/@width > 200)에 더 높은 수준의 검색 제한("width > 200")을 매핑합니다. 또는 수동으로 노드를 필터링하고 제약 조건을 확인할 수 있습니다.

NOTE
에 대한 자세한 내용은 PredicateEvaluatorcom.day.cq.search 패키지, 자세한 내용은 Java™ 설명서.

복제 메타데이터에 대한 사용자 지정 설명 평가기 구현 implementing-a-custom-predicate-evaluator-for-replication-metadata

이 섹션에서는 복제 메타데이터를 기반으로 데이터를 지원하는 사용자 정의 술어 평가기를 만드는 방법에 대해 설명합니다.

  • cq:lastReplicated 마지막 복제 작업의 날짜를 저장하는 날짜

  • cq:lastReplicatedBy 마지막 복제 작업을 트리거한 사용자의 id를 저장합니다.

  • cq:lastReplicationAction 마지막 복제 작업(예: 활성화, 비활성화)을 저장하는 작업

기본 술어 평가자를 사용하여 복제 메타데이터 쿼리 querying-replication-metadata-with-default-predicate-evaluators

다음 쿼리는 의 노드 목록을 가져옵니다. /content 에 의해 활성화된 분기 admin 연초부터.

path=/content

1_property=cq:lastReplicatedBy
1_property.value=admin

2_property=cq:lastReplicationAction
2_property.value=Activate

daterange.property=cq:lastReplicated
daterange.lowerBound=2013-01-01T00:00:00.000+01:00
daterange.lowerOperation=>=

이 쿼리는 유효하지만 읽기가 어려우며 세 가지 복제 속성 간의 관계를 강조 표시하지 않습니다. 사용자 지정 술어 평가기를 구현하면 복잡성이 줄어들고 이 쿼리의 의미 체계도 향상됩니다.

목표 objectives

의 목표 ReplicationPredicateEvaluator 는 다음 구문을 사용하여 위의 쿼리를 지원합니다.

path=/content

replic.by=admin
replic.since=2013-01-01T00:00:00.000+01:00
replic.action=Activate

복제 메타데이터 술어를 사용자 지정 술어 평가기와 그룹화하면 의미 있는 쿼리를 만드는 데 도움이 됩니다.

Maven 종속성 업데이트 중 updating-maven-dependencies

NOTE
Maven을 사용하는 새 Adobe Experience Manager(AEM) 프로젝트 설정은 다음 문서에서에 의해 문서화됩니다. Apache Maven을 사용하여 AEM 프로젝트를 작성하는 방법.

먼저 프로젝트의 Maven 종속성을 업데이트합니다. 다음 PredicateEvaluator 의 일부임 cq-search Maven pom.xml 파일에 추가해야 합니다.

NOTE
의 범위 cq-search 종속성이 다음으로 설정됨 provided 이유 cq-search 에서 제공합니다. OSGi 컨테이너.

pom.xml

다음 코드 조각은 의 차이점을 보여 줍니다. 통합 비교 형식

@@ -120,6 +120,12 @@
             <scope>provided</scope>
         <dependency>
+            <groupid>com.day.cq</groupid>
+            <artifactid>cq-search</artifactid>
+            <version>5.6.4</version>
+            <scope>provided</scope>
+        </dependency>
+        <dependency>
             <groupid>junit</groupid>
             <artifactid>junit</artifactid>
             <version>3.8.1</version></dependency>

aem-search-custom-predicate-evaluator - pom.xml

ReplicationPredicateEvaluator 작성 writing-the-replicationpredicateevaluator

다음 cq-search 이 프로젝트에는 AbstractPredicateEvaluator 추상 클래스입니다. 이를 몇 가지 단계를 통해 확장하여 자신만의 맞춤형 술어 평가기를 구현할 수 있습니다 (PredicateEvaluator).

NOTE
다음 절차에서는 Xpath 데이터를 필터링할 표현식입니다. 다른 옵션은 를 구현하는 것입니다. includes 행 단위로 데이터를 선택하는 메서드입니다. 다음을 참조하십시오. Java™ 설명서 추가 정보.
  1. 다음을 확장하는 Java™ 클래스 만들기 com.day.cq.search.eval.AbstractPredicateEvaluator

  2. 을(를) 사용하여 클래스에 주석 달기 @Component 다음과 같이

    src/main/java/com/adobe/aem/docs/search/ReplicationPredicateEvaluator.java

    다음 코드 조각은 의 차이점을 보여 줍니다. 통합 비교 형식

@@ -19,8 +19,11 @@
  */
 package com.adobe.aem.docs.search;

+import org.apache.felix.scr.annotations.Component;
+
 import com.day.cq.search.eval.AbstractPredicateEvaluator;

+@Component(metatype = false, factory = "com.day.cq.search.eval.PredicateEvaluator/repli")
 public class ReplicationPredicateEvaluator extends AbstractPredicateEvaluator {

 }

aem-search-custom-predicate-evaluator - src/main/java/com/adobe/aem/docs/search/ReplicationPredicateEvaluator.java

NOTE
다음 factory은(는) 다음으로 시작하는 고유한 문자열이어야 합니다. com.day.cq.search.eval.PredicateEvaluator/사용자 정의 이름으로 끝나는 경우 PredicateEvaluator.
NOTE
의 이름입니다. PredicateEvaluator 는 쿼리를 작성할 때 사용되는 술어 이름입니다.
  1. 오버라이드:

    code language-java
    public String getXPathExpression(Predicate predicate, EvaluationContext context)
    

    override 메서드에서 Xpath 를 기반으로 한 표현식 Predicate 논쟁 중에 주어집니다.

복제 메타데이터에 대한 사용자 지정 설명 평가기의 예 example-of-a-custom-predicate-evalutor-for-replication-metadata

이에 대한 완전한 구현 PredicateEvaluator 다음 클래스와 비슷할 수 있습니다.

src/main/java/com/adobe/aem/docs/search/ReplicationPredicateEvaluator.java

/*
 * #%L
 * aem-docs-custom-predicate-evaluator
 * %%
 * Copyright (C) 2013 Adobe Research
 * %%
 * 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
 *
 *      https://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.
 * #L%
 */

package com.adobe.aem.docs.search;

import org.apache.felix.scr.annotations.Component;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.day.cq.search.Predicate;
import com.day.cq.search.eval.AbstractPredicateEvaluator;
import com.day.cq.search.eval.EvaluationContext;

@Component(metatype = false, factory = "com.day.cq.search.eval.PredicateEvaluator/repli")

public class ReplicationPredicateEvaluator extends AbstractPredicateEvaluator {

    static final String PE_NAME = "replic";


    static final String PN_LAST_REPLICATED_BY = "cq:lastReplicatedBy";
    static final String PN_LAST_REPLICATED = "cq:lastReplicated";
    static final String PN_LAST_REPLICATED_ACTION = "cq:lastReplicationAction";

    static final String PREDICATE_BY = "by";
    static final String PREDICATE_SINCE = "since";
    static final String PREDICATE_SINCE_OP = " >= ";
    static final String PREDICATE_ACTION = "action";

    Logger log = LoggerFactory.getLogger(getClass());

    /**
     * Returns a XPath expression filtering by replication metadata.
     *
     * @see com.day.cq.search.eval.AbstractPredicateEvaluator#getXPathExpression(com.day.cq.search.Predicate,
     *      com.day.cq.search.eval.EvaluationContext)
     */

    @Override

    public String getXPathExpression(Predicate predicate,
            EvaluationContext context) {

        log.debug("predicate {}", predicate);

        String date = predicate.get(PREDICATE_SINCE);
        String user = predicate.get(PREDICATE_BY);
        String action = predicate.get(PREDICATE_ACTION);

        StringBuilder sb = new StringBuilder();

        if (date != null) {

            sb.append(PN_LAST_REPLICATED).append(PREDICATE_SINCE_OP);
            sb.append("xs:dateTime('").append(date).append("')");

        }

        if (user != null) {

            addAndOperator(sb);
            sb.append(PN_LAST_REPLICATED_BY);
            sb.append("='").append(user).append("'");

        }

        if (action != null) {

            addAndOperator(sb);
            sb.append(PN_LAST_REPLICATED_ACTION);
            sb.append("='").append(action).append("'");

        }

        String xpath = sb.toString();

        log.debug("xpath **{}**", xpath);

        return xpath;

    }

    /**
     * Add an and operator if the builder is not empty.
     *
     * @param sb a {@link StringBuilder} containing the query under construction
     */

    private void addAndOperator(StringBuilder sb) {

        if (sb.length() != 0) {

            sb.append(" and ");

        }

    }

}

aem-search-custom-predicate-evaluator - src/main/java/com/adobe/aem/docs/search/ReplicationPredicateEvaluator.java

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2