summaryrefslogtreecommitdiffstats
path: root/container-search/src/main/java/com/yahoo/search/schema/Schema.java
diff options
context:
space:
mode:
Diffstat (limited to 'container-search/src/main/java/com/yahoo/search/schema/Schema.java')
-rw-r--r--container-search/src/main/java/com/yahoo/search/schema/Schema.java45
1 files changed, 45 insertions, 0 deletions
diff --git a/container-search/src/main/java/com/yahoo/search/schema/Schema.java b/container-search/src/main/java/com/yahoo/search/schema/Schema.java
index c20aa1e81bd..20a776dc53e 100644
--- a/container-search/src/main/java/com/yahoo/search/schema/Schema.java
+++ b/container-search/src/main/java/com/yahoo/search/schema/Schema.java
@@ -8,6 +8,7 @@ import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Objects;
+import java.util.Optional;
/**
* Information about a schema which is part of the application running this.
@@ -20,25 +21,57 @@ import java.util.Objects;
public class Schema {
private final String name;
+ private final Map<String, Field> fields;
+ private final Map<String, FieldSet> fieldSets;
private final Map<String, RankProfile> rankProfiles;
private final Map<String, DocumentSummary> documentSummaries;
+ /** Fields indexed by both name and aliases. */
+ private final Map<String, Field> fieldsByAliases;
+
private Schema(Builder builder) {
this.name = builder.name;
+ this.fields = Collections.unmodifiableMap(builder.fields);
+ this.fieldSets = Collections.unmodifiableMap(builder.fieldSets);
this.rankProfiles = Collections.unmodifiableMap(builder.rankProfiles);
this.documentSummaries = Collections.unmodifiableMap(builder.documentSummaries);
+
+ fieldSets.values().forEach(fieldSet -> fieldSet.setSchema(this));
rankProfiles.values().forEach(rankProfile -> rankProfile.setSchema(this));
+
+ fieldsByAliases = new HashMap<>();
+ for (Field field : fields.values()) {
+ fieldsByAliases.put(field.name(), field);
+ field.aliases().forEach(alias -> fieldsByAliases.put(alias, field));
+ }
}
public String name() { return name; }
+ public Map<String, Field> fields() { return fields; }
public Map<String, RankProfile> rankProfiles() { return rankProfiles; }
public Map<String, DocumentSummary> documentSummaries() { return documentSummaries; }
+ /**
+ * Looks up a field or field set by the given name or alias in this schema.
+ *
+ * @param fieldName the name or alias of the field or field set. If this is empty, the name "default" is looked up
+ * @return information about the field or field set with the given name, or empty if no item with this name exists
+ */
+ public Optional<FieldInfo> fieldInfo(String fieldName) {
+ if (fieldName.isEmpty())
+ fieldName = "default";
+ Field field = fieldsByAliases.get(fieldName);
+ if (field != null) return Optional.of(field);
+ return Optional.ofNullable(fieldSets.get(fieldName));
+ }
+
@Override
public boolean equals(Object o) {
if (o == this) return true;
if ( ! (o instanceof Schema other)) return false;
if ( ! other.name.equals(this.name)) return false;
+ if ( ! other.fields.equals(this.fields)) return false;
+ if ( ! other.fieldSets.equals(this.fieldSets)) return false;
if ( ! other.rankProfiles.equals(this.rankProfiles)) return false;
if ( ! other.documentSummaries.equals(this.documentSummaries)) return false;
return true;
@@ -57,6 +90,8 @@ public class Schema {
public static class Builder {
private final String name;
+ private final Map<String, Field> fields = new LinkedHashMap<>();
+ private final Map<String, FieldSet> fieldSets = new LinkedHashMap<>();
private final Map<String, RankProfile> rankProfiles = new LinkedHashMap<>();
private final Map<String, DocumentSummary> documentSummaries = new LinkedHashMap<>();
@@ -64,6 +99,16 @@ public class Schema {
this.name = Objects.requireNonNull(name);
}
+ public Builder add(Field field) {
+ fields.put(field.name(), field);
+ return this;
+ }
+
+ public Builder add(FieldSet fieldSet) {
+ fieldSets.put(fieldSet.name(), fieldSet);
+ return this;
+ }
+
public Builder add(RankProfile profile) {
rankProfiles.put(profile.name(), profile);
return this;