Move solr field mappings for projects && add quotes

This commit is contained in:
Serafeim Chatzopoulos 2024-06-28 15:36:02 +03:00
parent a8f3c1dd72
commit 80b3a1e7c2
2 changed files with 40 additions and 36 deletions

View File

@ -12,16 +12,10 @@ import java.util.Optional;
@Mapper(componentModel = "spring") @Mapper(componentModel = "spring")
public interface ProjectRequestMapper { public interface ProjectRequestMapper {
Map<String, String> sortFieldMapping = Map.ofEntries(
Map.entry("relevance", "score"),
Map.entry("startDate", "projectstartyear"),
Map.entry("endDate", "projectendyear")
);
@Mapping(target = "start", expression = "java( calculateStart(src.getPage(), src.getPageSize()) )") @Mapping(target = "start", expression = "java( calculateStart(src.getPage(), src.getPageSize()) )")
@Mapping(target = "rows", source = "pageSize") @Mapping(target = "rows", source = "pageSize")
@Mapping(target = "debugQuery", source = "debugQuery") @Mapping(target = "debugQuery", source = "debugQuery")
@Mapping(target = "sort", expression = "java( eu.openaire.api.mappers.Utils.formatSortByParam(src.getSortBy(), sortFieldMapping) )") @Mapping(target = "sort", expression = "java( eu.openaire.api.mappers.Utils.formatSortByParam(src.getSortBy(), SolrFieldsMapper.projectSortMapping) )")
SolrQueryParams toSolrQuery(ProjectRequest src); SolrQueryParams toSolrQuery(ProjectRequest src);
@Named("calculateStart") @Named("calculateStart")
@ -32,31 +26,7 @@ public interface ProjectRequestMapper {
@AfterMapping @AfterMapping
default void paramsCustomMapping(ProjectRequest src, @MappingTarget SolrQueryParams solrQueryParams) { default void paramsCustomMapping(ProjectRequest src, @MappingTarget SolrQueryParams solrQueryParams) {
final Map<String, String> solrFieldMapping = Map.ofEntries( final Map<String, String> solrFieldMapping = SolrFieldsMapper.projectFieldMapping;
// search field mapping
Map.entry("search", "__all:(%s)"),
Map.entry("title", "projecttitle:(%s)"),
Map.entry("keywords", "projectkeywords:(%s)"),
// filter query field mapping
Map.entry("id", "__indexrecordidentifier:(%s)"),
Map.entry("code", "projectcode_nt:(%s)"),
Map.entry("acronym", "projectacronym:(%s)"),
Map.entry("fundingShortName", "fundershortname:(%s)"),
Map.entry("fundingStreamId", "fundinglevel0_name:(%s) OR fundinglevel1_name:(%s) OR fundinglevel2_name:(%s)"),
Map.entry("callIdentifier", "projectcallidentifier:(%s)"),
Map.entry("startDate", "projectstartdate:[%s TO %s]"),
Map.entry("endDate", "projectenddate:[%s TO %s]"),
// filter by related entity fields
Map.entry("relCommunityId", "communityid:(%s)"),
Map.entry("relOrganizationCountryCode", "relorganizationcountryid:(%s)"),
Map.entry("relOrganizationName", "relorganizationname: (%s) or relorganizationshortname: (%s)"),
Map.entry("relOrganizationId", "relorganizationid:(%s)"),
Map.entry("relCollectedFromDatasourceId", "collectedfromdatasourceid:(%s)")
);
var qList = new ArrayList<String>(); var qList = new ArrayList<String>();
@ -93,7 +63,7 @@ public interface ProjectRequestMapper {
} }
if (!Utils.isNullOrEmpty(src.getAcronym())) { if (!Utils.isNullOrEmpty(src.getAcronym())) {
fqList.add(String.format(solrFieldMapping.get("acronym"), Utils.escapeAndJoin(src.getAcronym(), "OR", false))); fqList.add(String.format(solrFieldMapping.get("acronym"), Utils.escapeAndJoin(src.getAcronym(), "OR", true)));
} }
if (!Utils.isNullOrEmpty(src.getFundingShortName())) { if (!Utils.isNullOrEmpty(src.getFundingShortName())) {
@ -101,12 +71,12 @@ public interface ProjectRequestMapper {
} }
if (!Utils.isNullOrEmpty(src.getFundingStreamId())) { if (!Utils.isNullOrEmpty(src.getFundingStreamId())) {
String fundingStreamId = Utils.escapeAndJoin(src.getFundingStreamId(), "OR", false); String fundingStreamId = Utils.escapeAndJoin(src.getFundingStreamId(), "OR", true);
fqList.add(String.format(solrFieldMapping.get("fundingStreamId"), fundingStreamId, fundingStreamId, fundingStreamId)); fqList.add(String.format(solrFieldMapping.get("fundingStreamId"), fundingStreamId, fundingStreamId, fundingStreamId));
} }
if (!Utils.isNullOrEmpty(src.getCallIdentifier())) { if (!Utils.isNullOrEmpty(src.getCallIdentifier())) {
fqList.add(String.format(solrFieldMapping.get("callIdentifier"), Utils.escapeAndJoin(src.getCallIdentifier(), "OR", false))); fqList.add(String.format(solrFieldMapping.get("callIdentifier"), Utils.escapeAndJoin(src.getCallIdentifier(), "OR", true)));
} }
// related entity fields // related entity fields

View File

@ -5,7 +5,7 @@ import java.util.Map;
public class SolrFieldsMapper { public class SolrFieldsMapper {
// mappings for the organization entity // mappings for the organization entity
public static final Map<String, String> organizationFieldsMapping = Map.ofEntries( public static final Map<String, String> organizationFieldsMapping = java.util.Map.ofEntries(
// search field mapping // search field mapping
Map.entry("search", "__all:(%s)"), Map.entry("search", "__all:(%s)"),
Map.entry("legalName", "organizationlegalname:(%s)"), Map.entry("legalName", "organizationlegalname:(%s)"),
@ -50,4 +50,38 @@ public class SolrFieldsMapper {
Map.entry("relevance", "score") Map.entry("relevance", "score")
); );
// mappings for the project entity
public static final Map<String, String> projectFieldMapping = Map.ofEntries(
// search field mapping
Map.entry("search", "__all:(%s)"),
Map.entry("title", "projecttitle:(%s)"),
Map.entry("keywords", "projectkeywords:(%s)"),
// filter query field mapping
Map.entry("id", "__indexrecordidentifier:(%s)"),
Map.entry("code", "projectcode_nt:(%s)"),
Map.entry("acronym", "projectacronym:(%s)"),
Map.entry("fundingShortName", "fundershortname:(%s)"),
Map.entry("fundingStreamId", "fundinglevel0_name:(%s) OR fundinglevel1_name:(%s) OR fundinglevel2_name:(%s)"),
Map.entry("callIdentifier", "projectcallidentifier:(%s)"),
Map.entry("startDate", "projectstartdate:[%s TO %s]"),
Map.entry("endDate", "projectenddate:[%s TO %s]"),
// filter by related entity fields
Map.entry("relCommunityId", "communityid:(%s)"),
Map.entry("relOrganizationCountryCode", "relorganizationcountryid:(%s)"),
Map.entry("relOrganizationName", "relorganizationname: (%s) OR relorganizationshortname: (%s)"),
Map.entry("relOrganizationId", "relorganizationid:(%s)"),
Map.entry("relCollectedFromDatasourceId", "collectedfromdatasourceid:(%s)")
);
public static final Map<String, String> projectSortMapping = Map.ofEntries(
Map.entry("relevance", "score"),
Map.entry("startDate", "projectstartyear"),
Map.entry("endDate", "projectendyear")
);
} }