Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions api/src/main/kotlin/edu/wgu/osmt/config/Constants.kt
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,4 @@ const val INDEX_RICHSKILL_DOC = "richskill_v1"
const val INDEX_COLLECTION_DOC = "collection_v1"
const val INDEX_JOBCODE_DOC = "jobcode_v1"
const val INDEX_KEYWORD_DOC = "keyword"
const val QUOTED_SEARCH_REGEX_PATTERN = "([\"\'])(?:(?=(\\\\?))\\2.)*?\\1"
8 changes: 4 additions & 4 deletions api/src/main/kotlin/edu/wgu/osmt/richskill/RichSkillEsRepo.kt
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import edu.wgu.osmt.PaginationDefaults
import edu.wgu.osmt.api.model.ApiAdvancedSearch
import edu.wgu.osmt.api.model.ApiSearch
import edu.wgu.osmt.api.model.ApiSimilaritySearch
import edu.wgu.osmt.config.QUOTED_SEARCH_REGEX_PATTERN
import edu.wgu.osmt.db.PublishStatus
import edu.wgu.osmt.elasticsearch.FindsAllByPublishStatus
import edu.wgu.osmt.elasticsearch.OffsetPageable
Expand Down Expand Up @@ -71,13 +72,12 @@ class CustomRichSkillQueriesImpl @Autowired constructor(override val elasticSear
} else {
bq.must(QueryBuilders.matchBoolPrefixQuery(RichSkillDoc::name.name, it))
}

}
category.nullIfEmpty()?.let {
if (it.contains("\"")) {
bq.must(simpleQueryStringQuery(it).field("${RichSkillDoc::category.name}.raw").defaultOperator(Operator.AND))
if (it.matches(Regex(QUOTED_SEARCH_REGEX_PATTERN))) {
bq.must(simpleQueryStringQuery(it).field("${RichSkillDoc::category.name}.keyword").defaultOperator(Operator.AND))
} else {
bq.must(QueryBuilders.matchBoolPrefixQuery(RichSkillDoc::category.name, it))
bq.must(matchBoolPrefixQuery(RichSkillDoc::category.name, it))
}
}
author.nullIfEmpty()?.let {
Expand Down