cisco_node_utils 1.1.0 → 1.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (202) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +2 -1
  3. data/CHANGELOG.md +126 -1
  4. data/README.md +19 -12
  5. data/Rakefile +1 -0
  6. data/bin/git/hooks/commit-msg/enforce_style +8 -0
  7. data/cisco_node_utils.gemspec +4 -3
  8. data/docs/README-develop-best-practices.md +127 -109
  9. data/docs/README-develop-node-utils-APIs.md +47 -39
  10. data/docs/template-router.rb +3 -7
  11. data/lib/.rubocop.yml +4 -4
  12. data/lib/cisco_node_utils.rb +1 -1
  13. data/lib/cisco_node_utils/aaa_authentication_login.rb +96 -0
  14. data/lib/cisco_node_utils/aaa_authentication_login_service.rb +133 -0
  15. data/lib/cisco_node_utils/aaa_authorization_service.rb +150 -0
  16. data/lib/cisco_node_utils/ace.rb +196 -0
  17. data/lib/cisco_node_utils/acl.rb +100 -0
  18. data/lib/cisco_node_utils/bgp.rb +301 -163
  19. data/lib/cisco_node_utils/bgp_af.rb +187 -19
  20. data/lib/cisco_node_utils/bgp_neighbor.rb +18 -33
  21. data/lib/cisco_node_utils/bgp_neighbor_af.rb +25 -48
  22. data/lib/cisco_node_utils/cisco_cmn_utils.rb +23 -4
  23. data/lib/cisco_node_utils/cmd_ref/README_YAML.md +593 -0
  24. data/lib/cisco_node_utils/cmd_ref/aaa_auth_login_service.yaml +22 -0
  25. data/lib/cisco_node_utils/cmd_ref/aaa_authentication_login.yaml +31 -0
  26. data/lib/cisco_node_utils/cmd_ref/aaa_authorization_service.yaml +22 -0
  27. data/lib/cisco_node_utils/cmd_ref/acl.yaml +43 -0
  28. data/lib/cisco_node_utils/cmd_ref/bgp.yaml +242 -0
  29. data/lib/cisco_node_utils/cmd_ref/bgp_af.yaml +164 -0
  30. data/lib/cisco_node_utils/cmd_ref/bgp_neighbor.yaml +131 -0
  31. data/lib/cisco_node_utils/cmd_ref/bgp_neighbor_af.yaml +179 -0
  32. data/lib/cisco_node_utils/cmd_ref/dnsclient.yaml +34 -0
  33. data/lib/cisco_node_utils/cmd_ref/evpn_vni.yaml +42 -0
  34. data/lib/cisco_node_utils/cmd_ref/fabricpath.yaml +172 -0
  35. data/lib/cisco_node_utils/cmd_ref/fabricpath_topology.yaml +35 -0
  36. data/lib/cisco_node_utils/cmd_ref/feature.yaml +42 -0
  37. data/lib/cisco_node_utils/cmd_ref/fex.yaml +9 -0
  38. data/lib/cisco_node_utils/cmd_ref/images.yaml +7 -0
  39. data/lib/cisco_node_utils/cmd_ref/interface.yaml +339 -0
  40. data/lib/cisco_node_utils/cmd_ref/interface_channel_group.yaml +28 -0
  41. data/lib/cisco_node_utils/cmd_ref/interface_ospf.yaml +61 -0
  42. data/lib/cisco_node_utils/cmd_ref/interface_portchannel.yaml +54 -0
  43. data/lib/cisco_node_utils/cmd_ref/interface_service_vni.yaml +32 -0
  44. data/lib/cisco_node_utils/cmd_ref/inventory.yaml +45 -0
  45. data/lib/cisco_node_utils/cmd_ref/memory.yaml +13 -0
  46. data/lib/cisco_node_utils/cmd_ref/ntp_config.yaml +7 -0
  47. data/lib/cisco_node_utils/cmd_ref/ntp_server.yaml +14 -0
  48. data/lib/cisco_node_utils/cmd_ref/ospf.yaml +74 -0
  49. data/lib/cisco_node_utils/cmd_ref/overlay_global.yaml +33 -0
  50. data/lib/cisco_node_utils/cmd_ref/pim.yaml +40 -0
  51. data/lib/cisco_node_utils/cmd_ref/portchannel_global.yaml +69 -0
  52. data/lib/cisco_node_utils/cmd_ref/radius_global.yaml +25 -0
  53. data/lib/cisco_node_utils/cmd_ref/radius_server.yaml +64 -0
  54. data/lib/cisco_node_utils/cmd_ref/radius_server_group.yaml +14 -0
  55. data/lib/cisco_node_utils/cmd_ref/show_system.yaml +5 -0
  56. data/lib/cisco_node_utils/cmd_ref/show_version.yaml +72 -0
  57. data/lib/cisco_node_utils/cmd_ref/snmp_community.yaml +23 -0
  58. data/lib/cisco_node_utils/cmd_ref/snmp_group.yaml +7 -0
  59. data/lib/cisco_node_utils/cmd_ref/snmp_notification_receiver.yaml +50 -0
  60. data/lib/cisco_node_utils/cmd_ref/snmp_server.yaml +51 -0
  61. data/lib/cisco_node_utils/cmd_ref/snmp_user.yaml +55 -0
  62. data/lib/cisco_node_utils/cmd_ref/snmpnotification.yaml +11 -0
  63. data/lib/cisco_node_utils/cmd_ref/syslog_server.yaml +18 -0
  64. data/lib/cisco_node_utils/cmd_ref/syslog_settings.yaml +7 -0
  65. data/lib/cisco_node_utils/cmd_ref/system.yaml +6 -0
  66. data/lib/cisco_node_utils/cmd_ref/tacacs_server.yaml +49 -0
  67. data/lib/cisco_node_utils/cmd_ref/tacacs_server_group.yaml +33 -0
  68. data/lib/cisco_node_utils/cmd_ref/tacacs_server_host.yaml +35 -0
  69. data/lib/cisco_node_utils/cmd_ref/vdc.yaml +38 -0
  70. data/lib/cisco_node_utils/cmd_ref/virtual_service.yaml +6 -0
  71. data/lib/cisco_node_utils/cmd_ref/vlan.yaml +56 -0
  72. data/lib/cisco_node_utils/cmd_ref/vni.yaml +76 -0
  73. data/lib/cisco_node_utils/cmd_ref/vpc.yaml +197 -0
  74. data/lib/cisco_node_utils/cmd_ref/vrf.yaml +88 -0
  75. data/lib/cisco_node_utils/cmd_ref/vtp.yaml +38 -0
  76. data/lib/cisco_node_utils/cmd_ref/vxlan_vtep.yaml +60 -0
  77. data/lib/cisco_node_utils/cmd_ref/vxlan_vtep_vni.yaml +39 -0
  78. data/lib/cisco_node_utils/cmd_ref/yum.yaml +13 -0
  79. data/lib/cisco_node_utils/command_reference.rb +359 -187
  80. data/lib/cisco_node_utils/configparser_lib.rb +1 -1
  81. data/lib/cisco_node_utils/dns_domain.rb +19 -5
  82. data/lib/cisco_node_utils/domain_name.rb +4 -8
  83. data/lib/cisco_node_utils/evpn_vni.rb +157 -0
  84. data/lib/cisco_node_utils/fabricpath_global.rb +388 -0
  85. data/lib/cisco_node_utils/fabricpath_topology.rb +150 -0
  86. data/lib/cisco_node_utils/feature.rb +111 -0
  87. data/lib/cisco_node_utils/interface.rb +390 -97
  88. data/lib/cisco_node_utils/interface_channel_group.rb +124 -0
  89. data/lib/cisco_node_utils/interface_ospf.rb +11 -34
  90. data/lib/cisco_node_utils/interface_portchannel.rb +157 -0
  91. data/lib/cisco_node_utils/interface_service_vni.rb +132 -0
  92. data/lib/cisco_node_utils/name_server.rb +1 -1
  93. data/lib/cisco_node_utils/node.rb +55 -249
  94. data/lib/cisco_node_utils/node_util.rb +5 -1
  95. data/lib/cisco_node_utils/ntp_config.rb +2 -2
  96. data/lib/cisco_node_utils/ntp_server.rb +14 -5
  97. data/lib/cisco_node_utils/overlay_global.rb +153 -0
  98. data/lib/cisco_node_utils/pim.rb +124 -0
  99. data/lib/cisco_node_utils/pim_group_list.rb +108 -0
  100. data/lib/cisco_node_utils/pim_rp_address.rb +102 -0
  101. data/lib/cisco_node_utils/platform.rb +8 -9
  102. data/lib/cisco_node_utils/portchannel_global.rb +277 -0
  103. data/lib/cisco_node_utils/radius_global.rb +9 -19
  104. data/lib/cisco_node_utils/radius_server.rb +31 -41
  105. data/lib/cisco_node_utils/radius_server_group.rb +117 -0
  106. data/lib/cisco_node_utils/router_ospf.rb +1 -1
  107. data/lib/cisco_node_utils/router_ospf_vrf.rb +14 -19
  108. data/lib/cisco_node_utils/snmp_notification_receiver.rb +158 -0
  109. data/lib/cisco_node_utils/snmpcommunity.rb +3 -5
  110. data/lib/cisco_node_utils/snmpgroup.rb +1 -1
  111. data/lib/cisco_node_utils/snmpnotification.rb +57 -0
  112. data/lib/cisco_node_utils/snmpserver.rb +8 -17
  113. data/lib/cisco_node_utils/snmpuser.rb +67 -28
  114. data/lib/cisco_node_utils/syslog_server.rb +3 -9
  115. data/lib/cisco_node_utils/syslog_settings.rb +2 -10
  116. data/lib/cisco_node_utils/tacacs_server.rb +9 -14
  117. data/lib/cisco_node_utils/tacacs_server_group.rb +145 -0
  118. data/lib/cisco_node_utils/tacacs_server_host.rb +5 -9
  119. data/lib/cisco_node_utils/vdc.rb +88 -0
  120. data/lib/cisco_node_utils/version.rb +5 -2
  121. data/lib/cisco_node_utils/vlan.rb +71 -8
  122. data/lib/cisco_node_utils/vni.rb +227 -0
  123. data/lib/cisco_node_utils/vpc.rb +377 -0
  124. data/lib/cisco_node_utils/vrf.rb +60 -9
  125. data/lib/cisco_node_utils/vrf_af.rb +191 -0
  126. data/lib/cisco_node_utils/vtp.rb +8 -6
  127. data/lib/cisco_node_utils/vxlan_vtep.rb +151 -0
  128. data/lib/cisco_node_utils/vxlan_vtep_vni.rb +234 -0
  129. data/lib/cisco_node_utils/yum.rb +1 -1
  130. data/tests/.rubocop.yml +1 -1
  131. data/tests/basetest.rb +16 -7
  132. data/tests/ciscotest.rb +55 -13
  133. data/tests/cmd_config.yaml +2 -2
  134. data/tests/platform_info.rb +3 -2
  135. data/tests/test_aaa_authentication_login.rb +219 -0
  136. data/tests/test_aaa_authentication_login_service.rb +759 -0
  137. data/tests/test_aaa_authorization_service.rb +1041 -0
  138. data/tests/test_ace.rb +160 -0
  139. data/tests/test_acl.rb +176 -0
  140. data/tests/test_bgp_af.rb +269 -13
  141. data/tests/test_bgp_neighbor.rb +38 -40
  142. data/tests/test_bgp_neighbor_af.rb +92 -32
  143. data/tests/test_command_config.rb +5 -5
  144. data/tests/test_command_reference.rb +284 -101
  145. data/tests/test_dns_domain.rb +1 -1
  146. data/tests/test_domain_name.rb +1 -1
  147. data/tests/test_evpn_vni.rb +106 -0
  148. data/tests/test_fabricpath_global.rb +243 -0
  149. data/tests/test_fabricpath_topology.rb +98 -0
  150. data/tests/test_interface.rb +292 -74
  151. data/tests/test_interface_channel_group.rb +74 -0
  152. data/tests/test_interface_ospf.rb +9 -4
  153. data/tests/test_interface_portchannel.rb +105 -0
  154. data/tests/test_interface_service_vni.rb +232 -0
  155. data/tests/test_interface_svi.rb +77 -62
  156. data/tests/test_interface_switchport.rb +17 -5
  157. data/tests/test_name_server.rb +1 -1
  158. data/tests/test_node.rb +1 -1
  159. data/tests/test_node_ext.rb +10 -20
  160. data/tests/test_ntp_config.rb +1 -1
  161. data/tests/test_ntp_server.rb +18 -6
  162. data/tests/test_overlay_global.rb +102 -0
  163. data/tests/test_pim.rb +177 -0
  164. data/tests/test_pim_group_list.rb +181 -0
  165. data/tests/test_pim_rp_address.rb +153 -0
  166. data/tests/test_platform.rb +3 -3
  167. data/tests/test_portchannel_global.rb +202 -0
  168. data/tests/test_radius_global.rb +1 -1
  169. data/tests/test_radius_server.rb +92 -57
  170. data/tests/test_radius_server_group.rb +149 -0
  171. data/tests/test_router_bgp.rb +283 -112
  172. data/tests/test_router_ospf.rb +2 -2
  173. data/tests/test_router_ospf_vrf.rb +4 -4
  174. data/tests/test_snmp_notification_receiver.rb +167 -0
  175. data/tests/test_snmpcommunity.rb +1 -1
  176. data/tests/test_snmpgroup.rb +1 -1
  177. data/tests/test_snmpnotification.rb +72 -0
  178. data/tests/test_snmpserver.rb +29 -105
  179. data/tests/test_snmpuser.rb +32 -30
  180. data/tests/test_syslog_server.rb +36 -10
  181. data/tests/test_syslog_settings.rb +1 -1
  182. data/tests/test_tacacs_server.rb +1 -1
  183. data/tests/test_tacacs_server_group.rb +405 -0
  184. data/tests/test_tacacs_server_host.rb +1 -1
  185. data/tests/test_vdc.rb +78 -0
  186. data/tests/test_vlan.rb +74 -19
  187. data/tests/test_vlan_mt_full.rb +95 -0
  188. data/tests/test_vni.rb +106 -0
  189. data/tests/test_vpc.rb +361 -0
  190. data/tests/test_vrf.rb +172 -29
  191. data/tests/test_vtp.rb +1 -1
  192. data/tests/test_vxlan_vtep.rb +214 -0
  193. data/tests/test_vxlan_vtep_vni.rb +201 -0
  194. data/tests/test_yum.rb +1 -1
  195. metadata +120 -11
  196. data/lib/cisco_node_utils/README_YAML.md +0 -325
  197. data/lib/cisco_node_utils/command_reference_common.yaml +0 -1051
  198. data/lib/cisco_node_utils/command_reference_common_bgp.yaml +0 -535
  199. data/lib/cisco_node_utils/command_reference_n3064.yaml +0 -13
  200. data/lib/cisco_node_utils/command_reference_n7k.yaml +0 -52
  201. data/lib/cisco_node_utils/command_reference_n9k.yaml +0 -26
  202. data/tests/platform_info.yaml +0 -10
@@ -3,7 +3,7 @@
3
3
  #
4
4
  # September 2015, Hunter Haugen
5
5
  #
6
- # Copyright (c) 2015 Cisco and/or its affiliates.
6
+ # Copyright (c) 2015-2016 Cisco and/or its affiliates.
7
7
  #
8
8
  # Licensed under the Apache License, Version 2.0 (the "License");
9
9
  # you may not use this file except in compliance with the License.
@@ -4,7 +4,7 @@
4
4
  #
5
5
  # December 2014, Glenn F. Matthews
6
6
  #
7
- # Copyright (c) 2014-2015 Cisco and/or its affiliates.
7
+ # Copyright (c) 2014-2016 Cisco and/or its affiliates.
8
8
  #
9
9
  # Licensed under the Apache License, Version 2.0 (the "License");
10
10
  # you may not use this file except in compliance with the License.
@@ -50,10 +50,6 @@ module Cisco
50
50
  class Node
51
51
  include Singleton
52
52
 
53
- # BEGIN NODE API
54
- # This is most of what a client/provider should need to code against.
55
- # Actual implementations of these methods are later in this file.
56
-
57
53
  # Convenience wrapper for show(command, :structured).
58
54
  # Uses CommandReference to look up the given show command and key
59
55
  # of interest, executes that command, and returns the value corresponding
@@ -69,46 +65,64 @@ module Cisco
69
65
  # @return [String, Hash, Array]
70
66
  # @example config_get("show_version", "system_image")
71
67
  # @example config_get("ospf", "router_id",
72
- # {:name => "green", :vrf => "one"})
68
+ # {name: "green", vrf: "one"})
73
69
  def config_get(feature, name, *args)
74
70
  fail 'lazy_connect specified but did not request connect' unless @cmd_ref
75
71
  ref = @cmd_ref.lookup(feature, name)
76
72
 
73
+ return ref.default_value if ref.default_only?
74
+
77
75
  begin
78
- token = build_config_get_token(feature, ref, args)
79
- rescue IndexError, TypeError
80
- # IndexError if value is not set, TypeError if set to nil explicitly
76
+ token = ref.config_get_token(*args)
77
+ rescue IndexError
78
+ # IndexError: no entry for config_get_token
81
79
  token = nil
82
80
  end
83
- if token.kind_of?(String)
84
- if token[0] == '/' && token[-1] == '/'
85
- fail RuntimeError unless args.length == token.scan(/%/).length
86
- # convert string to regexp and replace %s with args
87
- token = Regexp.new(sprintf(token, *args)[1..-2])
88
- text = build_config_get(feature, ref, :ascii)
89
- return Cisco.find_ascii(text, token)
90
- else
91
- hash = build_config_get(feature, ref, :structured)
92
- return hash[token]
93
- end
94
- elsif token.kind_of?(Array)
95
- # Array of /regexps/ -> ascii, array of strings/ints -> structured
96
- if token[0].kind_of?(String) &&
97
- token[0][0] == '/' &&
98
- (token[0][-1] == '/' || token[0][-2..-1] == '/i')
99
-
100
- token = token_str_to_regexp(token, args)
101
- text = build_config_get(feature, ref, :ascii)
102
- return Cisco.find_ascii(text, token[-1], *token[0..-2])
81
+ if token.nil?
82
+ # Just get the whole output
83
+ return massage(show(ref.config_get, :structured), ref)
84
+ elsif token[0].kind_of?(Regexp)
85
+ return massage(Cisco.find_ascii(show(ref.config_get, :ascii),
86
+ token[-1],
87
+ *token[0..-2]), ref)
88
+ else
89
+ return massage(
90
+ config_get_handle_structured(token,
91
+ show(ref.config_get, :structured)),
92
+ ref)
93
+ end
94
+ end
103
95
 
96
+ # Attempt to massage the given value into the format specified by the
97
+ # given CmdRef object.
98
+ def massage(value, ref)
99
+ CiscoLogger.debug "Massaging '#{value}' (#{value.inspect})"
100
+ if value.is_a?(Array) && !ref.multiple
101
+ fail "Expected zero/one value but got '#{value}'" if value.length > 1
102
+ value = value[0]
103
+ end
104
+ if (value.nil? || value.empty?) && ref.default_value? && ref.auto_default
105
+ CiscoLogger.debug "Default: #{ref.default_value}"
106
+ return ref.default_value
107
+ end
108
+ return value unless ref.kind
109
+ case ref.kind
110
+ when :boolean
111
+ if value.nil? || value.empty?
112
+ value = false
113
+ elsif /^no / =~ value
114
+ value = false
104
115
  else
105
- result = build_config_get(feature, ref, :structured)
106
- return config_get_handle_structured(token, result)
116
+ value = true
107
117
  end
108
- elsif token.nil?
109
- return show(ref.config_get, :structured)
118
+ when :int
119
+ value = value.to_i unless value.nil?
120
+ when :string
121
+ value = '' if value.nil?
122
+ value = value.to_s.strip
110
123
  end
111
- fail TypeError("Unclear to handle config_get_token #{token}")
124
+ CiscoLogger.debug "Massaged to '#{value}'"
125
+ value
112
126
  end
113
127
 
114
128
  # Uses CommandReference to lookup the default value for a given
@@ -144,31 +158,7 @@ module Cisco
144
158
  def config_set(feature, name, *args)
145
159
  fail 'lazy_connect specified but did not request connect' unless @cmd_ref
146
160
  ref = @cmd_ref.lookup(feature, name)
147
- config_set = build_config_set(feature, ref, args)
148
- if config_set.is_a?(String)
149
- param_count = config_set.scan(/%/).length
150
- elsif config_set.is_a?(Array)
151
- param_count = config_set.join(' ').scan(/%/).length
152
- else
153
- fail TypeError, '%{config_set.class} not supported for config_set'
154
- end
155
- unless args[0].is_a? Hash
156
- if param_count != args.length
157
- fail ArgumentError, 'Wrong number of params - expected: ' \
158
- "#{param_count} actual: #{args.length}"
159
- end
160
- end
161
- if config_set.is_a?(String)
162
- config(sprintf(config_set, *args))
163
- elsif config_set.is_a?(Array)
164
- new_config_set = []
165
- config_set.each do |line|
166
- param_count = line.scan(/%/).length
167
- new_config_set << sprintf(line, *args.first(param_count))
168
- args = args[param_count..-1]
169
- end
170
- config(new_config_set)
171
- end
161
+ config(ref.config_set(*args))
172
162
  end
173
163
 
174
164
  # Clear the cache of CLI output results.
@@ -209,7 +199,10 @@ module Cisco
209
199
  # "hidden" API - used for UT but shouldn't be used elsewhere
210
200
  def connect(*args)
211
201
  @client = CiscoNxapi::NxapiClient.new(*args)
212
- @cmd_ref = CommandReference::CommandReference.new(product_id)
202
+ # Hard-code platform and cli for now
203
+ @cmd_ref = CommandReference.new(product: product_id,
204
+ platform: :nexus,
205
+ cli: true)
213
206
  cache_flush
214
207
  end
215
208
 
@@ -234,159 +227,6 @@ module Cisco
234
227
  @client.cache_auto = enable
235
228
  end
236
229
 
237
- # Helper method for converting token strings to regexps. This helper
238
- # facilitates non-standard regexp options like ignore-case.
239
- # Example inputs:
240
- # token = ["/%s/i", "/%s foo %s/", "/zzz/i"]
241
- # args = ["LoopBack2", "no", "bar"]
242
- # Expected outputs:
243
- # [/LoopBack2/i, /no foo bar/, /zzz/i]
244
- #
245
- def token_str_to_regexp(token, args)
246
- unless args[0].is_a? Hash
247
- expected_args = token.join.scan(/%/).length
248
- fail "Given #{args.length} args, but token #{token} requires " \
249
- "#{expected_args}" unless args.length == expected_args
250
- end
251
- # replace all %s with *args
252
- token.map! { |str| sprintf(str, *args.shift(str.scan(/%/).length)) }
253
- # convert all to Regexp objects
254
- token.map! do |str|
255
- if str[-2..-1] == '/i'
256
- Regexp.new(str[1..-3], Regexp::IGNORECASE)
257
- else
258
- Regexp.new(str[1..-2])
259
- end
260
- end
261
- token
262
- end
263
-
264
- # Helper method to replace <> place holders in the config_get_token
265
- # and config_get_token_append yaml entries.
266
- #
267
- # @param regexp [String][Array] regexp entry with <> placeholders
268
- # @param values [Hash] Hash of named values to replace each <>
269
- # @return [String]
270
- def replace_token_ids(regexp, values)
271
- final = replace_token_ids_string(regexp, values) if regexp.is_a?(String)
272
- final = replace_token_ids_array(regexp, values) if regexp.is_a?(Array)
273
- final
274
- end
275
-
276
- # @param regexp [String] regexp entry with <> placeholders
277
- # @param values [Hash] Hash of named values to replace each <>
278
- # @return [String]
279
- def replace_token_ids_string(regexp, values)
280
- replace = regexp.scan(/<(\S+)>/).flatten.map(&:to_sym)
281
- replace.each do |item|
282
- regexp = regexp.sub "<#{item}>",
283
- values[item].to_s if values.key?(item)
284
- end
285
- # Only return lines that actually replaced ids or did not have any
286
- # ids to replace. Implicit nil returned if not.
287
- return regexp if /<\S+>/.match(regexp).nil?
288
- end
289
-
290
- # @param regexp [Array] regexp entry with <> placeholders
291
- # @param values [Hash] Hash of named values to replace each <>
292
- # @return [String]
293
- def replace_token_ids_array(regexp, values)
294
- final_regexp = []
295
- regexp.each do |line|
296
- final_regexp.push(replace_token_ids_string(line, values))
297
- end
298
- final_regexp
299
- end
300
-
301
- # Helper method to build a multi-line config_get_token if
302
- # the feature, name contains a config_get_token_append entry.
303
- #
304
- # @param feature [String]
305
- # @param ref [CommandReference::CmdRef]
306
- # @return [String, Array]
307
- def build_config_get_token(feature, ref, args)
308
- fail 'lazy_connect specified but did not request connect' unless @cmd_ref
309
- # Why clone token? A bug in some ruby versions caused token to convert
310
- # to type Regexp unexpectedly. The clone hard copy resolved it.
311
-
312
- # If the options are presented as type Hash process as
313
- # key-value replacement pairs
314
- return ref.config_get_token.clone unless args[0].is_a?(Hash)
315
- options = args[0]
316
- token = []
317
- # Use _template yaml entry if config_get_token_append
318
- if ref.to_s[/config_get_token_append/]
319
- # Get yaml feature template:
320
- template = @cmd_ref.lookup(feature, '_template')
321
- # Process config_get_token: from template:
322
- token.push(replace_token_ids(template.config_get_token, options))
323
- # Process config_get_token_append sequence: from template:
324
- template.config_get_token_append.each do |line|
325
- token.push(replace_token_ids(line, options))
326
- end
327
- # Add feature->property config_get_token append line
328
- token.push(ref.config_get_token_append)
329
- else
330
- token.push(replace_token_ids(ref.config_get_token, options))
331
- end
332
- token.flatten!
333
- token.compact!
334
- token
335
- end
336
-
337
- # Helper method to use the feature, name config_get
338
- # if present else use feature, "template" config_get
339
- #
340
- # @param feature [String]
341
- # @param ref [CommandReference::CmdRef]
342
- # @param type [Symbol]
343
- # @return [String, Array]
344
- def build_config_get(feature, ref, type)
345
- fail 'lazy_connect specified but did not request connect' unless @cmd_ref
346
- # Use feature name config_get string if present
347
- # else use feature template: config_get
348
- if ref.hash.key?('config_get')
349
- return show(ref.config_get, type)
350
- else
351
- template = @cmd_ref.lookup(feature, '_template')
352
- return show(template.config_get, type)
353
- end
354
- end
355
-
356
- # Helper method to build a multi-line config_set if
357
- # the feature, name contains a config_get_set_append
358
- # yaml entry.
359
- #
360
- # @param feature [String]
361
- # @param ref [CommandReference::CmdRef]
362
- # @return [String, Array]
363
- def build_config_set(feature, ref, args)
364
- fail 'lazy_connect specified but did not request connect' unless @cmd_ref
365
- # If the options are presented as type Hash process as
366
- # key-value replacement pairs
367
- return ref.config_set unless args[0].is_a?(Hash)
368
- options = args[0]
369
- config_set = []
370
- # Use _template yaml entry if config_set_append
371
- if ref.to_s[/config_set_append/]
372
- # Get yaml feature template:
373
- template = @cmd_ref.lookup(feature, '_template')
374
- # Process config_set: from template:
375
- config_set.push(replace_token_ids(template.config_set, options))
376
- # Process config_set_append sequence: from template:
377
- template.config_set_append.each do |line|
378
- config_set.push(replace_token_ids(line, options))
379
- end
380
- # Add feature->property config_set append line
381
- config_set.push(replace_token_ids(ref.config_set_append, options))
382
- else
383
- config_set.push(replace_token_ids(ref.config_set, options))
384
- end
385
- config_set.flatten!
386
- config_set.compact!
387
- config_set
388
- end
389
-
390
230
  # Helper method for config_get().
391
231
  # @param token [Array, Hash] lookup sequence
392
232
  # @param result [Array, Hash] structured output from node
@@ -482,12 +322,7 @@ module Cisco
482
322
 
483
323
  # @return [String] such as "example.com"
484
324
  def domain_name
485
- result = config_get('dnsclient', 'domain_name')
486
- if result.nil?
487
- return ''
488
- else
489
- return result[0]
490
- end
325
+ config_get('dnsclient', 'domain_name')
491
326
  end
492
327
 
493
328
  # @return [Integer] System uptime, in seconds
@@ -495,7 +330,6 @@ module Cisco
495
330
  cache_flush
496
331
  t = config_get('show_system', 'uptime')
497
332
  fail 'failed to retrieve system uptime' if t.nil?
498
- t = t.shift
499
333
  # time units: t = ["0", "23", "15", "49"]
500
334
  t.map!(&:to_i)
501
335
  d, h, m, s = t
@@ -504,12 +338,7 @@ module Cisco
504
338
 
505
339
  # @return [String] timestamp of last reset time
506
340
  def last_reset_time
507
- output = config_get('show_version', 'last_reset_time')
508
- return '' if output.nil?
509
- # NX-OS may provide leading/trailing whitespace:
510
- # " Sat Oct 25 00:39:25 2014\n"
511
- # so be sure to strip() it down to the actual string.
512
- output.strip
341
+ config_get('show_version', 'last_reset_time')
513
342
  end
514
343
 
515
344
  # @return [String] such as "Reset Requested by CLI command reload"
@@ -537,29 +366,6 @@ module Cisco
537
366
  end
538
367
  end
539
368
 
540
- # Convenience wrapper for find_ascii. Operates under the assumption
541
- # that there will be zero or one matches for the given query
542
- # and returns the match string (or "") rather than an array.
543
- #
544
- # @raise [RuntimeError] if more than one match is found.
545
- #
546
- # @param body [String] The body of text to search
547
- # @param regex_query [Regex] The regular expression to match
548
- # @param parents [*Regex] zero or more regular expressions defining
549
- # the parent configs to filter by.
550
- # @return [String] the matching (sub)string or "" if no match.
551
- #
552
- # @example Get the domain name if any
553
- # domain_name = find_one_ascii(running_cfg, "ip domain-name (.*)")
554
- # => 'example.com'
555
- def find_one_ascii(body, regex_query, *parent_cfg)
556
- matches = find_ascii(body, regex_query, *parent_cfg)
557
- return '' if matches.nil?
558
- fail RuntimeError if matches.length > 1
559
- matches[0]
560
- end
561
- module_function :find_one_ascii
562
-
563
369
  # Method for working with hierarchical show command output such as
564
370
  # "show running-config". Searches the given multi-line string
565
371
  # for all matches to the given regex_query. If parents is provided,
@@ -1,6 +1,6 @@
1
1
  # September 2015, Glenn F. Matthews
2
2
  #
3
- # Copyright (c) 2014-2015 Cisco and/or its affiliates.
3
+ # Copyright (c) 2014-2016 Cisco and/or its affiliates.
4
4
  #
5
5
  # Licensed under the Apache License, Version 2.0 (the "License");
6
6
  # you may not use this file except in compliance with the License.
@@ -57,5 +57,9 @@ module Cisco
57
57
  def config_set(*args)
58
58
  node.config_set(*args)
59
59
  end
60
+
61
+ def show(*args)
62
+ node.show(*args)
63
+ end
60
64
  end
61
65
  end
@@ -2,7 +2,7 @@
2
2
  #
3
3
  # Jonathan Tripathy et al., September 2015
4
4
  #
5
- # Copyright (c) 2014-2015 Cisco and/or its affiliates.
5
+ # Copyright (c) 2014-2016 Cisco and/or its affiliates.
6
6
  #
7
7
  # Licensed under the Apache License, Version 2.0 (the "License");
8
8
  # you may not use this file except in compliance with the License.
@@ -43,7 +43,7 @@ module Cisco
43
43
 
44
44
  def source_interface
45
45
  source_interface = config_get('ntp_config', 'source_interface')
46
- source_interface = source_interface[0].downcase \
46
+ source_interface = source_interface.downcase \
47
47
  unless source_interface.nil?
48
48
  source_interface
49
49
  end
@@ -2,7 +2,7 @@
2
2
  #
3
3
  # Jonathan Tripathy et al., September 2015
4
4
  #
5
- # Copyright (c) 2014-2015 Cisco and/or its affiliates.
5
+ # Copyright (c) 2014-2016 Cisco and/or its affiliates.
6
6
  #
7
7
  # Licensed under the Apache License, Version 2.0 (the "License");
8
8
  # you may not use this file except in compliance with the License.
@@ -25,9 +25,19 @@ module Cisco
25
25
  def initialize(ntpserver_id, prefer, instantiate=true)
26
26
  @ntpserver_id = ntpserver_id.to_s
27
27
  @ntpserver_prefer = prefer
28
- unless @ntpserver_id[/^(?:[0-9]{1,3}\.){3}[0-9]{1,3}$/]
29
- fail ArgumentError, 'Invalid value(IP is not an IP address)'
28
+
29
+ unless @ntpserver_id =~ /^[a-zA-Z0-9\.\:]*$/
30
+ fail ArgumentError,
31
+ 'Invalid value (IPv4/IPv6 address contains invalid characters)'
32
+ end
33
+
34
+ begin
35
+ IPAddr.new(@ntpserver_id)
36
+ rescue
37
+ raise ArgumentError,
38
+ 'Invalid value (Name is not a valid single IPv4/IPv6 address)'
30
39
  end
40
+
31
41
  unless @ntpserver_prefer == true ||
32
42
  @ntpserver_prefer == false ||
33
43
  @ntpserver_prefer.nil?
@@ -39,10 +49,9 @@ module Cisco
39
49
  def self.ntpservers
40
50
  hash = {}
41
51
  ntpservers_list = config_get('ntp_server', 'server')
42
- return hash if ntpservers_list.nil?
52
+ return hash if ntpservers_list.empty?
43
53
 
44
54
  preferred_servers = config_get('ntp_server', 'prefer')
45
- preferred_servers = [] unless preferred_servers
46
55
 
47
56
  ntpservers_list.each do |id|
48
57
  hash[id] = NtpServer.new(id, preferred_servers.include?(id), false)