/* 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 MongoDB.Driver.Core.Clusters; namespace MongoDB.Driver { /// /// Server connection mode. /// #if NET452 [Serializable] #endif public enum ConnectionMode { /// /// Automatically determine how to connect. /// Automatic, /// /// Connect directly to a server. /// Direct, /// /// Connect to a replica set. /// ReplicaSet, /// /// Connect to one or more shard routers. /// ShardRouter, /// /// Connect to a standalone server. /// Standalone } internal static class ConnectionModeExtensionMethods { public static ClusterConnectionMode ToCore(this ConnectionMode value) { switch (value) { case ConnectionMode.Automatic: return ClusterConnectionMode.Automatic; case ConnectionMode.Direct: return ClusterConnectionMode.Direct; case ConnectionMode.ReplicaSet: return ClusterConnectionMode.ReplicaSet; case ConnectionMode.ShardRouter: return ClusterConnectionMode.Sharded; case ConnectionMode.Standalone: return ClusterConnectionMode.Standalone; default: throw new ArgumentException("Invalid ConnectionMode.", "value"); } } } }