/* Copyright 2010-present MongoDB Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
using System;
using System.Collections.Generic;
using System.Dynamic;
using MongoDB.Bson.Serialization;
namespace MongoDB.Bson
{
///
/// A static helper class containing BSON defaults.
///
public static class BsonDefaults
{
// private static fields
private static bool __dynamicArraySerializerWasSet;
private static IBsonSerializer __dynamicArraySerializer;
private static bool __dynamicDocumentSerializerWasSet;
private static IBsonSerializer __dynamicDocumentSerializer;
private static GuidRepresentation __guidRepresentation = GuidRepresentation.CSharpLegacy;
private static GuidRepresentationMode __guidRepresentationMode = GuidRepresentationMode.V2;
private static int __maxDocumentSize = int.MaxValue;
private static int __maxSerializationDepth = 100;
// static constructor
static BsonDefaults()
{
var testWithDefaultGuidRepresentation = Environment.GetEnvironmentVariable("TEST_WITH_DEFAULT_GUID_REPRESENTATION");
if (testWithDefaultGuidRepresentation != null)
{
var _ = Enum.TryParse(testWithDefaultGuidRepresentation, out __guidRepresentation); // ignore errors
}
var testWithDefaultGuidRepresentationMode = Environment.GetEnvironmentVariable("TEST_WITH_DEFAULT_GUID_REPRESENTATION_MODE");
if (testWithDefaultGuidRepresentationMode != null)
{
var _ = Enum.TryParse(testWithDefaultGuidRepresentationMode, out __guidRepresentationMode); // ignore errors
}
}
// public static properties
///
/// Gets or sets the dynamic array serializer.
///
public static IBsonSerializer DynamicArraySerializer
{
get
{
if (!__dynamicArraySerializerWasSet)
{
__dynamicArraySerializer = BsonSerializer.LookupSerializer>();
}
return __dynamicArraySerializer;
}
set
{
__dynamicArraySerializerWasSet = true;
__dynamicArraySerializer = value;
}
}
///
/// Gets or sets the dynamic document serializer.
///
public static IBsonSerializer DynamicDocumentSerializer
{
get
{
if (!__dynamicDocumentSerializerWasSet)
{
__dynamicDocumentSerializer = BsonSerializer.LookupSerializer();
}
return __dynamicDocumentSerializer;
}
set
{
__dynamicDocumentSerializerWasSet = true;
__dynamicDocumentSerializer = value;
}
}
///
/// Gets or sets the default representation to be used in serialization of
/// Guids to the database.
///
///
[Obsolete("Configure serializers instead.")]
public static GuidRepresentation GuidRepresentation
{
get
{
if (BsonDefaults.GuidRepresentationMode != GuidRepresentationMode.V2)
{
throw new InvalidOperationException("BsonDefaults.GuidRepresentation can only be used when BsonDefaults.GuidRepresentationMode is V2.");
}
return __guidRepresentation;
}
set
{
if (BsonDefaults.GuidRepresentationMode != GuidRepresentationMode.V2)
{
throw new InvalidOperationException("BsonDefaults.GuidRepresentation can only be used when BsonDefaults.GuidRepresentationMode is V2.");
}
__guidRepresentation = value;
}
}
///
/// Gets or sets the default representation to be used in serialization of
/// Guids to the database.
///
///
[Obsolete("This property will be removed in a later release.")]
public static GuidRepresentationMode GuidRepresentationMode
{
get { return __guidRepresentationMode; }
set
{
__guidRepresentationMode = value;
if (value == GuidRepresentationMode.V3)
{
__guidRepresentation = GuidRepresentation.Unspecified;
}
}
}
///
/// Gets or sets the default max document size. The default is 4MiB.
///
public static int MaxDocumentSize
{
get { return __maxDocumentSize; }
set { __maxDocumentSize = value; }
}
///
/// Gets or sets the default max serialization depth (used to detect circular references during serialization). The default is 100.
///
public static int MaxSerializationDepth
{
get { return __maxSerializationDepth; }
set { __maxSerializationDepth = value; }
}
}
}