In the 5.2.1 release, the bundled JVM for the crawler plug-in and customer connector features will be transitioned to IBM Semeru Runtimes, Version 21. If your crawler plug-in or custom connectors used in version 5.2.0 or earlier utilize any features that are incompatible between IBM SDK, Java Technology Edition, Version 8 and IBM Semeru Runtimes, Version 21, you need to revise your code to ensure compatibility with future releases, and re-deploy the built package for version 5.2.1.
For JVM migration, see the following pages:
- https://www.ibm.com/support/pages/semeru-runtimes-migration-guide
- https://www.ibm.com/support/pages/semeru-runtimes-security-migration-guide
Building a custom connector
Discovery provides connectors to many popular data sources, as described in Configuring Cloud Pak for Data data sources. If you need to connect to a different data source, you can write and deploy a custom connector.
IBM Cloud Pak for Data IBM Software Hub
This information applies only to installed deployments.
Any custom code that is used with IBM Watson® Discovery is the responsibility of the developer and is not covered by IBM support.
Example code and configuration files for a basic custom connector are included.
Related topics:
- Developing custom Cloud Pak for Data connector code
- Assembling, compiling, and packaging a custom Cloud Pak for Data connector
- Installing and uninstalling a custom Cloud Pak for Data connector
- Using a custom Cloud Pak for Data connector from the Discovery user interface
Custom connector requirements
A custom connector is a component that uses the SDK and crawler framework that is documented here to connect to and crawl a specific data source. Custom connectors have the same general requirements as provided connectors. For more information, see Data source requirements.
Before you implement a custom connector, you need to know the following information about the data source:
- The data source's network location (server name or address, including port, or URL, including port)
- The data source's authentication method and security credentials
- The path or paths on the data source that the connector needs to crawl
- The connection method or protocol that the data source supports
Designing a custom connector
A custom connector needs the following capabilities:
- 
              Configuring a crawler. - Configuring all settings that are required to connect to the data source.
- Discovering a crawl space on the data source. At least one crawl space is required.
 
- 
              Crawling documents. - Crawling the documents on each data set.
- Adding Access Control List (ACL) information to each document.
 
- 
              Retrieving ACL information for the username that authenticates to the data source. 
These capabilities can be implemented by using the interfaces and methods that are described in Developing custom connector code.
Custom connector limitations
Observe the following notes and warnings when you implement a custom connector.
- 
              Custom connectors do not support the following features: - Synchronization settings
- Filtering documents based on user access at query time. (At crawl and index time, only documents that the current user has the right to access are returned.)
- The requiredandhiddenvalidation settings. They are ignored when the connector is displayed in Discovery
- The use of <condition />tags in the definition file. These tags are currently ignored.
 
- 
              When you use the example connector code in the current release, Discovery does not collapse and group authentication settings for the custom connector's properties. For example, even when the {connector_name}_DATASOURCE_SETTINGS_USE_KEY_LABELtoggle is set toOff, the user interface shows the fields for{connector_name}_DATASOURCE_SETTINGS_KEY_LABELand{connector_name}_DATATSOURCE_SETTINGS_PASSPHRASE_LABEL.
- 
              The listparameter type is not supported.
- 
              If a custom connector fails to connect to its source for any reason, it issues a generic error message such as Failed to create connectororTimed out, or a500HTTP error. Specific failure information is not currently provided.See the Release notes for more possible issues.