Overview
Use the following configuration settings to specify aggregation pipelines for change streams and read preferences for change stream cursors when working with the MongoDB Kafka source connector.
For a list of source connector configuration settings organized by category, see the guide on Source Connector Configuration Properties.
Settings
| Name | Description | |
|---|---|---|
| pipeline | Type: string Description: An array of aggregation pipelines to run in your change stream.
You must configure this setting for the change stream
event document, not the  fullDocumentfield.For example: For more examples, see: Default:  "[]"Accepted Values: Valid aggregation pipeline stage | |
| change.stream.full.document | Type: string Description: Determines what values your change stream returns on update
operations. The default setting returns the differences between the original
document and the updated document. The  updateLookupsetting returns the differences between the
original document and updated document as well as a copy of the
entire updated document at a point in time after the update.The  whenAvailablesetting returns the updated document,
if available.The  requiredsetting returns the updated document and
raises an error if it is not available.For more information on how this change stream option works, see
Lookup Full Document for Update Operations
in the MongoDB manual. Default:  ""Accepted Values:  "","updateLookup","whenAvailable", or"required" | |
| change.stream.show.expanded.events | Type: boolean Description: Determines if change streams notifies for DDL events such as createIndexes and events. To learn more, see showExpandedEvents. This setting is required to show updateDescription.disambiguatedPathsin update events, whichclarifies changes that involve ambiguous fields. To learn more, see disambiguatedPaths. Default:  falseAccepted Values:  trueorfalse | |
| change.stream.full.document.before.change | Type: string Description: Configures the document pre-image your change stream returns on update
operations. The pre-image is not available for source records
published while copying existing data, and the pre-image configuration
has no effect on copying. To learn how to configure a collection to enable
pre-images, see Change Streams with Document Pre- and Post-Images in the MongoDB manual. The default setting suppresses the document pre-image. The  whenAvailablesetting returns the document pre-image if
it's available, before it was replaced, updated, or
deleted.The  requiredsetting returns the document pre-image and
raises an error if it is not available.Default:  ""Accepted Values:  ""or"whenAvailable"or"required" | |
| publish.full.document.only | Type: boolean Description: Whether to return only the  fullDocumentfield from the
change stream event document produced by any update event. ThefullDocumentfield contains the most current version of the
updated document. To learn more about thefullDocumentfield, see the update Event in the Server manual.When set to  true, the connector overrides thechange.stream.full.documentsetting and sets it toupdateLookupso that thefullDocumentfield contains
updated documents.Default:  falseAccepted Values:  trueorfalse | |
| publish.full.document.only.tombstone.on.delete | Type: boolean Description: Whether to return tombstone events when documents are deleted.
Tombstone events contain the keys of deleted documents with
 nullvalues. This setting applies only whenpublish.full.document.onlyistrue.Default:  falseAccepted Values:  trueorfalse | |
| change.stream.document.key.as.key | Type: boolean Description: Whether to use the document key for the source record key if
the document key is present. When set to  true, the connector adds keys of the deleted
documents to the tombstone events. When set tofalse,
the connector uses the resume token as the source key for
the tombstone events.Default:  trueAccepted Values:  trueorfalse | |
| collation | Type: string Description: A JSON collation document
that specifies language-specific ordering rules that MongoDB
applies to the documents returned by the change stream. Default:  ""Accepted Values: A valid collation JSON document | |
| batch.size | Type: int Description: The change stream cursor batch size. Default:  0Accepted Values: An integer | |
| poll.await.time.ms | Type: long Description: The maximum amount of time in milliseconds that the server waits for new
data changes to report to the change stream cursor before returning an
empty batch. Default:  5000Accepted Values: An integer | |
| poll.max.batch.size | Type: int Description: Maximum number of documents to read in a single batch when polling
a change stream cursor for new data. You can use this setting to
limit the amount of data buffered internally in the connector. Default:  1000Accepted Values: An integer |