类:Mongo::URI::OptionsMapper Private
- 继承:
-
对象
- 对象
- Mongo::URI::OptionsMapper
- 包括:
- Loggable
- 定义于:
- build/Ruby-driver-v 2.19 /lib/mongo/uri/options_mapper.rb
Overview
此类是私有 API 的一部分。 应尽可能避免使用此类,因为它将来可能会被删除或更改。
在 URI 选项和 Ruby 选项之间执行映射。
该类包含:
-
定义如何将 URI 选项转换为 Ruby 选项的映射。
-
从小写 URI 选项名称到规范大小写 URI 选项名称的映射。
-
将 URI 选项值转换为 Ruby 选项值的方法(convert_* 方法)。 当给定的输入无效时,它们通常会发出警告并返回 nil。
-
将 Ruby 选项值转换为标准化 MongoClient 选项的方法(revert_* 方法)。 这些假设输入有效,通常不执行验证。
URI 选项名称不区分大小写。 Ruby 选项被指定为符号(尽管在客户端选项中使用无关访问)。
常量摘要
Loggable中包含的常量
实例属性摘要折叠
-
# options ⇒ 哈希
只读
private
选项。
实例方法摘要折叠
-
# add_uri_option (key, value, uri_options) ⇒ 对象
private
向 uri 选项哈希添加一个选项。
-
#initialize (**opts) ⇒ OptionsMapper
构造函数
private
实例化选项映射器。
-
# ruby_to_smc (opts) ⇒ 哈希
private
将提供的 Ruby 选项转换为“标准化 MongoClient 选项”。
-
# ruby_to_string (opts) ⇒ 哈希
private
将提供的Ruby选项转换为其在 URI string中的表示形式。
- # smc_to_Ruby (opts) ⇒ 对象 private
Loggable中包含的方法
#log_debug 、 #log_error 、 #log_ Fatal 、 #log_info 、 #log_warn 、 #logger
构造函数详情
#initialize (**opts) ⇒ OptionsMapper
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
实例化选项映射器。
46 47 48 |
# File 'build/Ruby-driver-v 2.19 /lib/mongo/uri/options_mapper.rb', 第46行 def 初始化(**opts) @options = opts end |
实例属性详细信息
# options ⇒哈希(只读)
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
返回 选项。
51 52 53 |
# File 'build/Ruby-driver-v 2.19 /lib/mongo/uri/options_mapper.rb', 第51行 def @options end |
实例方法详细信息
# add_uri_option (key, value, uri_options) ⇒对象
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
向 uri 选项哈希添加一个选项。
Acquires a target for the option based on group.
Transforms the value.
Merges the option into the target.
62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 |
# File 'build/Ruby-driver-v 2.19 /lib/mongo/uri/options_mapper.rb', 第62行 def add_uri_option(key, 值, ) 策略 = URI_OPTION_MAP[key.Downcase] if 策略.nil? log_warn(“ 在 URI ' #{ @string } ' 上 不支持 URI 选项 ' #{ key } } '。它将被忽略。 ") return end GROUP = 策略[:group] 目标 = if GROUP [GROUP] || {} else end 值 = apply_transform(key, 值, 策略[:type]) # 有时,此处的值为零,例如,如果我们正在处理 # 读取偏好标签或身份验证机制属性以及所有 # 其中的数据无效。 忽略此类选项。 除非 值.nil? merge_uri_option(目标, 值, 策略[:name]) end if GROUP && !目标.空? && !.键?(GROUP) [GROUP] = 目标 end end |
# ruby_to_smc (opts) ⇒哈希
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
将提供的 Ruby 选项转换为“标准化 MongoClient 选项”。
126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 |
# File 'build/Ruby-driver-v 2.19 /lib/mongo/uri/options_mapper.rb', 第126行 def ruby_to_smc(opts) rv = {} URI_OPTION_MAP.每 do |uri_key, spec| if spec[:group] v = opts[spec[:group]] v = v && v[spec[:name]] else v = opts[spec[:name]] end 除非 v.nil? if 类型 = spec[:type] v = 发送(" revert_ #{ type } ", v) end canonical_key = URI_OPTION_CANONICAL_NAMES[uri_key] 除非 canonical_key 提高 ArgumentError, "选项#{ uri_key }未知" end rv[canonical_key] = v end end # 对于默认为 true 的选项,如果为 true,请删除该值。 %w(retryReads retryWrites).每 do |k| if rv[k] rv.删除(k) end end # 当身份验证源为 $external 时,删除默认为 #(或要求)该身份验证源。 if %w(MONGODB-AWS).包括?(rv[' authMechanism ']) && rv[' authSource '] == ' $external ' rv.删除(' authSource ') end # ssl 和 tls 是别名,删除 ssl 别名 rv.删除(' ssl ') # 如果 authSource 与数据库相同,则删除 authSource, # 要求此方法知道客户端中指定的数据库。 rv end |
# ruby_to_string (opts) ⇒哈希
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
将提供的Ruby选项转换为其在 URI string中的表示形式。
169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 |
# File 'build/Ruby-driver-v 2.19 /lib/mongo/uri/options_mapper.rb', 第169行 def ruby_to_string(opts) rv = {} URI_OPTION_MAP.每 do |uri_key, spec| if spec[:group] v = opts[spec[:group]] v = v && v[spec[:name]] else v = opts[spec[:name]] end 除非 v.nil? if 类型 = spec[:type] v = 发送(" stringify_ #{ type } ", v) end canonical_key = URI_OPTION_CANONICAL_NAMES[uri_key] 除非 canonical_key 提高 ArgumentError, "选项#{ uri_key }未知" end rv[canonical_key] = v end end # 对于默认为 true 的选项,如果为 true,请删除该值。 %w(retryReads retryWrites).每 do |k| if rv[k] rv.删除(k) end end # 当身份验证源为 $external 时,删除默认为 #(或要求)该身份验证源。 if %w(MONGODB-AWS).包括?(rv[' authMechanism ']) && rv[' authSource '] == ' $external ' rv.删除(' authSource ') end # ssl 和 tls 是别名,删除 ssl 别名 rv.删除(' ssl ') # 如果 authSource 与数据库相同,则删除 authSource, # 要求此方法知道客户端中指定的数据库。 rv end |
# smc_to_Ruby (opts) ⇒对象
此方法是私有 API 的一部分。 您应尽可能避免使用此方法,因为它将来可能会被删除或更改。
88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 |
# File 'build/Ruby-driver-v 2.19 /lib/mongo/uri/options_mapper.rb', 第88行 def smc_to_Ruby(opts) = {} opts.每 do |key, 值| 策略 = URI_OPTION_MAP[key.Downcase] if 策略.nil? log_warn(“ 在 URI ' #{ @string } ' 上 不支持 URI 选项 ' #{ key } } '。它将被忽略。 ") return end GROUP = 策略[:group] 目标 = if GROUP [GROUP] || {} else end 值 = apply_transform(key, 值, 策略[:type]) # 有时,此处的值为零,例如,如果我们正在处理 # 读取偏好标签或身份验证机制属性以及所有 # 其中的数据无效。 忽略此类选项。 除非 值.nil? merge_uri_option(目标, 值, 策略[:name]) end if GROUP && !目标.空? && !.键?(GROUP) [GROUP] = 目标 end end end |