Skip to content

Commit

Permalink
**[edison-mongo]** add command listener to MongoClient
Browse files Browse the repository at this point in the history
  • Loading branch information
peterfouquet0001 committed Nov 24, 2021
1 parent ebfdd14 commit 2c1541e
Show file tree
Hide file tree
Showing 4 changed files with 15 additions and 6 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,10 @@
* **[edison-core]**
* Update to Spring Boot 2.5.0 and Spring 5.3.8

## 2.4.7.1
* **[edison-mongo]**
* add command listener to MongoClient

## 2.4.7
* **[edison-mongo]** add writeConcern to MongoProperties
* **[edison-togglz]** change ConditionalOnBean(MongoClient) to ConditionalOnClass(MongoClient) for MongoTogglzConfiguration
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
import com.mongodb.client.MongoClient;
import com.mongodb.client.MongoClients;
import com.mongodb.client.MongoDatabase;
import com.mongodb.event.CommandListener;
import org.bson.codecs.configuration.CodecRegistry;
import org.slf4j.Logger;
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
Expand Down Expand Up @@ -52,10 +53,10 @@ public MongoCompressor zlibCompressor() {
@Bean
@Primary
@ConditionalOnMissingBean(name = "mongoClient", value = MongoClient.class)
public MongoClient mongoClient(final MongoProperties mongoProperties, List<MongoCompressor> possibleCompressors) {
public MongoClient mongoClient(final MongoProperties mongoProperties, final List<MongoCompressor> possibleCompressors, final List<CommandListener> commandListeners) {
LOG.info("Creating MongoClient");

MongoClientSettings mongoClientSettings = mongoProperties.toMongoClientSettings(codecRegistry(), possibleCompressors);
MongoClientSettings mongoClientSettings = mongoProperties.toMongoClientSettings(codecRegistry(), possibleCompressors, commandListeners);

return MongoClients.create(mongoClientSettings);
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package de.otto.edison.mongo.configuration;

import com.mongodb.*;
import com.mongodb.event.CommandListener;
import de.otto.edison.status.domain.Datasource;
import org.bson.codecs.configuration.CodecRegistry;
import org.slf4j.Logger;
Expand Down Expand Up @@ -262,7 +263,7 @@ public void setClientServerCompressionEnabled(boolean clientServerCompressionEna
this.clientServerCompressionEnabled = clientServerCompressionEnabled;
}

public MongoClientSettings toMongoClientSettings(final CodecRegistry codecRegistry, List<MongoCompressor> possibleCompressors) {
public MongoClientSettings toMongoClientSettings(final CodecRegistry codecRegistry, final List<MongoCompressor> possibleCompressors, final List<CommandListener> commandListeners) {
MongoClientSettings.Builder clientOptionsBuilder = MongoClientSettings.builder()
.applyToSslSettings(builder -> builder.enabled(sslEnabled))
.codecRegistry(codecRegistry)
Expand All @@ -282,12 +283,15 @@ public MongoClientSettings toMongoClientSettings(final CodecRegistry codecRegist
if (isClientServerCompressionEnabled()) {
clientOptionsBuilder.compressorList(possibleCompressors);
}
if(useAuthorizedConnection()) {
if (useAuthorizedConnection()) {
clientOptionsBuilder.credential(getMongoCredentials());
}
if (nonNull(writeConcern)) {
clientOptionsBuilder.writeConcern(WriteConcern.valueOf(writeConcern));
}
if (nonNull(commandListeners)) {
commandListeners.forEach(e->clientOptionsBuilder.addCommandListener(e));
}

return clientOptionsBuilder.build();
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ void shouldConfigureCompressorListWhenClientServerCompressionIsEnabled() {

//when
props.setClientServerCompressionEnabled(true);
MongoClientSettings mongoClientOptions = props.toMongoClientSettings(MongoClientSettings.getDefaultCodecRegistry(), Collections.singletonList(MongoCompressor.createZlibCompressor()));
MongoClientSettings mongoClientOptions = props.toMongoClientSettings(MongoClientSettings.getDefaultCodecRegistry(), Collections.singletonList(MongoCompressor.createZlibCompressor()), null);

//then
assertThat(mongoClientOptions.getCompressorList(), is(Collections.singletonList(MongoCompressor.createZlibCompressor())));
Expand All @@ -38,7 +38,7 @@ void shouldNotConfigureCompressorListWhenClientServerCompressionIsDisabled() {

//when
props.setClientServerCompressionEnabled(false);
MongoClientSettings mongoClientOptions = props.toMongoClientSettings(MongoClientSettings.getDefaultCodecRegistry(), Collections.singletonList(MongoCompressor.createZlibCompressor()));
MongoClientSettings mongoClientOptions = props.toMongoClientSettings(MongoClientSettings.getDefaultCodecRegistry(), Collections.singletonList(MongoCompressor.createZlibCompressor()), null);

//then
assertThat(mongoClientOptions.getCompressorList(), is(Collections.emptyList()));
Expand Down

0 comments on commit 2c1541e

Please sign in to comment.