[OLINGO-1417]OData V4: Adopt search option based on new V4 abnf
This commit is contained in:
parent
9f9aebde55
commit
dfe1dd288c
|
@ -21,6 +21,7 @@ package org.apache.olingo.server.core.uri.parser.search;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <pre>
|
* <pre>
|
||||||
* searchExpr = ( OPEN BWS searchExpr BWS CLOSE / searchTerm )
|
* searchExpr = ( OPEN BWS searchExpr BWS CLOSE / searchTerm )
|
||||||
|
@ -121,7 +122,11 @@ public class SearchTokenizer {
|
||||||
}
|
}
|
||||||
|
|
||||||
static boolean isAllowedWord(final char character) {
|
static boolean isAllowedWord(final char character) {
|
||||||
return Character.isUnicodeIdentifierStart(character);
|
return Character.isUnicodeIdentifierStart(character)
|
||||||
|
|| Character.DASH_PUNCTUATION == Character.getType(character)
|
||||||
|
|| Character.DECIMAL_DIGIT_NUMBER == Character.getType(character)
|
||||||
|
|| (Character.OTHER_PUNCTUATION == Character.getType(character) &&
|
||||||
|
(character != ';' && character != '"'));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -614,6 +619,10 @@ public class SearchTokenizer {
|
||||||
*/
|
*/
|
||||||
public List<SearchQueryToken> tokenize(final String searchQuery) throws SearchTokenizerException {
|
public List<SearchQueryToken> tokenize(final String searchQuery) throws SearchTokenizerException {
|
||||||
|
|
||||||
|
if (searchQuery.contains("%28") || searchQuery.contains("%29") || searchQuery.contains("%22")) {
|
||||||
|
throw new SearchTokenizerException("Invalid Token in Query string '",
|
||||||
|
SearchTokenizerException.MessageKeys.NOT_EXPECTED_TOKEN, searchQuery);
|
||||||
|
}
|
||||||
char[] chars = searchQuery.trim().toCharArray();
|
char[] chars = searchQuery.trim().toCharArray();
|
||||||
|
|
||||||
State state = new SearchExpressionState();
|
State state = new SearchExpressionState();
|
||||||
|
|
|
@ -29,6 +29,7 @@ public class SearchParserAndTokenizerTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void basicParsing() throws Exception {
|
public void basicParsing() throws Exception {
|
||||||
|
assertQuery("99").resultsIn("'99'");
|
||||||
assertQuery("\"99\"").resultsIn("'99'");
|
assertQuery("\"99\"").resultsIn("'99'");
|
||||||
assertQuery("a").resultsIn("'a'");
|
assertQuery("a").resultsIn("'a'");
|
||||||
assertQuery("a AND b").resultsIn("{'a' AND 'b'}");
|
assertQuery("a AND b").resultsIn("{'a' AND 'b'}");
|
||||||
|
@ -83,7 +84,6 @@ public class SearchParserAndTokenizerTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void invalidSearchQuery() throws Exception {
|
public void invalidSearchQuery() throws Exception {
|
||||||
assertQuery("99").resultsIn(SearchParserException.MessageKeys.TOKENIZER_EXCEPTION);
|
|
||||||
assertQuery("NOT").resultsIn(SearchParserException.MessageKeys.INVALID_NOT_OPERAND);
|
assertQuery("NOT").resultsIn(SearchParserException.MessageKeys.INVALID_NOT_OPERAND);
|
||||||
assertQuery("AND").resultsInExpectedTerm(SearchQueryToken.Token.AND.name());
|
assertQuery("AND").resultsInExpectedTerm(SearchQueryToken.Token.AND.name());
|
||||||
assertQuery("OR").resultsInExpectedTerm(SearchQueryToken.Token.OR.name());
|
assertQuery("OR").resultsInExpectedTerm(SearchQueryToken.Token.OR.name());
|
||||||
|
|
|
@ -54,16 +54,20 @@ public class SearchTokenizerTest {
|
||||||
assertQuery("AN").resultsIn(word("AN"));
|
assertQuery("AN").resultsIn(word("AN"));
|
||||||
assertQuery("O").resultsIn(word("O"));
|
assertQuery("O").resultsIn(word("O"));
|
||||||
assertQuery("notAw0rd").resultsIn(word("notAw0rd"));
|
assertQuery("notAw0rd").resultsIn(word("notAw0rd"));
|
||||||
|
assertQuery("1").resultsIn(word("1"));
|
||||||
|
assertQuery("-").resultsIn(word("-"));
|
||||||
|
assertQuery("1.23a").resultsIn(word("1.23a"));
|
||||||
|
assertQuery(",").resultsIn(word(","));
|
||||||
|
assertQuery("*").resultsIn(word("*"));
|
||||||
assertQuery("not,").resultsIn(word("not,"));
|
assertQuery("not,").resultsIn(word("not,"));
|
||||||
assertQuery("not.").resultsIn(word("not."));
|
assertQuery("not.").resultsIn(word("not."));
|
||||||
assertQuery("B-B").resultsIn(word("B-B"));
|
assertQuery("B-B").resultsIn(word("B-B"));
|
||||||
assertQuery("Dž").resultsIn(word("Dž"));
|
assertQuery("Dž").resultsIn(word("Dž"));
|
||||||
// invalid
|
// invalid
|
||||||
assertQuery("%2F").resultsIn(SearchTokenizerException.MessageKeys.FORBIDDEN_CHARACTER);
|
assertQuery(";").resultsIn(SearchTokenizerException.MessageKeys.FORBIDDEN_CHARACTER);
|
||||||
assertQuery("%3A").resultsIn(SearchTokenizerException.MessageKeys.FORBIDDEN_CHARACTER);
|
assertQuery("%28").resultsIn(SearchTokenizerException.MessageKeys.NOT_EXPECTED_TOKEN);
|
||||||
assertQuery("not%5B").resultsIn(SearchTokenizerException.MessageKeys.FORBIDDEN_CHARACTER);
|
assertQuery("%29").resultsIn(SearchTokenizerException.MessageKeys.NOT_EXPECTED_TOKEN);
|
||||||
assertQuery("not%7B").resultsIn(SearchTokenizerException.MessageKeys.FORBIDDEN_CHARACTER);
|
assertQuery("not%22").resultsIn(SearchTokenizerException.MessageKeys.NOT_EXPECTED_TOKEN);
|
||||||
assertQuery("not%6A").resultsIn(SearchTokenizerException.MessageKeys.FORBIDDEN_CHARACTER);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private Validator.Tuple word(final String literal) {
|
private Validator.Tuple word(final String literal) {
|
||||||
|
|
|
@ -89,7 +89,7 @@ public class SearchParserTest {
|
||||||
.isExceptionMessage(SearchParserException.MessageKeys.TOKENIZER_EXCEPTION);
|
.isExceptionMessage(SearchParserException.MessageKeys.TOKENIZER_EXCEPTION);
|
||||||
testUri.runEx("ESTwoKeyNav", "$search=%22a%5Cbc%22")
|
testUri.runEx("ESTwoKeyNav", "$search=%22a%5Cbc%22")
|
||||||
.isExceptionMessage(SearchParserException.MessageKeys.TOKENIZER_EXCEPTION);
|
.isExceptionMessage(SearchParserException.MessageKeys.TOKENIZER_EXCEPTION);
|
||||||
testUri.runEx("ESTwoKeyNav", "$search=not%27allowed")
|
testUri.runEx("ESTwoKeyNav", "$search=not%28allowed")
|
||||||
.isExceptionMessage(SearchParserException.MessageKeys.TOKENIZER_EXCEPTION);
|
.isExceptionMessage(SearchParserException.MessageKeys.TOKENIZER_EXCEPTION);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue