com.mongodb.client.internal.MongoClientImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mongodb-driver-sync Show documentation
Show all versions of mongodb-driver-sync Show documentation
The MongoDB Synchronous Driver
/*
* Copyright 2008-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.
*/
package com.mongodb.client.internal;
import com.mongodb.AutoEncryptionSettings;
import com.mongodb.ClientSessionOptions;
import com.mongodb.MongoClientSettings;
import com.mongodb.MongoDriverInformation;
import com.mongodb.ReadPreference;
import com.mongodb.TransactionOptions;
import com.mongodb.client.ChangeStreamIterable;
import com.mongodb.client.ClientSession;
import com.mongodb.client.ListDatabasesIterable;
import com.mongodb.client.MongoClient;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.MongoIterable;
import com.mongodb.client.SynchronousContextProvider;
import com.mongodb.connection.ClusterDescription;
import com.mongodb.connection.SocketSettings;
import com.mongodb.connection.TransportSettings;
import com.mongodb.internal.client.model.changestream.ChangeStreamLevel;
import com.mongodb.internal.connection.Cluster;
import com.mongodb.internal.connection.DefaultClusterFactory;
import com.mongodb.internal.connection.InternalConnectionPoolSettings;
import com.mongodb.internal.connection.SocketStreamFactory;
import com.mongodb.internal.connection.StreamFactory;
import com.mongodb.internal.diagnostics.logging.Logger;
import com.mongodb.internal.diagnostics.logging.Loggers;
import com.mongodb.internal.session.ServerSessionPool;
import com.mongodb.lang.Nullable;
import com.mongodb.spi.dns.InetAddressResolver;
import org.bson.BsonDocument;
import org.bson.Document;
import org.bson.codecs.configuration.CodecRegistry;
import org.bson.conversions.Bson;
import java.util.Collections;
import java.util.List;
import static com.mongodb.assertions.Assertions.notNull;
import static com.mongodb.client.internal.Crypts.createCrypt;
import static com.mongodb.internal.connection.ClientMetadataHelper.createClientMetadataDocument;
import static com.mongodb.internal.connection.ServerAddressHelper.getInetAddressResolver;
import static com.mongodb.internal.connection.StreamFactoryHelper.getStreamFactoryFactoryFromSettings;
import static com.mongodb.internal.event.EventListenerHelper.getCommandListener;
import static java.lang.String.format;
import static org.bson.codecs.configuration.CodecRegistries.withUuidRepresentation;
/**
* This class is not part of the public API and may be removed or changed at any time
*/
public final class MongoClientImpl implements MongoClient {
private static final Logger LOGGER = Loggers.getLogger("client");
private final MongoClientSettings settings;
private final MongoDriverInformation mongoDriverInformation;
private final MongoClientDelegate delegate;
public MongoClientImpl(final MongoClientSettings settings, final MongoDriverInformation mongoDriverInformation) {
this(createCluster(settings, mongoDriverInformation), mongoDriverInformation, settings, null);
}
public MongoClientImpl(final Cluster cluster, final MongoDriverInformation mongoDriverInformation,
final MongoClientSettings settings,
@Nullable final OperationExecutor operationExecutor) {
this.settings = notNull("settings", settings);
this.mongoDriverInformation = mongoDriverInformation;
AutoEncryptionSettings autoEncryptionSettings = settings.getAutoEncryptionSettings();
if (settings.getContextProvider() != null && !(settings.getContextProvider() instanceof SynchronousContextProvider)) {
throw new IllegalArgumentException("The contextProvider must be an instance of "
+ SynchronousContextProvider.class.getName() + " when using the synchronous driver");
}
this.delegate = new MongoClientDelegate(notNull("cluster", cluster),
withUuidRepresentation(settings.getCodecRegistry(), settings.getUuidRepresentation()), this, operationExecutor,
autoEncryptionSettings == null ? null : createCrypt(this, autoEncryptionSettings), settings.getServerApi(),
(SynchronousContextProvider) settings.getContextProvider());
BsonDocument clientMetadataDocument = createClientMetadataDocument(settings.getApplicationName(), mongoDriverInformation);
LOGGER.info(format("MongoClient with metadata %s created with settings %s", clientMetadataDocument.toJson(), settings));
}
@Override
public MongoDatabase getDatabase(final String databaseName) {
return new MongoDatabaseImpl(databaseName, delegate.getCodecRegistry(), settings.getReadPreference(), settings.getWriteConcern(),
settings.getRetryWrites(), settings.getRetryReads(), settings.getReadConcern(),
settings.getUuidRepresentation(), settings.getAutoEncryptionSettings(), delegate.getOperationExecutor());
}
@Override
public MongoIterable listDatabaseNames() {
return createListDatabaseNamesIterable(null);
}
@Override
public MongoIterable listDatabaseNames(final ClientSession clientSession) {
notNull("clientSession", clientSession);
return createListDatabaseNamesIterable(clientSession);
}
@Override
public ListDatabasesIterable listDatabases() {
return listDatabases(Document.class);
}
@Override
public ListDatabasesIterable listDatabases(final Class clazz) {
return createListDatabasesIterable(null, clazz);
}
@Override
public ListDatabasesIterable listDatabases(final ClientSession clientSession) {
return listDatabases(clientSession, Document.class);
}
@Override
public ListDatabasesIterable listDatabases(final ClientSession clientSession, final Class clazz) {
notNull("clientSession", clientSession);
return createListDatabasesIterable(clientSession, clazz);
}
@Override
public ClientSession startSession() {
return startSession(ClientSessionOptions
.builder()
.defaultTransactionOptions(TransactionOptions.builder()
.readConcern(settings.getReadConcern())
.writeConcern(settings.getWriteConcern())
.build())
.build());
}
@Override
public ClientSession startSession(final ClientSessionOptions options) {
return delegate.createClientSession(notNull("options", options),
settings.getReadConcern(), settings.getWriteConcern(), settings.getReadPreference());
}
@Override
public void close() {
delegate.close();
}
@Override
public ChangeStreamIterable watch() {
return watch(Collections.emptyList());
}
@Override
public ChangeStreamIterable watch(final Class resultClass) {
return watch(Collections.emptyList(), resultClass);
}
@Override
public ChangeStreamIterable watch(final List extends Bson> pipeline) {
return watch(pipeline, Document.class);
}
@Override
public ChangeStreamIterable watch(final List extends Bson> pipeline, final Class resultClass) {
return createChangeStreamIterable(null, pipeline, resultClass);
}
@Override
public ChangeStreamIterable watch(final ClientSession clientSession) {
return watch(clientSession, Collections.emptyList(), Document.class);
}
@Override
public ChangeStreamIterable watch(final ClientSession clientSession, final Class resultClass) {
return watch(clientSession, Collections.emptyList(), resultClass);
}
@Override
public ChangeStreamIterable watch(final ClientSession clientSession, final List extends Bson> pipeline) {
return watch(clientSession, pipeline, Document.class);
}
@Override
public ChangeStreamIterable watch(final ClientSession clientSession, final List extends Bson> pipeline,
final Class resultClass) {
notNull("clientSession", clientSession);
return createChangeStreamIterable(clientSession, pipeline, resultClass);
}
@Override
public ClusterDescription getClusterDescription() {
return delegate.getCluster().getCurrentDescription();
}
private ChangeStreamIterable createChangeStreamIterable(@Nullable final ClientSession clientSession,
final List extends Bson> pipeline,
final Class resultClass) {
return new ChangeStreamIterableImpl<>(clientSession, "admin", delegate.getCodecRegistry(), settings.getReadPreference(),
settings.getReadConcern(), delegate.getOperationExecutor(),
pipeline, resultClass, ChangeStreamLevel.CLIENT, settings.getRetryReads());
}
public Cluster getCluster() {
return delegate.getCluster();
}
public CodecRegistry getCodecRegistry() {
return delegate.getCodecRegistry();
}
private static Cluster createCluster(final MongoClientSettings settings,
@Nullable final MongoDriverInformation mongoDriverInformation) {
notNull("settings", settings);
return new DefaultClusterFactory().createCluster(settings.getClusterSettings(), settings.getServerSettings(),
settings.getConnectionPoolSettings(), InternalConnectionPoolSettings.builder().build(),
getStreamFactory(settings, false), getStreamFactory(settings, true),
settings.getCredential(), settings.getLoggerSettings(), getCommandListener(settings.getCommandListeners()),
settings.getApplicationName(), mongoDriverInformation, settings.getCompressorList(), settings.getServerApi(),
settings.getDnsClient());
}
private static StreamFactory getStreamFactory(final MongoClientSettings settings, final boolean isHeartbeat) {
SocketSettings socketSettings = isHeartbeat ? settings.getHeartbeatSocketSettings() : settings.getSocketSettings();
TransportSettings transportSettings = settings.getTransportSettings();
InetAddressResolver inetAddressResolver = getInetAddressResolver(settings);
if (transportSettings == null) {
return new SocketStreamFactory(inetAddressResolver, socketSettings, settings.getSslSettings());
} else {
return getStreamFactoryFactoryFromSettings(transportSettings, inetAddressResolver)
.create(socketSettings, settings.getSslSettings());
}
}
private ListDatabasesIterable createListDatabasesIterable(@Nullable final ClientSession clientSession, final Class clazz) {
return new ListDatabasesIterableImpl<>(clientSession, clazz, delegate.getCodecRegistry(), ReadPreference.primary(),
delegate.getOperationExecutor(), settings.getRetryReads());
}
private MongoIterable createListDatabaseNamesIterable(@Nullable final ClientSession clientSession) {
return createListDatabasesIterable(clientSession, BsonDocument.class).nameOnly(true).map(result -> result.getString("name").getValue());
}
public ServerSessionPool getServerSessionPool() {
return delegate.getServerSessionPool();
}
public OperationExecutor getOperationExecutor() {
return delegate.getOperationExecutor();
}
public MongoClientSettings getSettings() {
return settings;
}
public MongoDriverInformation getMongoDriverInformation() {
return mongoDriverInformation;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy