inspec 2.0.16 → 2.0.17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (480) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +101 -101
  3. data/CHANGELOG.md +2949 -2944
  4. data/Gemfile +55 -55
  5. data/LICENSE +14 -14
  6. data/MAINTAINERS.md +31 -31
  7. data/MAINTAINERS.toml +47 -47
  8. data/README.md +438 -438
  9. data/Rakefile +284 -284
  10. data/bin/inspec +12 -12
  11. data/docs/.gitignore +2 -2
  12. data/docs/README.md +40 -40
  13. data/docs/dsl_inspec.md +258 -258
  14. data/docs/dsl_resource.md +93 -93
  15. data/docs/glossary.md +99 -99
  16. data/docs/habitat.md +191 -191
  17. data/docs/inspec_and_friends.md +107 -107
  18. data/docs/matchers.md +165 -165
  19. data/docs/migration.md +293 -293
  20. data/docs/platforms.md +118 -118
  21. data/docs/plugin_kitchen_inspec.md +49 -49
  22. data/docs/profiles.md +370 -370
  23. data/docs/reporters.md +105 -105
  24. data/docs/resources/aide_conf.md.erb +75 -75
  25. data/docs/resources/apache.md.erb +67 -67
  26. data/docs/resources/apache_conf.md.erb +68 -68
  27. data/docs/resources/apt.md.erb +71 -71
  28. data/docs/resources/audit_policy.md.erb +47 -47
  29. data/docs/resources/auditd.md.erb +79 -79
  30. data/docs/resources/auditd_conf.md.erb +68 -68
  31. data/docs/resources/aws_cloudtrail_trail.md.erb +140 -140
  32. data/docs/resources/aws_cloudtrail_trails.md.erb +81 -81
  33. data/docs/resources/aws_cloudwatch_alarm.md.erb +86 -86
  34. data/docs/resources/aws_cloudwatch_log_metric_filter.md.erb +151 -151
  35. data/docs/resources/aws_ec2_instance.md.erb +106 -106
  36. data/docs/resources/aws_iam_access_key.md.erb +123 -123
  37. data/docs/resources/aws_iam_access_keys.md.erb +198 -198
  38. data/docs/resources/aws_iam_group.md.erb +46 -46
  39. data/docs/resources/aws_iam_groups.md.erb +43 -43
  40. data/docs/resources/aws_iam_password_policy.md.erb +76 -76
  41. data/docs/resources/aws_iam_policies.md.erb +82 -82
  42. data/docs/resources/aws_iam_policy.md.erb +146 -146
  43. data/docs/resources/aws_iam_role.md.erb +65 -65
  44. data/docs/resources/aws_iam_root_user.md.erb +58 -58
  45. data/docs/resources/aws_iam_user.md.erb +64 -64
  46. data/docs/resources/aws_iam_users.md.erb +89 -89
  47. data/docs/resources/aws_kms_keys.md.erb +84 -84
  48. data/docs/resources/aws_route_table.md.erb +47 -47
  49. data/docs/resources/aws_s3_bucket.md.erb +134 -134
  50. data/docs/resources/aws_security_group.md.erb +152 -152
  51. data/docs/resources/aws_security_groups.md.erb +92 -92
  52. data/docs/resources/aws_sns_topic.md.erb +62 -62
  53. data/docs/resources/aws_subnet.md.erb +133 -133
  54. data/docs/resources/aws_subnets.md.erb +126 -126
  55. data/docs/resources/aws_vpc.md.erb +120 -120
  56. data/docs/resources/aws_vpcs.md.erb +48 -48
  57. data/docs/resources/azure_generic_resource.md.erb +170 -139
  58. data/docs/resources/azure_resource_group.md.erb +284 -284
  59. data/docs/resources/azure_virtual_machine.md.erb +347 -314
  60. data/docs/resources/azure_virtual_machine_data_disk.md.erb +224 -182
  61. data/docs/resources/bash.md.erb +75 -75
  62. data/docs/resources/bond.md.erb +90 -90
  63. data/docs/resources/bridge.md.erb +57 -57
  64. data/docs/resources/bsd_service.md.erb +67 -67
  65. data/docs/resources/command.md.erb +138 -138
  66. data/docs/resources/cpan.md.erb +79 -79
  67. data/docs/resources/cran.md.erb +64 -64
  68. data/docs/resources/crontab.md.erb +88 -88
  69. data/docs/resources/csv.md.erb +54 -54
  70. data/docs/resources/dh_params.md.erb +217 -217
  71. data/docs/resources/directory.md.erb +30 -30
  72. data/docs/resources/docker.md.erb +164 -164
  73. data/docs/resources/docker_container.md.erb +104 -104
  74. data/docs/resources/docker_image.md.erb +94 -94
  75. data/docs/resources/docker_service.md.erb +114 -114
  76. data/docs/resources/elasticsearch.md.erb +242 -242
  77. data/docs/resources/etc_fstab.md.erb +125 -125
  78. data/docs/resources/etc_group.md.erb +75 -75
  79. data/docs/resources/etc_hosts.md.erb +78 -78
  80. data/docs/resources/etc_hosts_allow.md.erb +74 -74
  81. data/docs/resources/etc_hosts_deny.md.erb +74 -74
  82. data/docs/resources/file.md.erb +515 -515
  83. data/docs/resources/filesystem.md.erb +41 -41
  84. data/docs/resources/firewalld.md.erb +107 -107
  85. data/docs/resources/gem.md.erb +79 -79
  86. data/docs/resources/group.md.erb +61 -61
  87. data/docs/resources/grub_conf.md.erb +101 -101
  88. data/docs/resources/host.md.erb +78 -78
  89. data/docs/resources/http.md.erb +101 -101
  90. data/docs/resources/iis_app.md.erb +122 -122
  91. data/docs/resources/iis_site.md.erb +135 -135
  92. data/docs/resources/inetd_conf.md.erb +94 -94
  93. data/docs/resources/ini.md.erb +76 -76
  94. data/docs/resources/interface.md.erb +58 -58
  95. data/docs/resources/iptables.md.erb +64 -64
  96. data/docs/resources/json.md.erb +62 -62
  97. data/docs/resources/kernel_module.md.erb +107 -107
  98. data/docs/resources/kernel_parameter.md.erb +53 -53
  99. data/docs/resources/key_rsa.md.erb +85 -85
  100. data/docs/resources/launchd_service.md.erb +57 -57
  101. data/docs/resources/limits_conf.md.erb +75 -75
  102. data/docs/resources/login_def.md.erb +71 -71
  103. data/docs/resources/mount.md.erb +69 -69
  104. data/docs/resources/mssql_session.md.erb +60 -60
  105. data/docs/resources/mysql_conf.md.erb +99 -99
  106. data/docs/resources/mysql_session.md.erb +74 -74
  107. data/docs/resources/nginx.md.erb +79 -79
  108. data/docs/resources/nginx_conf.md.erb +128 -128
  109. data/docs/resources/npm.md.erb +60 -60
  110. data/docs/resources/ntp_conf.md.erb +60 -60
  111. data/docs/resources/oneget.md.erb +53 -53
  112. data/docs/resources/oracledb_session.md.erb +52 -52
  113. data/docs/resources/os.md.erb +141 -141
  114. data/docs/resources/os_env.md.erb +78 -78
  115. data/docs/resources/package.md.erb +120 -120
  116. data/docs/resources/packages.md.erb +67 -67
  117. data/docs/resources/parse_config.md.erb +103 -103
  118. data/docs/resources/parse_config_file.md.erb +138 -138
  119. data/docs/resources/passwd.md.erb +141 -141
  120. data/docs/resources/pip.md.erb +67 -67
  121. data/docs/resources/port.md.erb +137 -137
  122. data/docs/resources/postgres_conf.md.erb +79 -79
  123. data/docs/resources/postgres_hba_conf.md.erb +93 -93
  124. data/docs/resources/postgres_ident_conf.md.erb +76 -76
  125. data/docs/resources/postgres_session.md.erb +69 -69
  126. data/docs/resources/powershell.md.erb +102 -102
  127. data/docs/resources/processes.md.erb +109 -109
  128. data/docs/resources/rabbitmq_config.md.erb +41 -41
  129. data/docs/resources/registry_key.md.erb +158 -158
  130. data/docs/resources/runit_service.md.erb +57 -57
  131. data/docs/resources/security_policy.md.erb +47 -47
  132. data/docs/resources/service.md.erb +121 -121
  133. data/docs/resources/shadow.md.erb +144 -144
  134. data/docs/resources/ssh_config.md.erb +80 -80
  135. data/docs/resources/sshd_config.md.erb +83 -83
  136. data/docs/resources/ssl.md.erb +119 -119
  137. data/docs/resources/sys_info.md.erb +42 -42
  138. data/docs/resources/systemd_service.md.erb +57 -57
  139. data/docs/resources/sysv_service.md.erb +57 -57
  140. data/docs/resources/upstart_service.md.erb +57 -57
  141. data/docs/resources/user.md.erb +140 -140
  142. data/docs/resources/users.md.erb +127 -127
  143. data/docs/resources/vbscript.md.erb +55 -55
  144. data/docs/resources/virtualization.md.erb +57 -57
  145. data/docs/resources/windows_feature.md.erb +47 -47
  146. data/docs/resources/windows_hotfix.md.erb +53 -53
  147. data/docs/resources/windows_task.md.erb +95 -95
  148. data/docs/resources/wmi.md.erb +81 -81
  149. data/docs/resources/x509_certificate.md.erb +151 -151
  150. data/docs/resources/xinetd_conf.md.erb +156 -156
  151. data/docs/resources/xml.md.erb +85 -85
  152. data/docs/resources/yaml.md.erb +69 -69
  153. data/docs/resources/yum.md.erb +98 -98
  154. data/docs/resources/zfs_dataset.md.erb +53 -53
  155. data/docs/resources/zfs_pool.md.erb +47 -47
  156. data/docs/ruby_usage.md +203 -203
  157. data/docs/shared/matcher_be.md.erb +1 -1
  158. data/docs/shared/matcher_cmp.md.erb +43 -43
  159. data/docs/shared/matcher_eq.md.erb +3 -3
  160. data/docs/shared/matcher_include.md.erb +1 -1
  161. data/docs/shared/matcher_match.md.erb +1 -1
  162. data/docs/shell.md +172 -172
  163. data/examples/README.md +8 -8
  164. data/examples/inheritance/README.md +65 -65
  165. data/examples/inheritance/controls/example.rb +14 -14
  166. data/examples/inheritance/inspec.yml +15 -15
  167. data/examples/kitchen-ansible/.kitchen.yml +25 -25
  168. data/examples/kitchen-ansible/Gemfile +19 -19
  169. data/examples/kitchen-ansible/README.md +53 -53
  170. data/examples/kitchen-ansible/files/nginx.repo +6 -6
  171. data/examples/kitchen-ansible/tasks/main.yml +16 -16
  172. data/examples/kitchen-ansible/test/integration/default/default.yml +5 -5
  173. data/examples/kitchen-ansible/test/integration/default/web_spec.rb +28 -28
  174. data/examples/kitchen-chef/.kitchen.yml +20 -20
  175. data/examples/kitchen-chef/Berksfile +3 -3
  176. data/examples/kitchen-chef/Gemfile +19 -19
  177. data/examples/kitchen-chef/README.md +27 -27
  178. data/examples/kitchen-chef/metadata.rb +7 -7
  179. data/examples/kitchen-chef/recipes/default.rb +6 -6
  180. data/examples/kitchen-chef/recipes/nginx.rb +30 -30
  181. data/examples/kitchen-chef/test/integration/default/web_spec.rb +28 -28
  182. data/examples/kitchen-puppet/.kitchen.yml +22 -22
  183. data/examples/kitchen-puppet/Gemfile +20 -20
  184. data/examples/kitchen-puppet/Puppetfile +25 -25
  185. data/examples/kitchen-puppet/README.md +53 -53
  186. data/examples/kitchen-puppet/manifests/site.pp +33 -33
  187. data/examples/kitchen-puppet/metadata.json +11 -11
  188. data/examples/kitchen-puppet/test/integration/default/web_spec.rb +28 -28
  189. data/examples/meta-profile/README.md +37 -37
  190. data/examples/meta-profile/controls/example.rb +13 -13
  191. data/examples/meta-profile/inspec.yml +13 -13
  192. data/examples/profile-attribute.yml +2 -2
  193. data/examples/profile-attribute/README.md +14 -14
  194. data/examples/profile-attribute/controls/example.rb +11 -11
  195. data/examples/profile-attribute/inspec.yml +8 -8
  196. data/examples/profile-aws/controls/iam_password_policy_expiration.rb +8 -8
  197. data/examples/profile-aws/controls/iam_password_policy_max_age.rb +8 -8
  198. data/examples/profile-aws/controls/iam_root_user_mfa.rb +8 -8
  199. data/examples/profile-aws/controls/iam_users_access_key_age.rb +8 -8
  200. data/examples/profile-aws/controls/iam_users_console_users_mfa.rb +8 -8
  201. data/examples/profile-aws/inspec.yml +11 -11
  202. data/examples/profile-azure/controls/azure_resource_group_example.rb +24 -24
  203. data/examples/profile-azure/controls/azure_vm_example.rb +29 -29
  204. data/examples/profile-azure/inspec.yml +11 -11
  205. data/examples/profile-sensitive/README.md +29 -29
  206. data/examples/profile-sensitive/controls/sensitive-failures.rb +9 -9
  207. data/examples/profile-sensitive/controls/sensitive.rb +9 -9
  208. data/examples/profile-sensitive/inspec.yml +8 -8
  209. data/examples/profile/README.md +48 -48
  210. data/examples/profile/controls/example.rb +23 -23
  211. data/examples/profile/controls/gordon.rb +36 -36
  212. data/examples/profile/controls/meta.rb +34 -34
  213. data/examples/profile/inspec.yml +10 -10
  214. data/examples/profile/libraries/gordon_config.rb +53 -53
  215. data/inspec.gemspec +47 -47
  216. data/lib/bundles/README.md +3 -3
  217. data/lib/bundles/inspec-artifact.rb +7 -7
  218. data/lib/bundles/inspec-artifact/README.md +1 -1
  219. data/lib/bundles/inspec-artifact/cli.rb +277 -277
  220. data/lib/bundles/inspec-compliance.rb +16 -16
  221. data/lib/bundles/inspec-compliance/.kitchen.yml +20 -20
  222. data/lib/bundles/inspec-compliance/README.md +185 -185
  223. data/lib/bundles/inspec-compliance/api.rb +316 -316
  224. data/lib/bundles/inspec-compliance/api/login.rb +152 -152
  225. data/lib/bundles/inspec-compliance/bootstrap.sh +41 -41
  226. data/lib/bundles/inspec-compliance/cli.rb +254 -254
  227. data/lib/bundles/inspec-compliance/configuration.rb +103 -103
  228. data/lib/bundles/inspec-compliance/http.rb +86 -86
  229. data/lib/bundles/inspec-compliance/support.rb +36 -36
  230. data/lib/bundles/inspec-compliance/target.rb +98 -98
  231. data/lib/bundles/inspec-compliance/test/integration/default/cli.rb +93 -93
  232. data/lib/bundles/inspec-habitat.rb +12 -12
  233. data/lib/bundles/inspec-habitat/cli.rb +36 -36
  234. data/lib/bundles/inspec-habitat/log.rb +10 -10
  235. data/lib/bundles/inspec-habitat/profile.rb +390 -390
  236. data/lib/bundles/inspec-init.rb +8 -8
  237. data/lib/bundles/inspec-init/README.md +31 -31
  238. data/lib/bundles/inspec-init/cli.rb +97 -97
  239. data/lib/bundles/inspec-init/templates/profile/README.md +3 -3
  240. data/lib/bundles/inspec-init/templates/profile/controls/example.rb +19 -19
  241. data/lib/bundles/inspec-init/templates/profile/inspec.yml +8 -8
  242. data/lib/bundles/inspec-supermarket.rb +13 -13
  243. data/lib/bundles/inspec-supermarket/README.md +45 -45
  244. data/lib/bundles/inspec-supermarket/api.rb +84 -84
  245. data/lib/bundles/inspec-supermarket/cli.rb +73 -73
  246. data/lib/bundles/inspec-supermarket/target.rb +34 -34
  247. data/lib/fetchers/git.rb +163 -163
  248. data/lib/fetchers/local.rb +74 -74
  249. data/lib/fetchers/mock.rb +35 -35
  250. data/lib/fetchers/url.rb +204 -204
  251. data/lib/inspec.rb +24 -24
  252. data/lib/inspec/archive/tar.rb +29 -29
  253. data/lib/inspec/archive/zip.rb +19 -19
  254. data/lib/inspec/backend.rb +92 -92
  255. data/lib/inspec/base_cli.rb +350 -333
  256. data/lib/inspec/cached_fetcher.rb +66 -66
  257. data/lib/inspec/cli.rb +292 -302
  258. data/lib/inspec/completions/bash.sh.erb +45 -45
  259. data/lib/inspec/completions/fish.sh.erb +34 -34
  260. data/lib/inspec/completions/zsh.sh.erb +61 -61
  261. data/lib/inspec/control_eval_context.rb +179 -179
  262. data/lib/inspec/dependencies/cache.rb +72 -72
  263. data/lib/inspec/dependencies/dependency_set.rb +92 -92
  264. data/lib/inspec/dependencies/lockfile.rb +115 -115
  265. data/lib/inspec/dependencies/requirement.rb +123 -123
  266. data/lib/inspec/dependencies/resolver.rb +86 -86
  267. data/lib/inspec/describe.rb +27 -27
  268. data/lib/inspec/dsl.rb +66 -66
  269. data/lib/inspec/dsl_shared.rb +33 -33
  270. data/lib/inspec/env_printer.rb +157 -157
  271. data/lib/inspec/errors.rb +13 -13
  272. data/lib/inspec/exceptions.rb +12 -12
  273. data/lib/inspec/expect.rb +45 -45
  274. data/lib/inspec/fetcher.rb +45 -45
  275. data/lib/inspec/file_provider.rb +275 -275
  276. data/lib/inspec/formatters.rb +3 -3
  277. data/lib/inspec/formatters/base.rb +250 -250
  278. data/lib/inspec/formatters/json_rspec.rb +20 -20
  279. data/lib/inspec/formatters/show_progress.rb +12 -12
  280. data/lib/inspec/library_eval_context.rb +58 -58
  281. data/lib/inspec/log.rb +11 -11
  282. data/lib/inspec/metadata.rb +247 -247
  283. data/lib/inspec/method_source.rb +24 -24
  284. data/lib/inspec/objects.rb +14 -14
  285. data/lib/inspec/objects/attribute.rb +65 -65
  286. data/lib/inspec/objects/control.rb +61 -61
  287. data/lib/inspec/objects/describe.rb +92 -92
  288. data/lib/inspec/objects/each_loop.rb +36 -36
  289. data/lib/inspec/objects/list.rb +15 -15
  290. data/lib/inspec/objects/or_test.rb +40 -40
  291. data/lib/inspec/objects/ruby_helper.rb +15 -15
  292. data/lib/inspec/objects/tag.rb +27 -27
  293. data/lib/inspec/objects/test.rb +87 -87
  294. data/lib/inspec/objects/value.rb +27 -27
  295. data/lib/inspec/plugins.rb +60 -60
  296. data/lib/inspec/plugins/cli.rb +24 -24
  297. data/lib/inspec/plugins/fetcher.rb +86 -86
  298. data/lib/inspec/plugins/resource.rb +133 -133
  299. data/lib/inspec/plugins/secret.rb +15 -15
  300. data/lib/inspec/plugins/source_reader.rb +40 -40
  301. data/lib/inspec/polyfill.rb +12 -12
  302. data/lib/inspec/profile.rb +510 -510
  303. data/lib/inspec/profile_context.rb +207 -207
  304. data/lib/inspec/profile_vendor.rb +66 -66
  305. data/lib/inspec/reporters.rb +50 -50
  306. data/lib/inspec/reporters/base.rb +24 -24
  307. data/lib/inspec/reporters/cli.rb +356 -356
  308. data/lib/inspec/reporters/json.rb +116 -116
  309. data/lib/inspec/reporters/json_min.rb +48 -48
  310. data/lib/inspec/reporters/junit.rb +77 -77
  311. data/lib/inspec/require_loader.rb +33 -33
  312. data/lib/inspec/resource.rb +186 -186
  313. data/lib/inspec/rule.rb +266 -266
  314. data/lib/inspec/runner.rb +344 -344
  315. data/lib/inspec/runner_mock.rb +41 -41
  316. data/lib/inspec/runner_rspec.rb +174 -174
  317. data/lib/inspec/runtime_profile.rb +26 -26
  318. data/lib/inspec/schema.rb +213 -213
  319. data/lib/inspec/secrets.rb +19 -19
  320. data/lib/inspec/secrets/yaml.rb +30 -30
  321. data/lib/inspec/shell.rb +220 -223
  322. data/lib/inspec/shell_detector.rb +90 -90
  323. data/lib/inspec/source_reader.rb +29 -29
  324. data/lib/inspec/version.rb +8 -8
  325. data/lib/matchers/matchers.rb +339 -339
  326. data/lib/resource_support/aws.rb +40 -40
  327. data/lib/resource_support/aws/aws_backend_base.rb +12 -12
  328. data/lib/resource_support/aws/aws_backend_factory_mixin.rb +12 -12
  329. data/lib/resource_support/aws/aws_plural_resource_mixin.rb +21 -21
  330. data/lib/resource_support/aws/aws_resource_mixin.rb +66 -66
  331. data/lib/resource_support/aws/aws_singular_resource_mixin.rb +24 -24
  332. data/lib/resources/aide_conf.rb +160 -160
  333. data/lib/resources/apache.rb +48 -48
  334. data/lib/resources/apache_conf.rb +156 -156
  335. data/lib/resources/apt.rb +149 -149
  336. data/lib/resources/audit_policy.rb +63 -63
  337. data/lib/resources/auditd.rb +231 -231
  338. data/lib/resources/auditd_conf.rb +55 -55
  339. data/lib/resources/aws/aws_cloudtrail_trail.rb +77 -77
  340. data/lib/resources/aws/aws_cloudtrail_trails.rb +47 -47
  341. data/lib/resources/aws/aws_cloudwatch_alarm.rb +62 -62
  342. data/lib/resources/aws/aws_cloudwatch_log_metric_filter.rb +100 -100
  343. data/lib/resources/aws/aws_ec2_instance.rb +157 -157
  344. data/lib/resources/aws/aws_iam_access_key.rb +106 -106
  345. data/lib/resources/aws/aws_iam_access_keys.rb +144 -144
  346. data/lib/resources/aws/aws_iam_group.rb +56 -56
  347. data/lib/resources/aws/aws_iam_groups.rb +45 -45
  348. data/lib/resources/aws/aws_iam_password_policy.rb +116 -116
  349. data/lib/resources/aws/aws_iam_policies.rb +46 -46
  350. data/lib/resources/aws/aws_iam_policy.rb +119 -119
  351. data/lib/resources/aws/aws_iam_role.rb +51 -51
  352. data/lib/resources/aws/aws_iam_root_user.rb +60 -60
  353. data/lib/resources/aws/aws_iam_user.rb +111 -111
  354. data/lib/resources/aws/aws_iam_users.rb +96 -96
  355. data/lib/resources/aws/aws_kms_keys.rb +46 -46
  356. data/lib/resources/aws/aws_route_table.rb +61 -61
  357. data/lib/resources/aws/aws_s3_bucket.rb +115 -115
  358. data/lib/resources/aws/aws_security_group.rb +93 -93
  359. data/lib/resources/aws/aws_security_groups.rb +68 -68
  360. data/lib/resources/aws/aws_sns_topic.rb +53 -53
  361. data/lib/resources/aws/aws_subnet.rb +88 -88
  362. data/lib/resources/aws/aws_subnets.rb +53 -53
  363. data/lib/resources/aws/aws_vpc.rb +69 -69
  364. data/lib/resources/aws/aws_vpcs.rb +45 -45
  365. data/lib/resources/azure/azure_backend.rb +377 -377
  366. data/lib/resources/azure/azure_generic_resource.rb +59 -59
  367. data/lib/resources/azure/azure_resource_group.rb +152 -152
  368. data/lib/resources/azure/azure_virtual_machine.rb +264 -264
  369. data/lib/resources/azure/azure_virtual_machine_data_disk.rb +136 -136
  370. data/lib/resources/bash.rb +35 -35
  371. data/lib/resources/bond.rb +68 -68
  372. data/lib/resources/bridge.rb +122 -122
  373. data/lib/resources/command.rb +69 -69
  374. data/lib/resources/cpan.rb +58 -58
  375. data/lib/resources/cran.rb +64 -64
  376. data/lib/resources/crontab.rb +170 -170
  377. data/lib/resources/csv.rb +60 -60
  378. data/lib/resources/dh_params.rb +82 -82
  379. data/lib/resources/directory.rb +25 -25
  380. data/lib/resources/docker.rb +236 -236
  381. data/lib/resources/docker_container.rb +89 -89
  382. data/lib/resources/docker_image.rb +83 -83
  383. data/lib/resources/docker_object.rb +57 -57
  384. data/lib/resources/docker_service.rb +90 -90
  385. data/lib/resources/elasticsearch.rb +169 -169
  386. data/lib/resources/etc_fstab.rb +102 -102
  387. data/lib/resources/etc_group.rb +156 -156
  388. data/lib/resources/etc_hosts.rb +81 -81
  389. data/lib/resources/etc_hosts_allow_deny.rb +123 -123
  390. data/lib/resources/file.rb +298 -298
  391. data/lib/resources/filesystem.rb +31 -31
  392. data/lib/resources/firewalld.rb +144 -144
  393. data/lib/resources/gem.rb +70 -70
  394. data/lib/resources/groups.rb +215 -215
  395. data/lib/resources/grub_conf.rb +237 -237
  396. data/lib/resources/host.rb +300 -300
  397. data/lib/resources/http.rb +250 -250
  398. data/lib/resources/iis_app.rb +104 -104
  399. data/lib/resources/iis_site.rb +148 -148
  400. data/lib/resources/inetd_conf.rb +62 -62
  401. data/lib/resources/ini.rb +29 -29
  402. data/lib/resources/interface.rb +129 -129
  403. data/lib/resources/iptables.rb +69 -69
  404. data/lib/resources/json.rb +117 -117
  405. data/lib/resources/kernel_module.rb +107 -107
  406. data/lib/resources/kernel_parameter.rb +58 -58
  407. data/lib/resources/key_rsa.rb +67 -67
  408. data/lib/resources/limits_conf.rb +55 -55
  409. data/lib/resources/login_def.rb +66 -66
  410. data/lib/resources/mount.rb +88 -88
  411. data/lib/resources/mssql_session.rb +101 -101
  412. data/lib/resources/mysql.rb +81 -81
  413. data/lib/resources/mysql_conf.rb +134 -134
  414. data/lib/resources/mysql_session.rb +71 -71
  415. data/lib/resources/nginx.rb +96 -96
  416. data/lib/resources/nginx_conf.rb +227 -227
  417. data/lib/resources/npm.rb +48 -48
  418. data/lib/resources/ntp_conf.rb +58 -58
  419. data/lib/resources/oneget.rb +71 -71
  420. data/lib/resources/oracledb_session.rb +139 -139
  421. data/lib/resources/os.rb +36 -36
  422. data/lib/resources/os_env.rb +76 -76
  423. data/lib/resources/package.rb +363 -363
  424. data/lib/resources/packages.rb +111 -111
  425. data/lib/resources/parse_config.rb +116 -116
  426. data/lib/resources/passwd.rb +74 -74
  427. data/lib/resources/pip.rb +89 -89
  428. data/lib/resources/platform.rb +109 -109
  429. data/lib/resources/port.rb +771 -771
  430. data/lib/resources/postgres.rb +130 -130
  431. data/lib/resources/postgres_conf.rb +121 -121
  432. data/lib/resources/postgres_hba_conf.rb +100 -100
  433. data/lib/resources/postgres_ident_conf.rb +78 -78
  434. data/lib/resources/postgres_session.rb +71 -71
  435. data/lib/resources/powershell.rb +57 -57
  436. data/lib/resources/processes.rb +204 -204
  437. data/lib/resources/rabbitmq_conf.rb +52 -52
  438. data/lib/resources/registry_key.rb +296 -296
  439. data/lib/resources/security_policy.rb +180 -180
  440. data/lib/resources/service.rb +789 -789
  441. data/lib/resources/shadow.rb +140 -140
  442. data/lib/resources/ssh_conf.rb +102 -102
  443. data/lib/resources/ssl.rb +99 -99
  444. data/lib/resources/sys_info.rb +28 -28
  445. data/lib/resources/toml.rb +32 -32
  446. data/lib/resources/users.rb +654 -654
  447. data/lib/resources/vbscript.rb +69 -69
  448. data/lib/resources/virtualization.rb +251 -251
  449. data/lib/resources/windows_feature.rb +84 -84
  450. data/lib/resources/windows_hotfix.rb +35 -35
  451. data/lib/resources/windows_task.rb +105 -105
  452. data/lib/resources/wmi.rb +113 -113
  453. data/lib/resources/x509_certificate.rb +143 -143
  454. data/lib/resources/xinetd.rb +111 -111
  455. data/lib/resources/xml.rb +46 -46
  456. data/lib/resources/yaml.rb +47 -47
  457. data/lib/resources/yum.rb +180 -180
  458. data/lib/resources/zfs_dataset.rb +60 -60
  459. data/lib/resources/zfs_pool.rb +49 -49
  460. data/lib/source_readers/flat.rb +39 -39
  461. data/lib/source_readers/inspec.rb +75 -75
  462. data/lib/utils/command_wrapper.rb +27 -27
  463. data/lib/utils/convert.rb +12 -12
  464. data/lib/utils/database_helpers.rb +77 -77
  465. data/lib/utils/erlang_parser.rb +192 -192
  466. data/lib/utils/filter.rb +272 -272
  467. data/lib/utils/filter_array.rb +27 -27
  468. data/lib/utils/find_files.rb +44 -44
  469. data/lib/utils/hash.rb +41 -41
  470. data/lib/utils/json_log.rb +18 -18
  471. data/lib/utils/latest_version.rb +22 -22
  472. data/lib/utils/modulator.rb +12 -12
  473. data/lib/utils/nginx_parser.rb +85 -85
  474. data/lib/utils/object_traversal.rb +49 -49
  475. data/lib/utils/parser.rb +274 -274
  476. data/lib/utils/plugin_registry.rb +93 -93
  477. data/lib/utils/simpleconfig.rb +120 -120
  478. data/lib/utils/spdx.rb +13 -13
  479. data/lib/utils/spdx.txt +343 -343
  480. metadata +1 -1
@@ -1,61 +1,61 @@
1
- class AwsRouteTable < Inspec.resource(1)
2
- name 'aws_route_table'
3
- desc 'Verifies settings for an AWS Route Table'
4
- example "
5
- describe aws_route_table do
6
- its('route_table_id') { should cmp 'rtb-2c60ec44' }
7
- end
8
- "
9
- supports platform: 'aws'
10
-
11
- include AwsSingularResourceMixin
12
-
13
- def to_s
14
- "Route Table #{@route_table_id}"
15
- end
16
-
17
- attr_reader :route_table_id, :vpc_id
18
-
19
- private
20
-
21
- def validate_params(raw_params)
22
- validated_params = check_resource_param_names(
23
- raw_params: raw_params,
24
- allowed_params: [:route_table_id],
25
- allowed_scalar_name: :route_table_id,
26
- allowed_scalar_type: String,
27
- )
28
-
29
- if validated_params.key?(:route_table_id) && validated_params[:route_table_id] !~ /^rtb\-[0-9a-f]{8}/
30
- raise ArgumentError, 'aws_route_table Route Table ID must be in the' \
31
- ' format "rtb-" followed by 8 hexadecimal characters.'
32
- end
33
-
34
- validated_params
35
- end
36
-
37
- def fetch_from_api
38
- backend = BackendFactory.create(inspec_runner)
39
-
40
- if @route_table_id.nil?
41
- args = nil
42
- else
43
- args = { filters: [{ name: 'route-table-id', values: [@route_table_id] }] }
44
- end
45
-
46
- resp = backend.describe_route_tables(args)
47
- routetable = resp.to_h[:route_tables]
48
- @exists = !routetable.empty?
49
- end
50
-
51
- class Backend
52
- class AwsClientApi < AwsBackendBase
53
- BackendFactory.set_default_backend(self)
54
- self.aws_client_class = Aws::EC2::Client
55
-
56
- def describe_route_tables(query)
57
- aws_service_client.describe_route_tables(query)
58
- end
59
- end
60
- end
61
- end
1
+ class AwsRouteTable < Inspec.resource(1)
2
+ name 'aws_route_table'
3
+ desc 'Verifies settings for an AWS Route Table'
4
+ example "
5
+ describe aws_route_table do
6
+ its('route_table_id') { should cmp 'rtb-2c60ec44' }
7
+ end
8
+ "
9
+ supports platform: 'aws'
10
+
11
+ include AwsSingularResourceMixin
12
+
13
+ def to_s
14
+ "Route Table #{@route_table_id}"
15
+ end
16
+
17
+ attr_reader :route_table_id, :vpc_id
18
+
19
+ private
20
+
21
+ def validate_params(raw_params)
22
+ validated_params = check_resource_param_names(
23
+ raw_params: raw_params,
24
+ allowed_params: [:route_table_id],
25
+ allowed_scalar_name: :route_table_id,
26
+ allowed_scalar_type: String,
27
+ )
28
+
29
+ if validated_params.key?(:route_table_id) && validated_params[:route_table_id] !~ /^rtb\-[0-9a-f]{8}/
30
+ raise ArgumentError, 'aws_route_table Route Table ID must be in the' \
31
+ ' format "rtb-" followed by 8 hexadecimal characters.'
32
+ end
33
+
34
+ validated_params
35
+ end
36
+
37
+ def fetch_from_api
38
+ backend = BackendFactory.create(inspec_runner)
39
+
40
+ if @route_table_id.nil?
41
+ args = nil
42
+ else
43
+ args = { filters: [{ name: 'route-table-id', values: [@route_table_id] }] }
44
+ end
45
+
46
+ resp = backend.describe_route_tables(args)
47
+ routetable = resp.to_h[:route_tables]
48
+ @exists = !routetable.empty?
49
+ end
50
+
51
+ class Backend
52
+ class AwsClientApi < AwsBackendBase
53
+ BackendFactory.set_default_backend(self)
54
+ self.aws_client_class = Aws::EC2::Client
55
+
56
+ def describe_route_tables(query)
57
+ aws_service_client.describe_route_tables(query)
58
+ end
59
+ end
60
+ end
61
+ end
@@ -1,115 +1,115 @@
1
- # author: Matthew Dromazos
2
- class AwsS3Bucket < Inspec.resource(1)
3
- name 'aws_s3_bucket'
4
- desc 'Verifies settings for a s3 bucket'
5
- example "
6
- describe aws_s3_bucket(bucket_name: 'test_bucket') do
7
- it { should exist }
8
- end
9
- "
10
- supports platform: 'aws'
11
-
12
- include AwsSingularResourceMixin
13
- attr_reader :bucket_name, :has_access_logging_enabled, :region
14
-
15
- def to_s
16
- "S3 Bucket #{@bucket_name}"
17
- end
18
-
19
- def bucket_acl
20
- catch_aws_errors do
21
- @bucket_acl ||= BackendFactory.create(inspec_runner).get_bucket_acl(bucket: bucket_name).grants
22
- end
23
- end
24
-
25
- def bucket_policy
26
- @bucket_policy ||= fetch_bucket_policy
27
- end
28
-
29
- # RSpec will alias this to be_public
30
- def public?
31
- # first line just for formatting
32
- false || \
33
- bucket_acl.any? { |g| g.grantee.type == 'Group' && g.grantee.uri =~ /AllUsers/ } || \
34
- bucket_acl.any? { |g| g.grantee.type == 'Group' && g.grantee.uri =~ /AuthenticatedUsers/ } || \
35
- bucket_policy.any? { |s| s.effect == 'Allow' && s.principal == '*' }
36
- end
37
-
38
- def has_access_logging_enabled?
39
- return unless @exists
40
- catch_aws_errors do
41
- @has_access_logging_enabled ||= !BackendFactory.create(inspec_runner).get_bucket_logging(bucket: bucket_name).logging_enabled.nil?
42
- end
43
- end
44
-
45
- private
46
-
47
- def validate_params(raw_params)
48
- validated_params = check_resource_param_names(
49
- raw_params: raw_params,
50
- allowed_params: [:bucket_name],
51
- allowed_scalar_name: :bucket_name,
52
- allowed_scalar_type: String,
53
- )
54
- if validated_params.empty? or !validated_params.key?(:bucket_name)
55
- raise ArgumentError, 'You must provide a bucket_name to aws_s3_bucket.'
56
- end
57
-
58
- validated_params
59
- end
60
-
61
- def fetch_from_api
62
- backend = BackendFactory.create(inspec_runner)
63
-
64
- # Since there is no basic "get_bucket" API call, use the
65
- # region fetch as the existence check.
66
- begin
67
- @region = backend.get_bucket_location(bucket: bucket_name).location_constraint
68
- rescue Aws::S3::Errors::NoSuchBucket
69
- @exists = false
70
- return
71
- end
72
- @exists = true
73
- end
74
-
75
- def fetch_bucket_policy
76
- backend = BackendFactory.create(inspec_runner)
77
- catch_aws_errors do
78
- begin
79
- # AWS SDK returns a StringIO, we have to read()
80
- raw_policy = backend.get_bucket_policy(bucket: bucket_name).policy
81
- return JSON.parse(raw_policy.read)['Statement'].map do |statement|
82
- lowercase_hash = {}
83
- statement.each_key { |k| lowercase_hash[k.downcase] = statement[k] }
84
- @bucket_policy = OpenStruct.new(lowercase_hash)
85
- end
86
- rescue Aws::S3::Errors::NoSuchBucketPolicy
87
- @bucket_policy = []
88
- end
89
- end
90
- end
91
-
92
- # Uses the SDK API to really talk to AWS
93
- class Backend
94
- class AwsClientApi < AwsBackendBase
95
- BackendFactory.set_default_backend(self)
96
- self.aws_client_class = Aws::S3::Client
97
-
98
- def get_bucket_acl(query)
99
- aws_service_client.get_bucket_acl(query)
100
- end
101
-
102
- def get_bucket_location(query)
103
- aws_service_client.get_bucket_location(query)
104
- end
105
-
106
- def get_bucket_policy(query)
107
- aws_service_client.get_bucket_policy(query)
108
- end
109
-
110
- def get_bucket_logging(query)
111
- aws_service_client.get_bucket_logging(query)
112
- end
113
- end
114
- end
115
- end
1
+ # author: Matthew Dromazos
2
+ class AwsS3Bucket < Inspec.resource(1)
3
+ name 'aws_s3_bucket'
4
+ desc 'Verifies settings for a s3 bucket'
5
+ example "
6
+ describe aws_s3_bucket(bucket_name: 'test_bucket') do
7
+ it { should exist }
8
+ end
9
+ "
10
+ supports platform: 'aws'
11
+
12
+ include AwsSingularResourceMixin
13
+ attr_reader :bucket_name, :has_access_logging_enabled, :region
14
+
15
+ def to_s
16
+ "S3 Bucket #{@bucket_name}"
17
+ end
18
+
19
+ def bucket_acl
20
+ catch_aws_errors do
21
+ @bucket_acl ||= BackendFactory.create(inspec_runner).get_bucket_acl(bucket: bucket_name).grants
22
+ end
23
+ end
24
+
25
+ def bucket_policy
26
+ @bucket_policy ||= fetch_bucket_policy
27
+ end
28
+
29
+ # RSpec will alias this to be_public
30
+ def public?
31
+ # first line just for formatting
32
+ false || \
33
+ bucket_acl.any? { |g| g.grantee.type == 'Group' && g.grantee.uri =~ /AllUsers/ } || \
34
+ bucket_acl.any? { |g| g.grantee.type == 'Group' && g.grantee.uri =~ /AuthenticatedUsers/ } || \
35
+ bucket_policy.any? { |s| s.effect == 'Allow' && s.principal == '*' }
36
+ end
37
+
38
+ def has_access_logging_enabled?
39
+ return unless @exists
40
+ catch_aws_errors do
41
+ @has_access_logging_enabled ||= !BackendFactory.create(inspec_runner).get_bucket_logging(bucket: bucket_name).logging_enabled.nil?
42
+ end
43
+ end
44
+
45
+ private
46
+
47
+ def validate_params(raw_params)
48
+ validated_params = check_resource_param_names(
49
+ raw_params: raw_params,
50
+ allowed_params: [:bucket_name],
51
+ allowed_scalar_name: :bucket_name,
52
+ allowed_scalar_type: String,
53
+ )
54
+ if validated_params.empty? or !validated_params.key?(:bucket_name)
55
+ raise ArgumentError, 'You must provide a bucket_name to aws_s3_bucket.'
56
+ end
57
+
58
+ validated_params
59
+ end
60
+
61
+ def fetch_from_api
62
+ backend = BackendFactory.create(inspec_runner)
63
+
64
+ # Since there is no basic "get_bucket" API call, use the
65
+ # region fetch as the existence check.
66
+ begin
67
+ @region = backend.get_bucket_location(bucket: bucket_name).location_constraint
68
+ rescue Aws::S3::Errors::NoSuchBucket
69
+ @exists = false
70
+ return
71
+ end
72
+ @exists = true
73
+ end
74
+
75
+ def fetch_bucket_policy
76
+ backend = BackendFactory.create(inspec_runner)
77
+ catch_aws_errors do
78
+ begin
79
+ # AWS SDK returns a StringIO, we have to read()
80
+ raw_policy = backend.get_bucket_policy(bucket: bucket_name).policy
81
+ return JSON.parse(raw_policy.read)['Statement'].map do |statement|
82
+ lowercase_hash = {}
83
+ statement.each_key { |k| lowercase_hash[k.downcase] = statement[k] }
84
+ @bucket_policy = OpenStruct.new(lowercase_hash)
85
+ end
86
+ rescue Aws::S3::Errors::NoSuchBucketPolicy
87
+ @bucket_policy = []
88
+ end
89
+ end
90
+ end
91
+
92
+ # Uses the SDK API to really talk to AWS
93
+ class Backend
94
+ class AwsClientApi < AwsBackendBase
95
+ BackendFactory.set_default_backend(self)
96
+ self.aws_client_class = Aws::S3::Client
97
+
98
+ def get_bucket_acl(query)
99
+ aws_service_client.get_bucket_acl(query)
100
+ end
101
+
102
+ def get_bucket_location(query)
103
+ aws_service_client.get_bucket_location(query)
104
+ end
105
+
106
+ def get_bucket_policy(query)
107
+ aws_service_client.get_bucket_policy(query)
108
+ end
109
+
110
+ def get_bucket_logging(query)
111
+ aws_service_client.get_bucket_logging(query)
112
+ end
113
+ end
114
+ end
115
+ end
@@ -1,93 +1,93 @@
1
- class AwsSecurityGroup < Inspec.resource(1)
2
- name 'aws_security_group'
3
- desc 'Verifies settings for an individual AWS Security Group.'
4
- example '
5
- describe aws_security_group("sg-12345678") do
6
- it { should exist }
7
- end
8
- '
9
- supports platform: 'aws'
10
-
11
- include AwsSingularResourceMixin
12
- attr_reader :description, :group_id, :group_name, :vpc_id
13
-
14
- def to_s
15
- "EC2 Security Group #{@group_id}"
16
- end
17
-
18
- private
19
-
20
- def validate_params(raw_params)
21
- recognized_params = check_resource_param_names(
22
- raw_params: raw_params,
23
- allowed_params: [:id, :group_id, :group_name, :vpc_id],
24
- allowed_scalar_name: :group_id,
25
- allowed_scalar_type: String,
26
- )
27
-
28
- # id is an alias for group_id
29
- recognized_params[:group_id] = recognized_params.delete(:id) if recognized_params.key?(:id)
30
-
31
- if recognized_params.key?(:group_id) && recognized_params[:group_id] !~ /^sg\-[0-9a-f]{8}/
32
- raise ArgumentError, 'aws_security_group security group ID must be in the format "sg-" followed by 8 hexadecimal characters.'
33
- end
34
-
35
- if recognized_params.key?(:vpc_id) && recognized_params[:vpc_id] !~ /^vpc\-[0-9a-f]{8}/
36
- raise ArgumentError, 'aws_security_group VPC ID must be in the format "vpc-" followed by 8 hexadecimal characters.'
37
- end
38
-
39
- validated_params = recognized_params
40
-
41
- if validated_params.empty?
42
- raise ArgumentError, 'You must provide parameters to aws_security_group, such as group_name, group_id, or vpc_id.g_group.'
43
- end
44
- validated_params
45
- end
46
-
47
- def fetch_from_api
48
- backend = BackendFactory.create(inspec_runner)
49
-
50
- # Transform into filter format expected by AWS
51
- filters = []
52
- [
53
- :description,
54
- :group_id,
55
- :group_name,
56
- :vpc_id,
57
- ].each do |criterion_name|
58
- instance_var = "@#{criterion_name}".to_sym
59
- next unless instance_variable_defined?(instance_var)
60
- val = instance_variable_get(instance_var)
61
- next if val.nil?
62
- filters.push(
63
- {
64
- name: criterion_name.to_s.tr('_', '-'),
65
- values: [val],
66
- },
67
- )
68
- end
69
- dsg_response = backend.describe_security_groups(filters: filters)
70
-
71
- if dsg_response.security_groups.empty?
72
- @exists = false
73
- return
74
- end
75
-
76
- @exists = true
77
- @description = dsg_response.security_groups[0].description
78
- @group_id = dsg_response.security_groups[0].group_id
79
- @group_name = dsg_response.security_groups[0].group_name
80
- @vpc_id = dsg_response.security_groups[0].vpc_id
81
- end
82
-
83
- class Backend
84
- class AwsClientApi < AwsBackendBase
85
- BackendFactory.set_default_backend self
86
- self.aws_client_class = Aws::EC2::Client
87
-
88
- def describe_security_groups(query)
89
- aws_service_client.describe_security_groups(query)
90
- end
91
- end
92
- end
93
- end
1
+ class AwsSecurityGroup < Inspec.resource(1)
2
+ name 'aws_security_group'
3
+ desc 'Verifies settings for an individual AWS Security Group.'
4
+ example '
5
+ describe aws_security_group("sg-12345678") do
6
+ it { should exist }
7
+ end
8
+ '
9
+ supports platform: 'aws'
10
+
11
+ include AwsSingularResourceMixin
12
+ attr_reader :description, :group_id, :group_name, :vpc_id
13
+
14
+ def to_s
15
+ "EC2 Security Group #{@group_id}"
16
+ end
17
+
18
+ private
19
+
20
+ def validate_params(raw_params)
21
+ recognized_params = check_resource_param_names(
22
+ raw_params: raw_params,
23
+ allowed_params: [:id, :group_id, :group_name, :vpc_id],
24
+ allowed_scalar_name: :group_id,
25
+ allowed_scalar_type: String,
26
+ )
27
+
28
+ # id is an alias for group_id
29
+ recognized_params[:group_id] = recognized_params.delete(:id) if recognized_params.key?(:id)
30
+
31
+ if recognized_params.key?(:group_id) && recognized_params[:group_id] !~ /^sg\-[0-9a-f]{8}/
32
+ raise ArgumentError, 'aws_security_group security group ID must be in the format "sg-" followed by 8 hexadecimal characters.'
33
+ end
34
+
35
+ if recognized_params.key?(:vpc_id) && recognized_params[:vpc_id] !~ /^vpc\-[0-9a-f]{8}/
36
+ raise ArgumentError, 'aws_security_group VPC ID must be in the format "vpc-" followed by 8 hexadecimal characters.'
37
+ end
38
+
39
+ validated_params = recognized_params
40
+
41
+ if validated_params.empty?
42
+ raise ArgumentError, 'You must provide parameters to aws_security_group, such as group_name, group_id, or vpc_id.g_group.'
43
+ end
44
+ validated_params
45
+ end
46
+
47
+ def fetch_from_api
48
+ backend = BackendFactory.create(inspec_runner)
49
+
50
+ # Transform into filter format expected by AWS
51
+ filters = []
52
+ [
53
+ :description,
54
+ :group_id,
55
+ :group_name,
56
+ :vpc_id,
57
+ ].each do |criterion_name|
58
+ instance_var = "@#{criterion_name}".to_sym
59
+ next unless instance_variable_defined?(instance_var)
60
+ val = instance_variable_get(instance_var)
61
+ next if val.nil?
62
+ filters.push(
63
+ {
64
+ name: criterion_name.to_s.tr('_', '-'),
65
+ values: [val],
66
+ },
67
+ )
68
+ end
69
+ dsg_response = backend.describe_security_groups(filters: filters)
70
+
71
+ if dsg_response.security_groups.empty?
72
+ @exists = false
73
+ return
74
+ end
75
+
76
+ @exists = true
77
+ @description = dsg_response.security_groups[0].description
78
+ @group_id = dsg_response.security_groups[0].group_id
79
+ @group_name = dsg_response.security_groups[0].group_name
80
+ @vpc_id = dsg_response.security_groups[0].vpc_id
81
+ end
82
+
83
+ class Backend
84
+ class AwsClientApi < AwsBackendBase
85
+ BackendFactory.set_default_backend self
86
+ self.aws_client_class = Aws::EC2::Client
87
+
88
+ def describe_security_groups(query)
89
+ aws_service_client.describe_security_groups(query)
90
+ end
91
+ end
92
+ end
93
+ end