/* 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; } } } }