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.
Subclases conocidas directas
Definido bajo Namespace
Clases: OptionsMapper, SRVProtocol
Colapso delresumen constante
- ESQUEMA =
Obsoleto.
Se eliminará en 3.0.
El esquema de cadena de conexión de mongodb.
'mongodb://'.freeze
- ESQUEMA MONGODB =
El esquema raíz de la cadena de conexión de MongoDB.
'mongodb'.freeze
- ESQUEMA_SRV_MONGODB =
El esquema de la cadena de conexión del protocolo srv de mongodb.
'mongodb+srv'.freeze
- 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}'".freeze
- formato =
Especificación del formato URI de MongoDB.
'mongodb://[nombre de usuario:contraseña@]host1[:puerto1][,host2[:puerto2]' + ',...[,hostN[:portN]]][/[database][?options]]'.freeze
- AYUDA =
URL de la documentación de la URI (cadena de conexión) de MongoDB
'https://www.mongodb.com/es/docs/manual/reference/connection-string/'.freeze
- INSEGURO =
Caracteres no seguros que deben estar codificados en URL.
/[\:\/\@]/- PERCENT_CHAR =
Signo de porcentaje que debe codificarse en las credenciales del usuario.
/\%/- UNIX_SOCKET =
Sufijo de socket Unix.
/.sock/- HOST_DELIM =
El carácter que delimita los hosts.
','.freeze
- HOST_PORT_DELIM =
El carácter que separa un host y un puerto.
':'.freeze
- DATABASE_DELIM =
El carácter que delimita una base de datos.
'/'.freeze
- URI_OPTS_DELIM =
Las opciones de delimitación de caracteres.
'?'.freeze
- INDIV_URI_OPTS_DELIM =
Obsoleto.
El carácter que delimita varias opciones.
'&'.freeze
- URI_OPTS_VALUE_DELIM =
El carácter que delimita una opción y su valor.
'='.freeze
- AUTH_USER_PWD_DELIM =
El carácter que separa un nombre de usuario de la contraseña.
':'.freeze
- AUTH_DELIM =
El carácter que delimita las credenciales de autenticación.
'@'.freeze
- SCHEME_DELIM =
Delimitador de esquema.
'://'.freeze
- 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} ' ".freeze
- CONTRASEÑA DE USUARIO SIN ESCAPAR =
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.".freeze
- UNESCAPED_UNIX_SOCKET =
Detalles del error para una ruta de socket Unix no codificada.
"Los sockets del dominio UNIX deben estar codificados como URL.".freeze
- UNESCAPED_DATABASE =
Detalles del error para un nombre de base de datos de autenticación sin codificación URL.
"Labase de datos de autenticación debe estar codificada enURL"..freeze
- 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.".freeze
- INVALID_HOST =
Detalles del error de un host faltante.
"Host faltante; se debe proporcionar al menos uno.".freeze
- PUERTO_INVÁLIDO =
Detalles del error para un puerto no válido.
"Puerto no válido. El puerto debe ser un número entero mayor que 0 y menor que 65536".freeze
- READ_MODE_MAP =
Mapa de modos de preferencia de lectura URI a modos de preferencia de lectura del driver Ruby
{ 'primario ' => :primario, 'primarypreferred' => :primary_preferred, 'secundario' => secundario, 'secundariopreferido' => :secundario_preferido, 'más cercano' => :más cercano }.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 del controlador 3.0 'MONGODB-CR' => :mongodb_cr, 'MONGODB-X509' => :mongodb_x509, 'PLAIN' => :plain, 'SCRAM-SHA-1' => :largarse, 'SCRAM-SHA-256' => :scram256, }.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 rastrear todos los valores pasados para esas opciones. Asumiendo que no haya conflictos, se condensarán a un solo valor inmediatamente después de analizar el URI.
[ :conjuntos de etiquetas, :ssl ]
Constantes incluidas desde Loggable
Resumen de atributos de la instancia colapsar
-
#opciones ⇒ Objeto
Solo lectura
Las opciones del objeto analizador URI.
-
#servidores ⇒ Objeto
Solo lectura
Los servidores especificados en la 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 se debe pasar a un Mongo::Client en la instanciación, por lo que no tenemos que fusionar las credenciales y la base de datos en ese punto: 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(cadena, opciones = {}) ⇒ 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 en 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.
284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 |
# Archivo 'lib/mongo/uri.rb', línea 284 def inicializar(string, = {}) a menos que string propagar Error::InvalidURI.Nuevo(string, 'La URI debe ser una string, no nula.') end si string.¿vacío? propagar Error::InvalidURI.Nuevo(string, 'No se puede analizar una URI vacía.') end @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 si restante.¿vacío? raise_invalid_error!('No hay hosts en la URI') end parse!(restante) end |
Detalles de los atributos de instancia
#opciones ⇒ Objeto (solo lectura)
Las opciones del objeto analizador URI.
39 40 41 |
# Archivo 'lib/mongo/uri.rb', línea 39 def @options end |
#servidores ⇒ Objeto (solo lectura)
Los servidores especificados en la URI.
49 50 51 |
# Archivo 'lib/mongo/uri.rb', línea 49 def servidores @servers end |
#uri_options ⇒ Object (solo lectura)
Mongo::Options::Redacted de las opciones especificadas en el uri.
44 45 46 |
# Archivo 'lib/mongo/uri.rb', línea 44 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.
230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 |
# Archivo 'lib/mongo/uri.rb', línea 230 def sí mismo.Obtener(string, opta = {}) a menos que string propagar Error::InvalidURI.Nuevo(string, 'La URI debe ser una string, no nula.') end si string.¿vacío? propagar Error::InvalidURI.Nuevo(string, 'No se puede analizar una URI vacía.') end esquema, _, _ = string.partición(SCHEME_DELIM) caso esquema Cuando MONGODB_SCHEME URI.Nuevo(string, opta) Cuando MONGODB_SRV_SCHEME SRVProtocol.Nuevo(string, opta) 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 se debe pasar a un Mongo::Client en la instanciación, por lo que no tenemos que fusionar las credenciales y la base de datos en ese punto: solo tenemos un único punto aquí.
259 260 261 262 263 264 265 |
# Archivo 'lib/mongo/uri.rb', línea 259 def opta = .tocar hacer |opta| opta[:database] = @database si @database end @user ? opta.fusionar(cartas credenciales) : opta end |
#credenciales ⇒ Hash
Obtén las credenciales proporcionadas en el URI.
315 316 317 |
# Archivo 'lib/mongo/uri.rb', línea 315 def cartas credenciales { Usuario/a => @user, :contraseña => @password } end |
#database ⇒ String
Obtenga la base de datos proporcionada en el URI.
327 328 329 |
# Archivo 'lib/mongo/uri.rb', línea 327 def database @database ? @database : Database::ADMIN end |
#srv_records ⇒ Objeto
267 268 269 |
# Archivo 'lib/mongo/uri.rb', línea 267 def registros_srv nulo end |
#to_s ⇒ String
Obtén el uri como una string.
337 338 339 |
# Archivo 'lib/mongo/uri.rb', línea 337 def to_s reconstruct_uri end |