| Oracle® WebCenter Framework Developer's Guide 10g (10.1.3.2.0) Part Number B31074-05 | 
 | 
| 
 | View PDF | 
In WebCenter applications, it may often be useful to provide users with the capacity to search some data or portion of the data presented to them on a page. To achieve this type of functionality, you can use a Web Service data control to call the searching function of Oracle Secure Enterprise Search.
This chapter explains how to integrate search into your WebCenter applications.
For more information, see the Oracle Secure Enterprise Search documentation that comes with the product.
To build a data control that uses Oracle Secure Enterprise Search, perform the following steps:
If you have not already done so, you must install Oracle Secure Enterprise Search by referring to the installation guide for your platform.
If you have not already done so, create an application and a project.
Right-click the project where want to incorporate searching and choose New from the context menu.
Expand Business Tier and select Web Services. If you do not see Web Services, then choose All Technologies from the Filter By list.
In the Items list, choose Web Service Data Control and click OK.
If the Welcome page of the Web Service Data Control Wizard appears, then click Next.
Enter a name for the data control.
Enter a Web Services Description Language (WSDL) URL. The WSDL URL for Oracle Secure Enterprise Search is of the form:
http://host:port/search/query/OracleSearch?WSDL
Note:
When Oracle Secure Enterprise Search is installed, the endpoint listed in the WSDL points to a placeholder location. Once the data control is created, you must correct the endpoint URL using the Structure pane. This step will be described later in this procedure.Click Services. The wizard page should now look similar to Figure 8-1.
Figure 8-1 Data Source Page of Web Service Data Control Wizard

Click Next.
From the Data Control Operations page, you choose which methods you want to expose by moving them from the Available list to the Selected list. For the purposes of this example, move doOracleSimpleSearch to the Selected list. When you are done, the page should look similar to Figure 8-2.
Figure 8-2 Data Control Operations Page of Web Service Data Control Wizard

For the purposes of this example, you can now click Finish. If you want to review the other pages of the wizard first, then click Next until you reach the end of the wizard and then click Finish.
In the Application Navigator, expand Application Sources and then project_name.
Click DataControls.dcx and its structure will appear in the Structure pane below the Application Navigator.
Right-click your data control in the Structure pane and choose Edt Web Service Connection from the context menu.
The Edit Web Service Connection dialog appears as shown in Figure 8-3. As noted earlier, the endpoint listed in the WSDL points to a placeholder location. You must now correct the endpoint URL.
Figure 8-3 Edit Web Service Connection Dialog

Click OK.
Now you can create a page on which to drop your new data control. Right-click your project and choose New from the context menu.
Under Web Tier, choose JSF. Under Items, choose JSF JSP.
Click OK.
Proceed through the JSF JSP wizard accepting the default settings for everything except File Name. Choose a meaningful file name.
Click Finish when ready.
Once your JSF JSP appears in the editor, click the Data Control tab to bring up the Data Control Palette. You should see your data control displayed in the Data Control Palette. If not, then the previous steps must not have completed successfully or perhaps you are in the wrong application.
Expand the top level node of your data control and then expand Return and Return. You can now see all of the data that is returned by the data control.
For the purposes of this example, drag and drop resultElements onto your page.
Select Tables, ADF Read-only Table from the context menu that appears. The Action Binding Editor appears.
For the sake of simplicity, you can hard code the values for each parameter as shown in Table 8-1.
When you are done, the dialog should look like Figure 8-4. Click OK.
Click OK.
The Edit Table Columns dialog appears. Select lastModified and click Delete (Figure 8-5).
Click OK.
You must now remove the lastModified column from the page definition as well. Right-click your page in the Structure pane and choose Go To Page Definition from the context menu.
Find <Item Value="lastModified"/> and delete it.
Now you can run your page. Right-click the page in the Application Navigator and choose Run from the context menu.
Browse through your output and notice how occurrences of the word oracle are surrounded by <b></b> tags. Figure 8-6 shows a small sample fragment of this output. Currently, the search hits are not formatted because you have not yet converted the view component that renders this column to OutputFormatted.
Figure 8-6 Sample of Searched Output, Hits Unformatted

Back in Oracle JDeveloper, return to your JSP by clicking its tab in the editor.
In the Structure pane, find and expand one of the columns that contains oracle, for example, the description column.
Right-click af:outputText - #{row.snippet} for that column and choose Convert from the context menu. The Convert dialog appears.
Select OutputFormatted and click OK.
If the Confirm Convert dialog appears, then click OK again.
Run the page again to see the changes. You should now see output similar to that in Figure 8-7. Notice how the <b></b> around the word oracle is now interpreted so that search hits appear in bold.
Figure 8-7 Sample of Searched Output, Hits Formatted

Using the Structure pane, delete the extraneous columns of your table. When you are done, you should only have row.author, row.title, row.snippet, row.score, and row.language left.
Repeat steps 35 through 40 for each of the columns that remains on your page.
Run the page again. Note how you see automatic pagination in the upper right corner of the table. The reason for this behavior is that the default number of rows for an Oracle ADF table is 10, but you chose to return 20 results. To enhance the page further, you will provide an estimated count.
From the Data Control Palette, drag and drop estimatedHitCount onto the page. Select Texts, ADF Output Text w/ Label from the context menu.
Another useful feature for this table would be a link to open the document. You can achieve this by dragging a GoLink from under ADF Faces Core in the Component Palette and dropping it right in front of outputFormatted of the title column. Note that you can perform this step a little more accurately in the Structure pane.In the Property Inspector, change the Text attribute to Open.
Right-click the af:goLink - Open in the Structure pane and choose Properties from the context menu.
Click the Bind button next to Destination.
In the Bind to Data dialog, expand the row node under JSP Objects and find the url row and add it to the Expression. Click OK.
Click OK.
Click the Source tab. You should see something similar to the following in the source for your page:
<af:goLink text="Open" destination="#{row.url}"/>
Run the page again. Confirm that the Open link and the estimatedHitCount are present and working properly.
The last feature to add is an input box and a submit button to enable users to perform their own custom searches. Click the Design tab.
Return to the Data Control Palette and expand the first Parameters node under your data control.
Drag query and drop it just above the left corner of your table. Choose Texts, ADF Input Text w/ Label from the context menu.
Drag doOracleSimpleSearch from the Data Control Palette and drop it just below the parameter input box you just created. Choose Methods, ADF Command Button from the context menu.
To avoid getting an error when someone first runs the page, you must set a default value for the query parameter. Go to the page definition, PageDef.xml.
In the Structure pane, expand variables under executables and select doOracleSimpleSearch_query.
In the Property Inspector, select the DefaultValue property and enter a default search, for example, oracle.
Run the page. Enter a different search term in the box and click the button you just created. The results should change.
Note:
Because you previously limited the number of results returned, the hit count you added at the bottom of the page is now artificially limited. To fix this problem and get an accurate hit count, find the following line in yourPageDef.xml file:
<NamedData NDName="returnCount" NDValue="false" NDType="java.lang.Boolean"/>
and change it to:
<NamedData NDName="returnCount" NDValue="true"
   NDType="java.lang.Boolean"/>