Option¶
Additional parameters that are passed to MongoDB operations.
Options are usually configured with the options = {} optional parameter in a command. For example, if we want to know how many notifications a user has, but can only display "99" because of UI size constraints, we can use the following command:
If the same option is specified multiple times, only the very last one applies:
will only count at most 10 elements.
Accessing the current value of an option¶
See Options.allOptions and option.
Implementing this interface¶
Implementations of this interface must be careful to respect the contract of BsonNode, in particular about the toString representation.
Option implementations must be immutable. If the user wants to change an option, they can specify it a second time (which will override the previous one).
Inheritors¶
Properties¶
context¶
@LowLevelApi
abstract val context: BsonContext
The context used to generate this expression.
name¶
The name of this option, as it appears in the BSON representation.
Options always have the form:
In this example, the LimitOption has the name "limit" and the SortOption has the name "sort".
Implementation notes
This value should be immutable.
Functions¶
freeze¶
@LowLevelApi
abstract override fun freeze()
Makes this expression immutable.
read¶
Reads the value of this option.
Performance
Note that this method requires to write this option into a temporary BSON value.
simplify¶
@LowLevelApi
abstract fun simplify(): BsonNode?
Returns a simplified (but equivalent) expression to the current expression.
toBson¶
@LowLevelApi
open fun toBson(): BsonDocument
Writes the result of simplifying to a new BsonDocument.
toString¶
writeTo¶
@LowLevelApi
abstract override fun writeTo(writer: BsonFieldWriter)
Writes the result of simplifying this expression into writer.