
org.mongodb.scala.MongoClient.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mongo-scala-driver_2.11 Show documentation
Show all versions of mongo-scala-driver_2.11 Show documentation
A Scala wrapper of the MongoDB Reactive Streams Java driver
/*
* Copyright 2015 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.
*/
package org.mongodb.scala
import java.io.Closeable
import scala.reflect.ClassTag
import org.bson.codecs.configuration.CodecRegistry
import com.mongodb.ConnectionString
import com.mongodb.async.client.{ MongoClient => JMongoClient, MongoClients }
import org.mongodb.scala.bson.DefaultHelper.DefaultsTo
import org.mongodb.scala.connection.{ ClusterSettings, ConnectionPoolSettings, ServerSettings, SocketSettings, SslSettings }
import org.mongodb.scala.internal.ObservableHelper.observe
/**
* Companion object for creating new [[MongoClient]] instances
*
* @since 1.0
*/
object MongoClient {
/**
* Create a default MongoClient at localhost:27017
*
* @return MongoClient
*/
def apply(): MongoClient = apply("mongodb://localhost:27017")
/**
* Create a MongoClient instance from a connection string uri
*
* @param uri the connection string
* @return MongoClient
*/
def apply(uri: String): MongoClient = {
val connectionString = new ConnectionString(uri)
apply(MongoClientSettings.builder()
.codecRegistry(DEFAULT_CODEC_REGISTRY)
.clusterSettings(ClusterSettings.builder().applyConnectionString(connectionString).build())
.connectionPoolSettings(ConnectionPoolSettings.builder().applyConnectionString(connectionString).build())
.serverSettings(ServerSettings.builder().build()).credentialList(connectionString.getCredentialList)
.sslSettings(SslSettings.builder().applyConnectionString(connectionString).build())
.socketSettings(SocketSettings.builder().applyConnectionString(connectionString).build())
.build())
}
/**
* Create a MongoClient instance from the MongoClientSettings
*
* @param clientSettings MongoClientSettings to use for the MongoClient
* @return
*/
def apply(clientSettings: MongoClientSettings): MongoClient = MongoClient(MongoClients.create(clientSettings))
val DEFAULT_CODEC_REGISTRY: CodecRegistry = org.mongodb.scala.bson.codecs.DEFAULT_CODEC_REGISTRY
}
/**
* A client-side representation of a MongoDB cluster. Instances can represent either a standalone MongoDB instance, a replica set,
* or a sharded cluster. Instance of this class are responsible for maintaining an up-to-date state of the cluster,
* and possibly cache resources related to this, including background threads for monitoring, and connection pools.
*
* Instance of this class server as factories for [[MongoDatabase]] instances.
*
* @param wrapped the underlying java MongoClient
* @since 1.0
*/
case class MongoClient(private val wrapped: JMongoClient) extends Closeable {
/**
* Gets the database with the given name.
*
* @param name the name of the database
* @return the database
*/
def getDatabase(name: String): MongoDatabase = MongoDatabase(wrapped.getDatabase(name))
/**
* Close the client, which will close all underlying cached resources, including, for example,
* sockets and background monitoring threads.
*/
def close(): Unit = wrapped.close()
/**
* Gets the settings that this client uses to connect to server.
*
* **Note**: `MongoClientSettings` is immutable.
*
* @return the settings
*/
lazy val settings: MongoClientSettings = wrapped.getSettings
/**
* Get a list of the database names
*
* [[http://docs.mongodb.org/manual/reference/commands/listDatabases List Databases]]
* @return an iterable containing all the names of all the databases
*/
def listDatabaseNames(): Observable[String] = observe(wrapped.listDatabaseNames())
/**
* Gets the list of databases
*
* @tparam TResult the type of the class to use instead of `Document`.
* @return the fluent list databases interface
*/
def listDatabases[TResult]()(implicit e: TResult DefaultsTo Document, ct: ClassTag[TResult]): ListDatabasesObservable[TResult] =
ListDatabasesObservable(wrapped.listDatabases(ct))
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy