LuceneIndexDefinition.java
3.97 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/*
* Decompiled with CFR 0_118.
*
* Could not load the following classes:
* com.google.common.collect.ImmutableMap
* com.google.common.collect.ImmutableMap$Builder
* org.apache.jackrabbit.oak.plugins.index.lucene.IndexFormatVersion
* org.apache.sling.api.resource.PersistenceException
* org.apache.sling.api.resource.Resource
* org.apache.sling.api.resource.ResourceResolver
* org.slf4j.Logger
* org.slf4j.LoggerFactory
*/
package com.adobe.cq.mobile.index.impl.builder;
import com.adobe.cq.mobile.index.impl.builder.AggregationRule;
import com.adobe.cq.mobile.index.impl.builder.IndexDefinition;
import com.adobe.cq.mobile.index.impl.builder.IndexRule;
import com.google.common.collect.ImmutableMap;
import java.util.List;
import java.util.Map;
import org.apache.jackrabbit.oak.plugins.index.lucene.IndexFormatVersion;
import org.apache.sling.api.resource.PersistenceException;
import org.apache.sling.api.resource.Resource;
import org.apache.sling.api.resource.ResourceResolver;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class LuceneIndexDefinition
implements IndexDefinition {
private static final String[] GENERIC_LUCENE_EXCLUDES = new String[]{"/var", "/etc/replication", "/etc/workflow/instances", "/jcr:system"};
private static Logger log = LoggerFactory.getLogger(LuceneIndexDefinition.class);
String indexName;
List<IndexRule> indexRules;
List<AggregationRule> aggregationRules;
public LuceneIndexDefinition(String indexName, List<AggregationRule> aggregationRules, List<IndexRule> indexRules) {
this.indexName = indexName;
this.aggregationRules = aggregationRules;
this.indexRules = indexRules;
}
@Override
public boolean build(Resource resource) {
return this.build(resource, false);
}
@Override
public boolean build(Resource resource, boolean reindex) {
if (resource == null) {
log.warn("LuceneIndexDefinition build failed due to null resource");
return false;
}
ResourceResolver resolver = resource.getResourceResolver();
try {
Resource oakIndexNode = resolver.getResource(resource, "oak:index");
if (oakIndexNode == null) {
oakIndexNode = resolver.create(resource, "oak:index", (Map)new ImmutableMap.Builder().put((Object)"jcr:primaryType", (Object)"nt:unstructured").build());
}
log.info(oakIndexNode.getPath());
if (resolver.getResource(oakIndexNode, this.indexName) != null) {
resolver.delete(resolver.getResource(oakIndexNode, this.indexName));
}
Resource indexDefNode = resolver.create(oakIndexNode, this.indexName, (Map)new ImmutableMap.Builder().put((Object)"jcr:primaryType", (Object)"oak:QueryIndexDefinition").put((Object)"async", (Object)"async").put((Object)"compatVersion", (Object)IndexFormatVersion.V2.getVersion()).put((Object)"type", (Object)"lucene").put((Object)"evaluatePathRestrictions", (Object)true).put((Object)"excludedPaths", (Object)GENERIC_LUCENE_EXCLUDES).put((Object)"indexPath", (Object)(oakIndexNode.getPath() + "/" + this.indexName)).put((Object)"reindex", (Object)reindex).build());
Resource aggregatesNode = resolver.create(indexDefNode, "aggregates", (Map)ImmutableMap.of((Object)"jcr:primaryType", (Object)"nt:unstructured"));
for (AggregationRule aggRule : this.aggregationRules) {
aggRule.build(aggregatesNode);
}
Resource indexRulesNode = resolver.create(indexDefNode, "indexRules", (Map)ImmutableMap.of((Object)"jcr:primaryType", (Object)"nt:unstructured"));
for (IndexRule indexRule : this.indexRules) {
indexRule.build(indexRulesNode);
}
resolver.commit();
return true;
}
catch (PersistenceException e) {
log.error("Error while creating LuceneIndexDefinition at {}", (Object)resource.getPath(), (Object)e);
return false;
}
}
}