Clase: Mongo::URI
- Hereda:
-
Objeto
- Objeto
- Mongo::URI
- Incluye:
- Address::Validator, Loggable
- Definido en:
- lib/mongo/uri.rb,
lib/mongo/uri/srv_protocol.rb,
lib/mongo/uri/options_mapper.rb
Overview
La clase URI proporciona una forma para que los usuarios analicen el uri de MongoDB tal como se define en la especificación del formato de la cadena de conexión.
https://www.mongodb.com/es/docs/manual/reference/connection-string/
Definido bajo Namespace
clase: OptionsMapper, SRVProtocol
Resumen de constantes colapsar
- ESQUEMA =
Obsoleto.
Se eliminará en 3.0.
El esquema de cadena de conexión de mongodb.
'mongodb://'- MONGODB_SCHEME =
El esquema raíz de la cadena de conexión de MongoDB.
'mongodb'- MONGODB_SRV_SCHEME =
El esquema raíz de la cadena de conexión del protocolo srv de MongoDB.
'mongodb+srv'- INVALID_SCHEME =
Obsoleto.
Detalles de error para un esquema inválido.
"Esquema no válido. El esquema debe ser '#{MONGODB_SCHEME}' o '#{MONGODB_SRV_SCHEME}'"- formato =
Especificación del formato URI de MongoDB.
'mongodb://[nombre de usuario:contraseña@]host1[:puerto1][,host2[:puerto2]' + '...[,hostN[:portN]]][/[base de datos][?options]]'
- AYUDA =
URL de documentación del URI de MongoDB (cadena de conexión)
'https://www.mongodb.com/es/docs/manual/reference/connection-string/'- NO SEGURO =
Caracteres no seguros que deben estar codificados en URL.
%r{[:/@]}- PERCENT_CHAR =
Signo de porcentaje que debe ser codificado en las credenciales del usuario.
/%/- UNIX_SOCKET =
Sufijo de socket Unix.
/.sock/- HOST_DELIM =
El carácter que delimita los hosts.
','- HOST_PORT_DELIM =
El carácter que separa un host y un puerto.
':'- DATABASE_DELIM =
El carácter que delimita una base de datos.
'/'- URI_OPTS_DELIM =
Las opciones de delimitación de caracteres.
'?'- INDIV_URI_OPTS_DELIM =
Obsoleto.
El carácter que delimita varias opciones.
'&'- URI_OPTS_VALUE_DELIM =
El carácter que delimita una opción y su valor.
'='- AUTH_USER_PWD_DELIM =
El carácter que separa un nombre de usuario de la contraseña.
':'- AUTH_DELIM =
El carácter que delimita las credenciales de autenticación.
'@'- SCHEME_DELIM =
Delimitador de esquema.
'://'- INVALID_OPTS_VALUE_DELIM =
Detalles del error para un formato de opciones no válido.
'Las opciones y sus valores deben estar delimitados' + " por '#{URI_OPTS_VALUE_DELIM}'"
- UNESCAPED_USER_PWD =
Detalles del error para un nombre de usuario o contraseña sin URLEncoding.
'El nombre de usuario y la contraseña deben estar codificados en URL.'- UNESCAPED_UNIX_SOCKET =
Detalles del error para una ruta de socket Unix no codificada.
'Los sockets de dominio UNIX deben estar codificados en URL.'- UNESCAPED_DATABASE =
Detalles del error de un nombre de base de datos de autenticación que no está codificado en URL.
'La base de datos de autenticación debe estar urlencoded.'- INVALID_OPTS_DELIM =
Detalles del error para proporcionar opciones sin un delimitador de base de datos.
"El delimitador de base de datos '#{DATABASE_DELIM}' debe estar presente si se especifican opciones."- INVALID_HOST =
Detalles del error por un host ausente.
'Falta el host; debe proporcionarse al menos uno.'- PUERTO_INVÁLIDO =
Detalles del error para un puerto no válido.
'Puerto inválido. El puerto debe ser un número entero mayor que 0 y menor que 65536'- READ_MODE_MAP =
Mapa de modos de preferencia de lectura URI a modos de preferencia de lectura del driver Ruby
{ 'primario/a' => primario/a, 'primarypreferred' => :primary_preferred, 'secundario' => secundario, 'secondarypreferred' => preferencia_secundaria, 'más cercano' => :nearest }.freeze
- AUTH_MECH_MAP =
Mapa de mecanismos de autenticación URI a mecanismos del driver de Ruby
{ 'GSSAPI' => :gssapi, 'MONGODB-AWS' => aws, # MONGODB-CR está obsoleto y se eliminará en la versión 3.0del controlador 'MONGODB-CR' => :mongodb_cr, 'MONGODB-X509' => :mongodb_x509, 'PLAIN' => :plain, 'SCRAM-SHA-1' => Schram, 'SCRAM-SHA-256' => :scram256, }.freeze
- SERVER_MONITORING_MODES =
Valores válidos para la opción URI serverMonitoringMode.
%w[Transmisión sondeo auto].freeze
- REPEATABLE_OPTIONS =
Opciones que se permiten que aparezcan más de una vez en el URI.
Para cumplir con el requisito de la especificación de opciones URI de que todas las instancias de 'tls' y 'ssl' tengan el mismo valor, necesitamos realizar un seguimiento de todos los valores que se pasen para esas opciones. Suponiendo que no entren en conflicto, se condensarán en un solo valor inmediatamente después de analizar el URI.
%i[tag_sets ssl]
Constantes incluidas desde Loggable
Resumen de atributos de la instancia colapsar
-
#opciones ⇒ Objeto
Solo lectura
Las opciones de objeto del parser uri.
-
#servidores ⇒ Objeto
Solo lectura
Los servidores especificados en el uri.
-
#uri_options ⇒ objeto
Solo lectura
Mongo::Options::Redacted de las opciones especificadas en el uri.
Resumen del método de clase colapsar
-
.get(string, opts = {}) ⇒ URI, URI::SRVProtocol
Obtiene un objeto URI o un objeto SRVProtocol URI.
Resumen del método de instancia colapsar
-
#client_options ⇒ Mongo::Options::Redacted
Obtiene el hash de opciones que debe pasarse a un Mongo::Client al momento de la creación, para que no tengamos que fusionar las credenciales y la base de datos en ese momento: solo tenemos un único punto aquí.
-
#credenciales ⇒ Hash
Obtén las credenciales proporcionadas en el URI.
-
#database ⇒ String
Obtenga la base de datos proporcionada en el URI.
-
#inicializar(string, options = {}) ⇒ URI
constructor
Crear el nuevo uri a partir de la string proporcionada.
- #srv_registros ⇒ Objeto
-
#to_s ⇒ String
Obtén el uri como una string.
Métodos incluidos de Address::Validator
Métodos incluidos desde Registrable
#log_debug, #log_error, #log_fatal, #log_info, #log_warn, #logger
Detalles del Constructor
#initialize(string, opciones = {}) ⇒ URI
Crear el nuevo uri a partir de la string proporcionada.
282 283 284 285 286 287 288 289 290 291 292 293 294 295 |
# Archivo 'lib/mongo/uri.rb', línea 282 def inicializar(string, = {}) propagar Error::InvalidURI.Nuevo(string, 'La URI debe ser una string, no nula.') a menos que string propagar Error::InvalidURI.Nuevo(string, 'No se puede analizar una URI vacía.') si string.¿vacío? @string = string @options = parsed_scheme, _, restante = string.partición(SCHEME_DELIM) a menos que parsed_scheme == esquema raise_invalid_error!("Esquema inválido '#{parsed_scheme}'. El esquema debe ser '#{MONGODB_SCHEME}'. Utilice URI#get para analizar los URI SRV.") end raise_invalid_error!('No hay hosts en la URI') si restante.¿vacío? parse!(restante) end |
Detalles de atributo de instancias
#opciones ⇒ Objeto (solo lectura)
Las opciones de objeto del parser uri.
37 38 39 |
# Archivo 'lib/mongo/uri.rb', línea 37 def @options end |
#servidores ⇒ Objeto (solo lectura)
Los servidores especificados en el uri.
47 48 49 |
# Archivo 'lib/mongo/uri.rb', línea 47 def servidor @servers end |
#uri_options ⇒ Object (solo lectura)
Mongo::Options::Redacted de las opciones especificadas en el uri.
42 43 44 |
# Archivo 'lib/mongo/uri.rb', línea 42 def @uri_options end |
Detalles del método de clase
.get(string, opts = {}) ⇒ URI, URI::SRVProtocol
Obtiene un objeto URI o un objeto SRVProtocol URI.
231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 |
# Archivo 'lib/mongo/uri.rb', línea 231 def sí mismo.Obtener(string, opciones = {}) propagar Error::InvalidURI.Nuevo(string, 'La URI debe ser una string, no nula.') a menos que string propagar Error::InvalidURI.Nuevo(string, 'No se puede analizar una URI vacía.') si string.¿vacío? esquema, = string.partición(SCHEME_DELIM) caso esquema cuando MONGODB_SCHEME URI.Nuevo(string, opciones) cuando MONGODB_SRV_SCHEME SRVProtocol.Nuevo(string, opciones) else propagar Error::InvalidURI.Nuevo(string, "Esquema no válido '#{scheme}'. El esquema debe ser '#{MONGODB_SCHEME}' o '#{MONGODB_SRV_SCHEME}'") end end |
Detalles del método de instancia
#client_options ⇒ Mongo::Options::Redacted
Obtiene el hash de opciones que debe pasarse a un Mongo::Client al momento de la creación, para que no tengamos que fusionar las credenciales y la base de datos en ese momento: solo tenemos un único punto aquí.
257 258 259 260 261 262 263 |
# Archivo 'lib/mongo/uri.rb', línea 257 def opciones = .tocar hacer |opciones| opciones[:database] = @database si @database end @user ? opciones.fusionar(credenciales) : opciones end |
#credenciales ⇒ Hash
Obtén las credenciales proporcionadas en el URI.
307 308 309 |
# Archivo 'lib/mongo/uri.rb', línea 307 def credenciales { usuario: @user, Contraseña: @password } end |
#database ⇒ String
Obtenga la base de datos proporcionada en el URI.
319 320 321 |
# Archivo 'lib/mongo/uri.rb', línea 319 def database @database || Database::ADMIN end |
#srv_records → Objeto
265 266 267 |
# Archivo 'lib/mongo/uri.rb', línea 265 def srv_records nulo end |
#to_s ⇒ String
Obtén el uri como una string.
329 330 331 |
# Archivo 'lib/mongo/uri.rb', línea 329 def to_s reconstruct_uri end |