This is an automated email from the ASF dual-hosted git repository.

ilgrosso pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/syncope.git


The following commit(s) were added to refs/heads/master by this push:
     new af0af5a227 Fixing Elasticsearch and OpenSearch ILIKE / IEQ for values 
with underscore
af0af5a227 is described below

commit af0af5a2272ce38c56b0c23a55474d4b4a935912
Author: Francesco Chicchiriccò <[email protected]>
AuthorDate: Tue Mar 5 15:27:42 2024 +0100

    Fixing Elasticsearch and OpenSearch ILIKE / IEQ for values with underscore
---
 .../persistence/elasticsearch/dao/ElasticsearchAnySearchDAO.java     | 5 +++--
 .../core/persistence/opensearch/dao/OpenSearchAnySearchDAO.java      | 5 +++--
 2 files changed, 6 insertions(+), 4 deletions(-)

diff --git 
a/ext/elasticsearch/persistence/src/main/java/org/apache/syncope/core/persistence/elasticsearch/dao/ElasticsearchAnySearchDAO.java
 
b/ext/elasticsearch/persistence/src/main/java/org/apache/syncope/core/persistence/elasticsearch/dao/ElasticsearchAnySearchDAO.java
index 5707c710f5..afbbae98c3 100644
--- 
a/ext/elasticsearch/persistence/src/main/java/org/apache/syncope/core/persistence/elasticsearch/dao/ElasticsearchAnySearchDAO.java
+++ 
b/ext/elasticsearch/persistence/src/main/java/org/apache/syncope/core/persistence/elasticsearch/dao/ElasticsearchAnySearchDAO.java
@@ -531,7 +531,7 @@ public class ElasticsearchAnySearchDAO extends 
AbstractAnySearchDAO {
 
             case ILIKE:
                 StringBuilder output = new StringBuilder();
-                for (char c : 
cond.getExpression().toLowerCase().toCharArray()) {
+                for (char c : 
cond.getExpression().toLowerCase().replace("\\_", "_").toCharArray()) {
                     if (c == '%') {
                         output.append(".*");
                     } else if (Character.isLetter(c)) {
@@ -549,7 +549,8 @@ public class ElasticsearchAnySearchDAO extends 
AbstractAnySearchDAO {
 
             case LIKE:
                 query = new Query.Builder().wildcard(QueryBuilders.wildcard().
-                        
field(schema.getKey()).value(cond.getExpression().replace('%', 
'*')).build()).build();
+                        
field(schema.getKey()).value(cond.getExpression().replace('%', 
'*').replace("\\_", "_")).
+                        build()).build();
                 break;
 
             case IEQ:
diff --git 
a/ext/opensearch/persistence/src/main/java/org/apache/syncope/core/persistence/opensearch/dao/OpenSearchAnySearchDAO.java
 
b/ext/opensearch/persistence/src/main/java/org/apache/syncope/core/persistence/opensearch/dao/OpenSearchAnySearchDAO.java
index 6d4e05c669..37b93ea42a 100644
--- 
a/ext/opensearch/persistence/src/main/java/org/apache/syncope/core/persistence/opensearch/dao/OpenSearchAnySearchDAO.java
+++ 
b/ext/opensearch/persistence/src/main/java/org/apache/syncope/core/persistence/opensearch/dao/OpenSearchAnySearchDAO.java
@@ -530,7 +530,7 @@ public class OpenSearchAnySearchDAO extends 
AbstractAnySearchDAO {
 
             case ILIKE:
                 StringBuilder output = new StringBuilder();
-                for (char c : 
cond.getExpression().toLowerCase().toCharArray()) {
+                for (char c : 
cond.getExpression().toLowerCase().replace("\\_", "_").toCharArray()) {
                     if (c == '%') {
                         output.append(".*");
                     } else if (Character.isLetter(c)) {
@@ -548,7 +548,8 @@ public class OpenSearchAnySearchDAO extends 
AbstractAnySearchDAO {
 
             case LIKE:
                 query = new Query.Builder().wildcard(QueryBuilders.wildcard().
-                        
field(schema.getKey()).value(cond.getExpression().replace('%', 
'*')).build()).build();
+                        
field(schema.getKey()).value(cond.getExpression().replace('%', 
'*').replace("\\_", "_")).
+                        build()).build();
                 break;
 
             case IEQ:

Reply via email to