Skip to content

Commit

Permalink
[DS-2042] Discovery/Solr is improperly indexing the "dc.description.p…
Browse files Browse the repository at this point in the history
…rovenance" field. Added the default configuration settings to the SpellIndexPlugin to ensure that the ignored metadata is not indexed in any way.
  • Loading branch information
KevinVdV committed Dec 17, 2014
1 parent c417798 commit 02ff2d8
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -971,6 +971,7 @@ protected void buildDocument(Context context, Item item)
}
}

List<String> toIgnoreMetadataFields = SearchUtils.getIgnoredMetadataFields(item.getType());
Metadatum[] mydc = item.getMetadata(Item.ANY, Item.ANY, Item.ANY, Item.ANY);
for (Metadatum meta : mydc)
{
Expand All @@ -989,7 +990,6 @@ protected void buildDocument(Context context, Item item)
field += "." + meta.qualifier;
}

List<String> toIgnoreMetadataFields = SearchUtils.getIgnoredMetadataFields(item.getType());
//We are not indexing provenance, this is useless
if (toIgnoreMetadataFields != null && (toIgnoreMetadataFields.contains(field) || toIgnoreMetadataFields.contains(unqualifiedField + "." + Item.ANY)))
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@
import org.dspace.content.Item;
import org.dspace.core.Context;

import java.util.List;

/**
* Created with IntelliJ IDEA.
* User: kevin
Expand All @@ -25,12 +27,29 @@ public class SolrServiceSpellIndexingPlugin implements SolrServiceIndexPlugin {
@Override
public void additionalIndex(Context context, DSpaceObject dso, SolrInputDocument document) {
if(dso instanceof Item){
Metadatum[] dcValues = ((Item) dso).getMetadata(Item.ANY, Item.ANY, Item.ANY, Item.ANY);
Item item = (Item) dso;
Metadatum[] dcValues = item.getMetadata(Item.ANY, Item.ANY, Item.ANY, Item.ANY);
List<String> toIgnoreMetadataFields = SearchUtils.getIgnoredMetadataFields(item.getType());
for (Metadatum dcValue : dcValues) {
document.addField("a_spell", dcValue.value);
String field = dcValue.schema + "." + dcValue.element;
String unqualifiedField = field;

String value = dcValue.value;

if (value == null)
{
continue;
}

if (dcValue.qualifier != null && !dcValue.qualifier.trim().equals(""))
{
field += "." + dcValue.qualifier;
}

if(!toIgnoreMetadataFields.contains(field)){
document.addField("a_spell", dcValue.value);
}
}
}

}
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@

import org.dspace.utils.DSpace;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

Expand All @@ -18,7 +19,7 @@
public class DiscoveryConfigurationService {

private Map<String, DiscoveryConfiguration> map;
private Map<Integer, List<String>> toIgnoreMetadataFields;
private Map<Integer, List<String>> toIgnoreMetadataFields = new HashMap<>();

public Map<String, DiscoveryConfiguration> getMap() {
return map;
Expand Down

0 comments on commit 02ff2d8

Please sign in to comment.