Documentation ¶
Overview ¶
Package bsonutil provides utilities for processing BSON data.
Index ¶
- Variables
- func ConvertBSONValueToJSON(x interface{}) (interface{}, error)
- func ConvertJSONDocumentToBSON(doc map[string]interface{}) error
- func ConvertJSONValueToBSON(x interface{}) (interface{}, error)
- func FindValueByKey(keyName string, document *bson.D) (interface{}, error)
- func GetBSONValueAsJSON(x interface{}) (interface{}, error)
- func GetExtendedBsonD(doc bson.D) (bson.D, error)
- func MakeSortString(sortObj bson.D) ([]string, error)
- func ParseJSONValue(jsonValue interface{}) (interface{}, error)
- func ParseSpecialKeys(special interface{}) (interface{}, error)
- type MarshalD
Constants ¶
This section is empty.
Variables ¶
var ErrNoSuchField = errors.New("no such field")
Functions ¶
func ConvertBSONValueToJSON ¶
func ConvertBSONValueToJSON(x interface{}) (interface{}, error)
ConvertBSONValueToJSON walks through a document or an array and converts any BSON value to its corresponding extended JSON type. It returns the converted JSON document and any error encountered.
func ConvertJSONDocumentToBSON ¶
ConvertJSONDocumentToBSON iterates through the document map and converts JSON values to their corresponding BSON values. It also replaces any extended JSON type value (e.g. $date) with the corresponding BSON type.
func ConvertJSONValueToBSON ¶
func ConvertJSONValueToBSON(x interface{}) (interface{}, error)
ConvertJSONValueToBSON walks through a document or an array and replaces any extended JSON value with its corresponding BSON type.
func FindValueByKey ¶
FindValueByKey returns the value of keyName in document. If keyName is not found in the top-level of the document, ErrNoSuchField is returned as the error.
func GetBSONValueAsJSON ¶
func GetBSONValueAsJSON(x interface{}) (interface{}, error)
GetBSONValueAsJSON is equivalent to ConvertBSONValueToJSON, but does not mutate its argument.
func GetExtendedBsonD ¶
GetExtendedBsonD iterates through the document and returns a bson.D that adds type information for each key in document.
func MakeSortString ¶
MakeSortString takes a bson.D object and converts it to a slice of strings that can be used as the input args to mgo's .Sort(...) function. For example: {a:1, b:-1} -> ["+a", "-b"]
func ParseJSONValue ¶
func ParseJSONValue(jsonValue interface{}) (interface{}, error)
ParseJSONValue takes any value generated by the json package and returns a BSON version of that value.
func ParseSpecialKeys ¶
func ParseSpecialKeys(special interface{}) (interface{}, error)
ParseSpecialKeys takes a JSON document and inspects it for any extended JSON type (e.g $numberLong) and replaces any such values with the corresponding BSON type.
Types ¶
type MarshalD ¶
MarshalD is a wrapper for bson.D that allows unmarshalling of bson.D with preserved order. Necessary for printing certain database commands.
func (MarshalD) MarshalJSON ¶
MarshalJSON makes the MarshalD type usable by the encoding/json package.