io.vertx.ext.mongo.impl.config.MongoClientOptionsParser Maven / Gradle / Ivy
package io.vertx.ext.mongo.impl.config;
import com.mongodb.*;
import com.mongodb.connection.*;
import io.vertx.core.Vertx;
import io.vertx.core.json.JsonObject;
import io.vertx.ext.mongo.MongoClient;
import io.vertx.ext.mongo.impl.codec.json.JsonObjectCodec;
import org.bson.codecs.*;
import org.bson.codecs.configuration.CodecRegistries;
import org.bson.codecs.configuration.CodecRegistry;
import java.util.List;
import java.util.Objects;
/**
* @author Nick Scavelli
*/
public class MongoClientOptionsParser {
private final static CodecRegistry commonCodecRegistry = CodecRegistries.fromCodecs(new StringCodec(), new IntegerCodec(),
new BooleanCodec(), new DoubleCodec(), new LongCodec(), new BsonDocumentCodec());
private final MongoClientSettings settings;
private final String database;
public MongoClientOptionsParser(Vertx vertx, JsonObject config) {
Objects.requireNonNull(config);
MongoClientSettings.Builder options = MongoClientSettings.builder();
options.codecRegistry(CodecRegistries.fromRegistries(commonCodecRegistry, CodecRegistries.fromCodecs(new JsonObjectCodec(config))));
// All parsers should support connection_string first
String cs = config.getString("connection_string");
ConnectionString connectionString = (cs == null) ? null : new ConnectionString(cs);
String csDatabase = (connectionString != null) ? connectionString.getDatabase() : null;
this.database = config.getString("db_name", csDatabase != null ? csDatabase : MongoClient.DEFAULT_DB_NAME);
// ClusterSettings
ClusterSettings clusterSettings = new ClusterSettingsParser(connectionString, config).settings();
options.applyToClusterSettings(builder -> builder.applySettings(clusterSettings));
// ConnectionPoolSettings
ConnectionPoolSettings connectionPoolSettings = new ConnectionPoolSettingsParser(connectionString, config).settings();
options.applyToConnectionPoolSettings(builder -> builder.applySettings(connectionPoolSettings));
// Credentials
// The previous mongo client supported credentials list but their new implementation supports only
// one credentials. The deprecated code path resorts to using the last credentials if a list is passed
// we are doing the same here.
List credentials = new CredentialListParser(connectionString, config).credentials();
if (!credentials.isEmpty())
options.credential(credentials.get(credentials.size() - 1));
// SocketSettings
SocketSettings socketSettings = new SocketSettingsParser(connectionString, config).settings();
options.applyToSocketSettings(builder -> builder.applySettings(socketSettings));
// Transport type
new StreamTypeParser(config).streamFactory().ifPresent(options::streamFactoryFactory);
// SSLSettings
SslSettings sslSettings = new SSLSettingsParser(connectionString, config).settings(vertx);
options.applyToSslSettings(builder -> builder.applySettings(sslSettings));
// WriteConcern
WriteConcern writeConcern = new WriteConcernParser(connectionString, config).writeConcern();
if (writeConcern != null) {
options.writeConcern(writeConcern);
}
// ReadConcern
ReadConcern readConcern = new ReadConcernLevelParser(connectionString, config).readConcern();
if (readConcern != null) {
options.readConcern(readConcern);
}
// ReadPreference
ReadPreference readPreference = new ReadPreferenceParser(connectionString, config).readPreference();
if (readPreference != null) {
options.readPreference(readPreference);
}
// ServerSettings
ServerSettings serverSettings = new ServerSettingsParser(config).settings();
options.applyToServerSettings(builder -> builder.applySettings(serverSettings));
this.settings = options.build();
}
public MongoClientSettings settings() {
return settings;
}
public String database() {
return database;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy