A client sends a query by calling ICISContentQuery::Search(). Search() executes the query and returns results.
Searching is a synchronous operation by default, with Search() returning only when it has search results, or if the query fails. See also Synchronous Behavior below.
Note: Notifying the client of the query’s acceptance is an integral part of the process, in a similar fashion to the queuing mechanism for indexing. If calling ICISStatusCallback::ReportStatus() fails, then the Query instance should fail to accept the query. This way, it is not possible to have a situation where a query is accepted but the client has not yet received the “queued” status report for it.
This mechanism helps ensure that besides incorrect API usage (an issue at the client) and a minimum of unexpected failures (for example, running out of memory), the start and end of a query is always logged. In other words, the acceptance of a query is the expected behavior, even if it fails almost immediately because of trivia such as an invalid parameter value. You should report any failure reason, such as invalid XML syntax, invalid configuration parameter, connection failure to the content database service, inconsistent or invalid search parameters, and others, through the "completed" status report. This approach maximizes information provided through logging.
The Search() call supplies two separate pieces of data: the query configuration parameters, and the query search parameters. It also supplies the ICISStatusCallback interface pointer that the Query instance uses to send status reports to the client about the query.
The Search() method returns search results (if applicable) in the ppSearchResultsXml output parameter. If the search is asynchronous, results (if applicable) are fed through status reports.
See ICISContentProvider.idl for more behavior details.
A client can cancel ongoing searches by calling ICISContentQuery::CancelSearch().
See ICISContentProvider.idl for more behavior details.
A Content Provider must support searching synchronously. This is the default behavior. Synchronous searching means that a call to ICISContentQuery::Search() returns only when it has search results, or if the query fails.
A Content Provider can also support asynchronous searching. If so, this capability must be indicated in the Query function information element (see the XML schema).
The ICISContentIndexer::Search() method implementation must verify if a client wants to run an asynchronous search, and fail if appropriate (for example, with CIS_E_NOT_SUPPORTED).
See ICISContentProvider.idl for more detail about the expected behavior of asynchronous searching and Search() in particular.
Note: The CA DataMinder 14.0 and 14.1 Content Indexer Server (client) does not currently use synchronous indexing. This may change in future releases.
The Query instance sends status reports for a query by calling the ReportStatus() method on the ICISStatusCallback interface pointer that the Query instance received when the client called ICISContentIndexer::Search().
The Query instance must send status reports when:
The Query instance may send optional status reports when, for example the query is taking too long.
The implementation of the ICISContentQuery interface must be multithreaded.
A client may call methods on an ICISContentQuery interface pointer from multiple threads.
Copyright © 2014 CA.
All rights reserved.
|
|