Class DefaultSearchService
- All Implemented Interfaces:
SearchService
SearchService.- Since:
- v4.0
-
Nested Class Summary
Nested classes/interfaces inherited from interface com.atlassian.jira.bc.issue.search.SearchService
SearchService.IssueSearchParameters, SearchService.ParseResult -
Constructor Summary
ConstructorsConstructorDescriptionDefaultSearchService(SearchHandlerManager searchHandlerManager, JqlQueryParser jqlQueryParser, ValidatorVisitor.ValidatorVisitorFactory validatorVisitorFactory, QueryContextVisitor.QueryContextVisitorFactory queryContextVisitorFactory, JqlStringSupport jqlStringSupport, QueryContextConverter queryContextConverter, QueryCache queryCache, JqlOperandResolver jqlOperandResolver, OrderByValidator orderByValidator, SearchProvider searchProvider, IssueFactory issueFactory, I18nHelper.BeanFactory factory, IndexingFeatures indexingFeatures, IssueDocumentSearchService issueDocumentSearchService) -
Method Summary
Modifier and TypeMethodDescriptionbooleandoesQueryFitFilterForm(ApplicationUser user, Query query) Checks if aQueryis capable of being shown on the simple (GUI-based) issue navigator edit screen.getGeneratedJqlString(Query query) Generates a JQL string representation for the passed query.Returns the URL relative to the app context to represent the specified issue search.getJqlString(Query query) Gets the JQL string representation for the passed query.getQueryContext(ApplicationUser searcher, Query query) Generates a full QueryContext for the specifiedQueryfor the searching user.getQueryString(ApplicationUser user, Query query) Returns the query string to represent the specified SearchQuery.getSearchContext(ApplicationUser searcher, Query query) This produces an old-styleSearchContextbased on the passed in search query and the user that is performing the search.getSimpleQueryContext(ApplicationUser searcher, Query query) Generates a simple QueryContext for the specifiedQueryfor the searching user.parseQuery(ApplicationUser searcher, String query) Parses the query string into a JQLQuery.sanitiseSearchQuery(ApplicationUser searcher, Query query) Returns an equivalentQuerywith all the potential "information leaks" removed, with regards to the specified user.search(ApplicationUser searcher, Query jqlQuery, Query filterQuery, PagerFilter pager) Searches the index and returns issues within the pager's range.search(ApplicationUser searcher, Query query, PagerFilter pager) Search the index, and only return issues that are in the pager's range.longsearchCount(ApplicationUser searcher, Query query) Search the index, and return the count of the issues matching the query.longsearchCount(ApplicationUser searcher, Query query, Long timeout) Search the index, and return the count of the issues matching the query.longsearchCountOverrideSecurity(ApplicationUser searcher, Query query) Return the number of issues matching the provided search criteria, overridding any security constraints.searchOverrideSecurity(ApplicationUser searcher, Query query, PagerFilter pager) Search the index, and only return issues that are in the pager's range while AND'ing the raw lucene query to the generated query from the provided searchQuery, not taking into account any security constraints.streamSearch(ApplicationUser searcher, Query query) Search the index, and only return the matched issues as a stream, which is memory efficient for a large number of issues.validateQuery(ApplicationUser searcher, Query query) Validates the specifiedQueryfor passed user.validateQuery(ApplicationUser searcher, Query query, Long searchRequestId) Validates the specifiedQueryfor passed user and search request.
-
Constructor Details
-
DefaultSearchService
public DefaultSearchService(SearchHandlerManager searchHandlerManager, JqlQueryParser jqlQueryParser, ValidatorVisitor.ValidatorVisitorFactory validatorVisitorFactory, QueryContextVisitor.QueryContextVisitorFactory queryContextVisitorFactory, JqlStringSupport jqlStringSupport, QueryContextConverter queryContextConverter, QueryCache queryCache, JqlOperandResolver jqlOperandResolver, OrderByValidator orderByValidator, SearchProvider searchProvider, IssueFactory issueFactory, I18nHelper.BeanFactory factory, IndexingFeatures indexingFeatures, IssueDocumentSearchService issueDocumentSearchService)
-
-
Method Details
-
doesQueryFitFilterForm
Description copied from interface:SearchServiceChecks if aQueryis capable of being shown on the simple (GUI-based) issue navigator edit screen.- Specified by:
doesQueryFitFilterFormin interfaceSearchService- Parameters:
user- the user who is executing the query.query- the Query which to check that is displayable on the simple (GUI-based) issue navigator edit screen. Does not accept null.- Returns:
- true if the query is displayable on the simple (GUI-based) issue navigator edit screen, false otherwise.
-
search
public SearchResults<Issue> search(ApplicationUser searcher, Query query, PagerFilter pager) throws SearchException Description copied from interface:SearchServiceSearch the index, and only return issues that are in the pager's range.Note: that this method returns read only
Issueobjects, and should not be used where you need the issue for update.- Specified by:
searchin interfaceSearchService- Parameters:
searcher- the user performing the search, which will be used to create a permission filter that filters out any of the results the user is not able to see and will be used to provide context for the search.query- contains the information required to perform the search.pager- Pager filter (usePagerFilter.getUnlimitedFilter()to get all issues).- Returns:
- A
SearchResultscontaining the resulting issues. - Throws:
SearchException- thrown if there is a severe problem encountered with lucene when searching (wraps an IOException).
-
search
public SearchResults<Issue> search(ApplicationUser searcher, Query jqlQuery, Query filterQuery, PagerFilter pager) throws SearchException Description copied from interface:SearchServiceSearches the index and returns issues within the pager's range. Allows adding a filter query (filterQuery) to merge with the JQL query (jqlQuery).Note that this method returns read only
Issueobjects, and should not be used where you need the issue for update.- Specified by:
searchin interfaceSearchService- Parameters:
searcher- the user performing the search, providing context for the search.jqlQuery- the JQL query to search with.filterQuery- an additional search query to combine with the generated query from the providedjqlQuery.pager- the pager filter (usePagerFilter.getUnlimitedFilter()to retrieve all issues).- Returns:
- A
SearchResultscontaining the resulting issues. - Throws:
SearchException- if a severe problem is encountered during the search (wraps an IOException).
-
streamSearch
public SearchStreamResults<Issue> streamSearch(ApplicationUser searcher, Query query) throws SearchException Description copied from interface:SearchServiceSearch the index, and only return the matched issues as a stream, which is memory efficient for a large number of issues.Note: that this method returns read only
Issueobjects, and should not be used where you need the issue for update.- Specified by:
streamSearchin interfaceSearchService- Parameters:
searcher- the user performing the search, which will be used to create a permission filter that filters out any of the results the user is not able to see and will be used to provide context for the search.query- contains the information required to perform the search.- Returns:
- A
SearchStreamResultscontaining the stream of resulting issues. - Throws:
SearchException- thrown if there is a severe problem encountered when searching (wraps an IOException).
-
searchOverrideSecurity
public SearchResults<Issue> searchOverrideSecurity(ApplicationUser searcher, Query query, PagerFilter pager) throws SearchException Description copied from interface:SearchServiceSearch the index, and only return issues that are in the pager's range while AND'ing the raw lucene query to the generated query from the provided searchQuery, not taking into account any security constraints.As the method name implies, it bypasses the security restrictions that would normally be applied when performing a search. As such, it should only be used for administrative tasks where you really need to know about ALL affected issues.
Note that this method returns read only
Issueobjects, and should not be used where you need the issue for update. Also note that if you are only after the number of search results useSearchService.searchCount(ApplicationUser, Query)as it provides better performance.- Specified by:
searchOverrideSecurityin interfaceSearchService- Parameters:
searcher- the user performing the search which will be used to provide context for the search.query- contains the information required to perform the search.pager- Pager filter (usePagerFilter.getUnlimitedFilter()to get all issues).- Returns:
- A
SearchResultscontaining the resulting issues. - Throws:
SearchException- thrown if there is a severe problem encountered with lucene when searching (wraps an IOException).ClauseTooComplexSearchException- if the query or part of the query produces lucene that is too complex to be processed.
-
searchCount
Description copied from interface:SearchServiceSearch the index, and return the count of the issues matching the query.- Specified by:
searchCountin interfaceSearchService- Parameters:
searcher- the user performing the search, which will be used to create a permission filter that filters out any of the results the user is not able to see and will be used to provide context for the search.query- contains the information required to perform the search.- Returns:
- the number of issues matching the query
- Throws:
SearchException- thrown if there is a severe problem encountered with lucene when searching (wraps an IOException).
-
searchCount
Description copied from interface:SearchServiceSearch the index, and return the count of the issues matching the query.- Specified by:
searchCountin interfaceSearchService- Parameters:
searcher- the user performing the search, which will be used to create a permission filter that filters out any of the results the user is not able to see and will be used to provide context for the searchquery- contains the information required to perform the search.timeout- timeout in milliseconds- Returns:
- the number of issues matching the query
- Throws:
SearchException- thrown if there is a severe problem encountered with lucene when searching (wraps an IOException).
-
searchCountOverrideSecurity
public long searchCountOverrideSecurity(ApplicationUser searcher, Query query) throws SearchException Description copied from interface:SearchServiceReturn the number of issues matching the provided search criteria, overridding any security constraints.As the method name implies, it bypasses the security restrictions that would normally be applied when performing a search. As such, it should only be used for administrative tasks where you really need to know about ALL affected issues.
Note: Searching for the count avoids loading the issue data into memory, so this should be preferred when the count is all you need to know.
- Specified by:
searchCountOverrideSecurityin interfaceSearchService- Parameters:
searcher- the user performing the search which will be used to provide context for the search.query- contains the information required to perform the search.- Returns:
- number of matching results.
- Throws:
SearchException- thrown if there is a severe problem encountered with lucene when searching (wraps an IOException).ClauseTooComplexSearchException- if the query or part of the query produces lucene that is too complex to be processed.
-
getSearchContext
Description copied from interface:SearchServiceThis produces an old-styleSearchContextbased on the passed in search query and the user that is performing the search.This will only make sense if the query returns true for
SearchService.doesQueryFitFilterForm(ApplicationUser, Query)since SearchContext is only relevant for simple queries.The more acurate context can be gotten by calling
SearchService.getQueryContext(ApplicationUser, Query).If the query will not fit in the simple issue navigator then the generated SearchContext will be empty. This method never returns a null SearchContext, even when passed a null SearchQuery.
- Specified by:
getSearchContextin interfaceSearchService- Parameters:
searcher- the user performing the search, not always the SearchRequest's ownerquery- the query for which you want a context- Returns:
- a SearchContext with the correct project/issue types if the query fits in the issue navigator, otherwise an empty SearchContext. Never null.
-
getQueryString
Description copied from interface:SearchServiceReturns the query string to represent the specified SearchQuery.The query string is prepended with "
&jqlQuery=" so that it is ready for use in building a URL.- Specified by:
getQueryStringin interfaceSearchService- Parameters:
user- the user performing the searchquery- the SearchQuery to generate the query string of. Does not accept null.- Returns:
- a String which represents the query string of a SearchQuery (ie no context/base applied). Never null.
-
getIssueSearchPath
Description copied from interface:SearchServiceReturns the URL relative to the app context to represent the specified issue search.The URL is composed by the issue search path and provided parameters (e.g. "
&/issues/?jql=...&filter=..."), but does NOT include the context path.- Specified by:
getIssueSearchPathin interfaceSearchService- Parameters:
user- the user performing the searchparams- the parameters to generate the URL. Possible parameters are filter Id and query (JQL), both are optional but you cannot use both at the same time. Does not accept null.- Returns:
- a String which represents the issue search URL and query string corresponding to the parameters (no context/base applied). Never null.
-
parseQuery
Description copied from interface:SearchServiceParses the query string into a JQLQuery.- Specified by:
parseQueryin interfaceSearchService- Parameters:
searcher- the user in contextquery- the query to parse into aQuery.- Returns:
- a result set that contains the query and a message set of any errors or warnings that occured during the parse.
-
getQueryContext
Description copied from interface:SearchServiceGenerates a full QueryContext for the specifiedQueryfor the searching user. The full QueryContext contains all explicit and implicitly specified projects and issue types from the Query.For a better explanation of the differences between the full and simple QueryContexts, see
QueryContextVisitorinjira-core.- Specified by:
getQueryContextin interfaceSearchService- Parameters:
searcher- the user performing the searchquery- the search query to generate the context for- Returns:
- a QueryContext that contains the implicit and explicit project / issue types implied by the included clauses in the query.
-
getSimpleQueryContext
Description copied from interface:SearchServiceGenerates a simple QueryContext for the specifiedQueryfor the searching user. The simple QueryContext contains only the explicit projects and issue types specified in the Query. If none were specified, it will be the Global context.For a better explanation of the differences between the full and simple QueryContexts, see
QueryContextVisitorinjira-core.- Specified by:
getSimpleQueryContextin interfaceSearchService- Parameters:
searcher- the user performing the searchquery- the search query to generate the context for- Returns:
- a QueryContext that contains only the explicit project / issue types from the included clauses in the query.
-
validateQuery
Description copied from interface:SearchServiceValidates the specifiedQueryfor passed user. The same as callingvalidateQuery(searcher, query, null);.- Specified by:
validateQueryin interfaceSearchService- Parameters:
searcher- the user performing the searchquery- the search query to validate- Returns:
- a message set containing any errors encountered; never null.
-
validateQuery
@Nonnull public MessageSet validateQuery(ApplicationUser searcher, @Nonnull Query query, Long searchRequestId) Description copied from interface:SearchServiceValidates the specifiedQueryfor passed user and search request. This validates the the passed query as if it was run as the passed search request.- Specified by:
validateQueryin interfaceSearchService- Parameters:
searcher- the user performing the search.query- the search query to validate.searchRequestId- validate in the context of this search request. Can be null to indicate the passed query is not currently a search request.- Returns:
- a message set containing any errors encountered; never null.
-
getJqlString
Description copied from interface:SearchServiceGets the JQL string representation for the passed query. Returns the string fromQuery.getQueryString()if it exists or generates one if it does not. Equilavent to:if (query.getQueryString() != null) return query.getQueryString(); else return getGeneratedJqlString(query);- Specified by:
getJqlStringin interfaceSearchService- Parameters:
query- the query. Cannot be null.- Returns:
- the JQL string represenation of the passed query.
-
getGeneratedJqlString
Description copied from interface:SearchServiceGenerates a JQL string representation for the passed query. The JQL string is always generated, that is,Query.getQueryString()is completely ignored if it exists. The returned JQL is automatically escaped as necessary.- Specified by:
getGeneratedJqlStringin interfaceSearchService- Parameters:
query- the query. Cannot be null.- Returns:
- the generated JQL string representation of the passed query.
-
sanitiseSearchQuery
Description copied from interface:SearchServiceReturns an equivalentQuerywith all the potential "information leaks" removed, with regards to the specified user. For example, if the query contains the clause "project = Invisible", and the specified user does not have browse permission for project "Invisible", the sanitised query will replace this clause with "project = 12345" (where 12345 is the id of the project).- Specified by:
sanitiseSearchQueryin interfaceSearchService- Parameters:
searcher- the user performing the searchquery- the query to sanitise; must not be null.- Returns:
- the sanitised query; never null.
-