This sample shows some of the capabilities of Acoustic Content (formerly Watson Content Hub or WCH) search services. This is a technical sample intended for developers exploring the Acoustic Content APIs and data model.
This other sample has more options are should be used in most cases: https://github.com/acoustic-content-samples/sample-delivery-search-api
This sample illustrates:
- Using the Delivery and Authoring search APIs and some of the powerful filtering capabilities.
- Calling the authenticated search API both from client JavaScript and from Node.js.
- Using the document data that is optionally returned as part of the search results.
- A simple Node.js Express server that does the search as a "proxied" request. This way of accessing the WCH doesn't require the CORS enablement that's required for browser JS calls to WCH.
There is a client-side sample using browser based JavaScript and a server-side implementations, using Node.js in a simple Express server. Both implementations are available as reusable functions. The client JavaScript version is in public/delivery-search.js and public/authoring-search.js. The Node.js implmentation is in lib/search.js.
The WCH search service is built on the powerful SOLR search engine, and the search parameters offer a great number of useful features for searching and controlling the returned search results. In this sample you can select from a list of example search queries to try them out and to see the search parameters that are used. You can also edit the search parameters input to try your own search queries. The search results table displays some of the common fields you can use. At the top you can see how many rows were found. This is often different than the number of result entries, which is controlled with the "rows" parameter.
Here is a screenshot showing a search for all the content items of type Article:
You can click on the "JSON" button for any entry to see the complete JSON. You can also click on the "Document JSON" button to see the parsed contents of the "document" field that can optionally be returned with search results. See below for more information on the document field and on controlling which fields are returned in your results.
The example queries in the drop-down list show a number of useful queries, shown in this screenshot.
General documentation for SOLR queries can be found at https://lucene.apache.org/solr/guide/6_6/searching.html
One of the parameters for search is the "fl" parameter for selecting which fields are returned for each entry. In the sample, most of the example queries use the following list of fields: &fl=name,document,id,classification,type,status
The "document" field includes the complete referenced document, for example the complete content item or the complete asset JSON. By default it is returned as single string that you would need to parse as JSON. You can also add the ":[json]" option to have the document field automatically parsed as JSON, as in this example: &fl=name,document:[json]
Here are some of the parameters used in the example queries:
-
q specifies the search term (query) in field:value format, for example q=*:* specifies a wildcard query matching all fields and values
-
fl selects the set of fields to include in the results, for example &fl=name,document:[json] or &fl=* (all fields)
-
rows specifies how many result entries to return, for example rows=20 (default == 10)
-
start specifies the starting entry number to return, for example start=20 (default == 0)
-
sort specifies a field to sort on, with asc or desc for ascending/descending, for example sort=lastModified%20desc
-
fq (filter queries) further restrict the superset of query results returned from the primary query as described here: https://lucene.apache.org/solr/guide/6_6/common-query-parameters.html#CommonQueryParameters-Thefq_FilterQuery_Parameter
-
fq=classification: selects what kind(s) of artifacts to search for (eg, asset, type, content), for example to search for assets only, use fq=classification:asset
-
fq=type: searches for an item using a particular content type, for example fq=type:Article
-
fq=status: searches for artifacts matching draft/ready/retired status, for example fq=status:draft
-
fq=tags: searches for one or more tags, for example fq=tags:(beach OR summer)
-
fq=categoryLeaves: searches for category values, for example fq=categoryLeaves:(travel OR auto)
-
fq=classification:(category)&fq=path:(\/Sample\ Article\/*) search for categories under a taxonomy named "Sample Article"
The delivery search example shows how to search for content by the value of a particular element. The examples show searching for Products by a ProductId and searching for Events by the event date. In order for the Product examples to show results, a "Product" content type needs to exist in the target tenancy, containing an element named "ProductId" that is configured to have a search key of "string1". In order for the Event example to show results, an "Event" content type needs to exist in the target tenancy, containing an element named "EventDate" that is configured to have a search key of "sortableDate1". A video showing these steps in more detail is here: https://youtu.be/j0WdgTvJX7Y
To search for categories under a given taxonomy, you can use a path query with wildcards. For example, to search for all categories under a "Sample Article" taxonomy, you can use a query like the following (where backslash is used to escape the forward slashes and the space in the path value, and where backslash itself may need to be url encoded as %5C in the actual URL sent to the service):
q=*:*&fl=id,name&fq=classification:(category)&fq=path:(\/Sample\ Article\/*)
See the following Solr documentation for more information on escaping characters in queries: https://lucene.apache.org/solr/guide/6_6/the-standard-query-parser.html#the-standard-query-parser
Some of the queries in this search sample were built specifically for the authoring artifacts available with the sample-article-content package in the following repository: https://github.com/ibm-wch/sample-article-content
Download the project files into any folder on your workstation. Then run
npm install
All of these samples require setting the base tenant API URL. The authoring search samples require authentication and use hard-coded user name, and password values. For the client-side implementation, these are set in the public/delivery-search.js and authoring-search.js files. For the Node.js implementation they are set in main.js. Update the name and password values in those files. To avoid putting credentials in the source you could change the application to provide browser inputs for username and password.
The baseTenantUrl variable must be set for your tenant. In the Acoustic Content user interface, open the "Hub Information" dialog from the "About" flyout menu in the left navigation pane. The pop-up window shows your Watson Content Hub tenant specific "API URL". Use this information to update the value of baseTenantUrl in the above mentioned JS files. For example it might look something like this:
const baseTenantUrl = "https://content-eu-4.content-cms.com/api/12345678-9abc-def0-1234-56789abcdef0";
To use the client JavaScript implementation of this sample you will need to enable CORS support for your tenant. To control the CORS enablement for Watson Content Hub, go to Hub set up -> General settings -> Security tab. After adding your domain (or "*" for any domain), be sure to click the Save button at the top right of the screen.
Run this command
node main.js
- Sample application that uses client JS to call WCH Delivery Search:
http://localhost:3000/delivery-search.html
- Sample application that uses client JS to call WCH Authoring Search:
http://localhost:3000/authoring-search.html
- Sample application that calls WCH search via Node.js:
http://localhost:3000/index-nodejs-search.html
- The Delivery Search API can be called with any search parameters like this:
http://localhost:3000/api/delivery-search?q=*:*&wt=json&sort=name%20desc&rows=1
- The Authoring Search API can be called with any search parameters like this:
http://localhost:3000/api/authoring-search?q=*:*&wt=json&sort=name%20desc&rows=1
Download the application files (html, js, and css) from the 'public' folder into any folder on your workstation.
Update the name, password, and baseTenantUrl values in the app.js file as described above.
See above for how to do this.
You can do this right from the file system in Firefox, Chrome, or Safari browsers.
Acoustic Content developer documentation: https://developer.goacoustic.com/acoustic-content/docs
Acoustic Content API reference documentation: https://developer.goacoustic.com/acoustic-content/reference
Acoustic Content Samples Gallery: https://content-samples.goacoustic.com/