Class BsonUtils
java.lang.Object
org.springframework.data.mongodb.util.BsonUtils
Internal API for operations on 
Bson elements that can be either Document or DBObject.- Since:
- 2.0
- Author:
- Christoph Strobl, Mark Paluch
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final org.bson.DocumentThe empty document (immutable).
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic voidaddAllToMap(org.bson.conversions.Bson target, Map<String, ?> source) Add all entries from the given sourceMapto the target.static voidstatic org.bson.conversions.BsonReturns the given source object asBson, i.e.static Collection<?>asCollection(Object source) Returns given object asCollection.static org.bson.DocumentasDocument(org.bson.conversions.Bson bson) Return theBsonobject asDocument.static org.bson.DocumentasDocument(org.bson.conversions.Bson bson, org.bson.codecs.configuration.CodecRegistry codecRegistry) Return theBsonobject asDocument.asMap(org.bson.conversions.Bson bson) Return theBsonobject asMap.asMap(org.bson.conversions.Bson bson, org.bson.codecs.configuration.CodecRegistry codecRegistry) Return theBsonobject asMap.static org.bson.DocumentasMutableDocument(org.bson.conversions.Bson bson) Return theBsonobject as mutableDocumentcontaining all entries fromBson.static booleanCheck if a given entry (key/value pair) is present in the givenBson.static <T> Tstatic booleanReturns whether the underlyingbsonhas a value (null or non-null) for the givenkey.static booleanstatic booleanisJsonArray(String value) Check if a given String looks likeparsablejson array.static booleanisJsonDocument(String value) Check if a given String looks likeparsablejson.static org.bson.DocumentmapEntries(org.bson.Document source, Function<Map.Entry<String, Object>, String> keyMapper, Function<Map.Entry<String, Object>, Object> valueMapper) static org.bson.DocumentmapValues(org.bson.Document source, BiFunction<String, Object, Object> valueMapper) static org.bson.Documentmerge(org.bson.Document... documents) Merge the givendocumentsinto on in the given order.static org.bson.Documentparse(String json, CodecRegistryProvider codecRegistryProvider) Parse the given json toDocumentapplying transformations as specified by a potentially givenCodec.static booleanremoveNullId(org.bson.conversions.Bson bson) Remove_id : nullfrom the givenBsonif present.static ObjectresolveValue(Map<String, Object> source, String key) Resolve the value for a given key.static ObjectresolveValue(Map<String, Object> source, FieldName fieldName) Resolve the value for a givenfield name.static ObjectresolveValue(org.bson.conversions.Bson bson, String key) Resolve the value for a given key.static ObjectresolveValue(org.bson.conversions.Bson bson, FieldName fieldName) Resolve the value for a givenfield name.static org.bson.BsonValuesimpleToBsonValue(Object source) Convert a given simple value (eg.static org.bson.BsonValuesimpleToBsonValue(Object source, org.bson.codecs.configuration.CodecRegistry codecRegistry) Convert a given simple value (eg.static booleansupportsBson(Object source) Returns the given source can be used/converted asBson.static org.bson.DocumenttoDocumentOrElse(String source, Function<String, org.bson.Document> orElse) static ObjecttoJavaType(org.bson.BsonValue value) Extract the corresponding plain value fromBsonValue.static StringtoJson(org.bson.Document source) Serialize the givenDocumentas Json applying default codecs if necessary.
- 
Field Details- 
EMPTY_DOCUMENTpublic static final org.bson.Document EMPTY_DOCUMENTThe empty document (immutable). This document is serializable.- Since:
- 3.2.5
 
 
- 
- 
Constructor Details- 
BsonUtilspublic BsonUtils()
 
- 
- 
Method Details- 
get
- 
asMapReturn theBsonobject asMap. Depending on the input type, the return value can be either a casted version ofbsonor a converted (detached from the original value).- Parameters:
- bson-
- Returns:
 
- 
asMappublic static Map<String,Object> asMap(@Nullable org.bson.conversions.Bson bson, org.bson.codecs.configuration.CodecRegistry codecRegistry) Return theBsonobject asMap. Depending on the input type, the return value can be either a casted version ofbsonor a converted (detached from the original value) using the givenCodecRegistryto obtaincodecsthat might be required for conversion.- Parameters:
- bson- can be null.
- codecRegistry- must not be null.
- Returns:
- never null. Returns an empty Mapif inputBsonis null.
- Since:
- 4.0
 
- 
asDocumentpublic static org.bson.Document asDocument(org.bson.conversions.Bson bson) Return theBsonobject asDocument. Depending on the input type, the return value can be either a casted version ofbsonor a converted (detached from the original value).- Parameters:
- bson-
- Returns:
- Since:
- 3.2.5
 
- 
asDocumentpublic static org.bson.Document asDocument(org.bson.conversions.Bson bson, org.bson.codecs.configuration.CodecRegistry codecRegistry) Return theBsonobject asDocument. Depending on the input type, the return value can be either a casted version ofbsonor a converted (detached from the original value) using the givenCodecRegistryto obtaincodecsthat might be required for conversion.- Parameters:
- bson-
- codecRegistry- must not be null.
- Returns:
- never null.
- Since:
- 4.0
 
- 
asMutableDocumentpublic static org.bson.Document asMutableDocument(org.bson.conversions.Bson bson) Return theBsonobject as mutableDocumentcontaining all entries fromBson.- Parameters:
- bson-
- Returns:
- a mutable Documentcontaining all entries fromBson.
- Since:
- 3.2.5
 
- 
addToMap
- 
addAllToMapAdd all entries from the given sourceMapto the target.- Parameters:
- target- must not be null.
- source- must not be null.
- Since:
- 3.2
 
- 
containsCheck if a given entry (key/value pair) is present in the givenBson.- Parameters:
- bson- must not be null.
- key- must not be null.
- value- can be null.
- Returns:
- true if (key/value pair) is present.
- Since:
- 3.2
 
- 
removeNullIdpublic static boolean removeNullId(org.bson.conversions.Bson bson) Remove_id : nullfrom the givenBsonif present.- Parameters:
- bson- must not be null.
- Since:
- 3.2
 
- 
toJavaType- Parameters:
- value- must not be null.
- Returns:
- Since:
- 2.1
 
- 
simpleToBsonValue- Parameters:
- source- must not be null.
- Returns:
- the corresponding BsonValuerepresentation.
- Throws:
- IllegalArgumentException- if source does not correspond to a- BsonValuetype.
- Since:
- 3.0
 
- 
simpleToBsonValuepublic static org.bson.BsonValue simpleToBsonValue(Object source, org.bson.codecs.configuration.CodecRegistry codecRegistry) - Parameters:
- source- must not be null.
- codecRegistry- The- CodecRegistryused as a fallback to convert types using native- Codec. Must not be null.
- Returns:
- the corresponding BsonValuerepresentation.
- Throws:
- IllegalArgumentException- if source does not correspond to a- BsonValuetype.
- Since:
- 4.2
 
- 
mergepublic static org.bson.Document merge(org.bson.Document... documents) Merge the givendocumentsinto on in the given order. Keys contained within multiple documents are overwritten by their follow-ups.- Parameters:
- documents- must not be null. Can be empty.
- Returns:
- the document containing all key value pairs.
- Since:
- 2.2
 
- 
toDocumentOrElsepublic static org.bson.Document toDocumentOrElse(String source, Function<String, org.bson.Document> orElse) - Parameters:
- source-
- orElse-
- Returns:
- Since:
- 2.2
 
- 
toJsonSerialize the givenDocumentas Json applying default codecs if necessary.- Parameters:
- source-
- Returns:
- Since:
- 2.2.1
 
- 
isJsonDocumentCheck if a given String looks likeparsablejson.- Parameters:
- value- can be null.
- Returns:
- true if the given value looks like a json document.
- Since:
- 3.0
 
- 
isJsonArrayCheck if a given String looks likeparsablejson array.- Parameters:
- value- can be null.
- Returns:
- true if the given value looks like a json array.
- Since:
- 3.0
 
- 
parsepublic static org.bson.Document parse(String json, @Nullable CodecRegistryProvider codecRegistryProvider) Parse the given json toDocumentapplying transformations as specified by a potentially givenCodec.- Parameters:
- json- must not be null.
- codecRegistryProvider- can be null. In that case the default- DocumentCodecis used.
- Returns:
- never null.
- Throws:
- IllegalArgumentException- if the required argument is null.
- Since:
- 3.0
 
- 
resolveValueResolve the value for a given key. If the givenBsonvalue contains the key the value is immediately returned. If not and the key contains a path using the dot (.) notation it will try to resolve the path by inspecting the individual parts. If one of the intermediate ones is null or cannot be inspected further (wrong) type, null is returned.- Parameters:
- bson- the source to inspect. Must not be null.
- key- the key to lookup. Must not be null.
- Returns:
- can be null.
- Since:
- 3.0.8
 
- 
resolveValueResolve the value for a givenfield name. If the given name is aFieldName.Type.KEYthe value is obtained from the targetBsonimmediately. If the given fieldName is aFieldName.Type.PATHmaybe using the dot (.) notation it will try to resolve the path by inspecting the individual parts. If one of the intermediate ones is null or cannot be inspected further (wrong) type, null is returned.- Parameters:
- bson- the source to inspect. Must not be null.
- fieldName- the name to lookup. Must not be null.
- Returns:
- can be null.
- Since:
- 4.2
 
- 
resolveValueResolve the value for a givenfield name. If the given name is aFieldName.Type.KEYthe value is obtained from the targetBsonimmediately. If the given fieldName is aFieldName.Type.PATHmaybe using the dot (.) notation it will try to resolve the path by inspecting the individual parts. If one of the intermediate ones is null or cannot be inspected further (wrong) type, null is returned.- Parameters:
- source- the source to inspect. Must not be null.
- fieldName- the key to lookup. Must not be null.
- Returns:
- can be null.
- Since:
- 4.2
 
- 
resolveValueResolve the value for a given key. If the givenMapvalue contains the key the value is immediately returned. If not and the key contains a path using the dot (.) notation it will try to resolve the path by inspecting the individual parts. If one of the intermediate ones is null or cannot be inspected further (wrong) type, null is returned.- Parameters:
- source- the source to inspect. Must not be null.
- key- the key to lookup. Must not be null.
- Returns:
- can be null.
- Since:
- 4.1
 
- 
hasValue
- 
hasValueReturns whether the underlyingbsonhas a value (null or non-null) for the givenkey.- Parameters:
- bson- the source to inspect. Must not be null.
- key- the key to lookup. Must not be null.
- Returns:
- true if no non null value present.
- Since:
- 3.0.8
 
- 
asBsonReturns the given source object asBson, i.e.Documents and maps as is or throwIllegalArgumentException.- Parameters:
- source-
- Returns:
- the converted/casted source object.
- Throws:
- IllegalArgumentException- if- sourcecannot be converted/cast to- Bson.
- Since:
- 3.2.3
- See Also:
 
- 
supportsBsonReturns the given source can be used/converted asBson.- Parameters:
- source-
- Returns:
- true if the given source can be converted to Bson.
- Since:
- 3.2.3
 
- 
asCollectionReturns given object asCollection. Will return theCollectionas is if the source is aCollectionalready, will convert an array into aCollectionor simply create a single element collection for everything else.- Parameters:
- source- must not be null.
- Returns:
- never null.
- Since:
- 3.2
 
- 
mapValuespublic static org.bson.Document mapValues(org.bson.Document source, BiFunction<String, Object, Object> valueMapper) 
- 
mapEntries
 
-