20#include "mongo/client/export_macros.h"
21#include "mongo/logger/log_domain.h"
22#include "mongo/logger/message_log_domain.h"
23#include "mongo/stdx/functional.h"
37 static const unsigned int kDefaultAutoShutdownGracePeriodMillis = 0;
38 static const int kDefaultDefaultLocalThresholdMillis = 15;
41 typedef std::auto_ptr<logger::MessageLogDomain::EventAppender> LogAppenderPtr;
42 typedef stdx::function<LogAppenderPtr()> LogAppenderFactory;
55 enum DefaultPorts { kDbServer = 27017, kShardServer = 27018, kConfigServer = 27019 };
92 bool callShutdownAtExit()
const;
100 unsigned int autoShutdownGracePeriodMillis()
const;
112 int defaultLocalThresholdMillis()
const;
137 return SSLMode() != kSSLDisabled;
145 const bool FIPSMode()
const;
153 const std::vector<TLSProtocol>& SSLDisabledTLSProtocols()
const;
160 const std::string& SSLCAFile()
const;
167 const std::string& SSLPEMKeyFile()
const;
174 const std::string& SSLPEMKeyPassword()
const;
181 const std::string& SSLCRLFile()
const;
188 const bool SSLAllowInvalidCertificates()
const;
195 const bool SSLAllowInvalidHostnames()
const;
202 const std::string& SSLCipherConfig()
const;
213 const LogAppenderFactory& logAppenderFactory()
const;
221 logger::LogSeverity minLoggedSeverity()
const;
232 bool IPv6Enabled()
const;
243 bool validateObjects()
const;
246 bool _callShutdownAtExit;
247 unsigned int _autoShutdownGracePeriodMillis;
250 std::vector<TLSProtocol> _sslDisabledTLSProtocols;
251 std::string _sslCAFile;
252 std::string _sslPEMKeyFile;
253 std::string _sslPEMKeyPassword;
254 std::string _sslCRLFile;
255 bool _sslAllowInvalidCertificates;
256 bool _sslAllowInvalidHostnames;
257 std::string _sslCipherConfig;
258 int _defaultLocalThresholdMillis;
259 LogAppenderFactory _appenderFactory;
260 logger::LogSeverity _minLoggedSeverity;
262 bool _validateObjects;
The Options structure is passed to mongo::client::initialize to configure various properties and conf...
Definition options.h:32
Options & setSSLAllowInvalidCertificates(bool value=true)
When set true, SSL certificate validation is disabled.
Options & setSSLMode(SSLModes sslMode=kSSLRequired)
If set to kSSLRequired, the driver will use SSL when connecting.
Options & setValidateObjects(bool value=true)
Configure whether BSON objects returned from the server should be validated.
Options & setSSLDisabledTLSProtocols(const std::vector< TLSProtocol > &protocols)
Allow disabling particular TLS protocols.
static const Options & current()
Obtains the currently configured options for the driver.
Options & setDefaultLocalThresholdMillis(int millis)
Set the default threshold to consider a node local.
SSLModes
The possible modes for SSL support in an SSL enabled build of the driver.
Definition options.h:58
@ kSSLDisabled
Don't attempt to make SSL connections, or require SSL support of the server.
Definition options.h:61
Options & setSSLCipherConfig(const std::string &config)
Override the default OpenSSL cipher configuration.
DefaultPorts
The default ports where different mongodb servers tend to run.
Definition options.h:55
Options & setCallShutdownAtExit(bool value=true)
If true, the driver will automatically schedule a client::shutdown via 'std::atexit'.
TLSProtocol
The TLS protocols.
Definition options.h:75
Options & setSSLCRLFile(const std::string &fileName)
Configure the SSL CRL file to use.
Options & setSSLPEMKeyPassword(const std::string &password)
Configure the SSL PEM key password.
Options & setSSLPEMKeyFile(const std::string &fileName)
Configure the SSL PEM key file to use.
Options & setAutoShutdownGracePeriodMillis(unsigned int millis)
The grace period used when calling client::shutdown from atexit.
Options & setLogAppenderFactory(const LogAppenderFactory &factory)
Provide a factory for a log appender to configure logging.
Options()
Constructs a default options object with default values for all options.
Options & setSSLCAFile(const std::string &fileName)
Configure the SSL CA file to use.
Options & setIPv6Enabled(bool state)
Enable support for the IPv6 protocol family.
Options & setFIPSMode(bool value=true)
Sets whether to operate in FIPS mode.
Options & setMinLoggedSeverity(logger::LogSeverity level)
Specify the minimum severity of messages that will be logged, if logging is enabled.
bool SSLEnabled() const
A convenience: returns true if SSL is not disabled (preferred or required).
Definition options.h:136
Options & setSSLAllowInvalidHostnames(bool value=true)
When set true, SSL hostname validation is disabled.
the main MongoDB namespace
Definition bulk_operation_builder.h:24