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,84 +1,84 @@
1
- # encoding: utf-8
2
-
3
- # check for a Windows feature
4
- # Usage:
5
- # describe windows_feature('DHCP Server') do
6
- # it{ should be_installed }
7
- # end
8
- #
9
- # deprecated serverspec syntax:
10
- # describe windows_feature('IIS-Webserver') do
11
- # it{ should be_installed.by("dism") }
12
- # end
13
- #
14
- # describe windows_feature('Web-Webserver') do
15
- # it{ should be_installed.by("powershell") }
16
- # end
17
- #
18
- # This implementation uses the Get-WindowsFeature commandlet:
19
- # Get-WindowsFeature | Where-Object {$_.Name -eq 'XPS Viewer' -or $_.DisplayName -eq 'XPS Viewe
20
- # r'} | Select-Object -Property Name,DisplayName,Description,Installed,InstallState | ConvertTo-Json
21
- # {
22
- # "Name": "XPS-Viewer",
23
- # "DisplayName": "XPS Viewer",
24
- # "Description": "The XPS Viewer is used to read, set permissions for, and digitally sign XPS documents.",
25
- # "Installed": false,
26
- # "InstallState": 0
27
- # }
28
- module Inspec::Resources
29
- class WindowsFeature < Inspec.resource(1)
30
- name 'windows_feature'
31
- supports platform: 'windows'
32
- desc 'Use the windows_feature InSpec audit resource to test features on Microsoft Windows.'
33
- example "
34
- describe windows_feature('dhcp') do
35
- it { should be_installed }
36
- end
37
- "
38
-
39
- def initialize(feature)
40
- @feature = feature
41
- @cache = nil
42
-
43
- # verify that this resource is only supported on Windows
44
- return skip_resource 'The `windows_feature` resource is not supported on your OS.' if !inspec.os.windows?
45
- end
46
-
47
- # returns true if the package is installed
48
- def installed?(_provider = nil, _version = nil)
49
- info[:installed] == true
50
- end
51
-
52
- # returns the package description
53
- def info
54
- return @cache if !@cache.nil?
55
- features_cmd = "Get-WindowsFeature | Where-Object {$_.Name -eq '#{@feature}' -or $_.DisplayName -eq '#{@feature}'} | Select-Object -Property Name,DisplayName,Description,Installed,InstallState | ConvertTo-Json"
56
- cmd = inspec.command(features_cmd)
57
-
58
- @cache = {
59
- name: @feature,
60
- type: 'windows-feature',
61
- }
62
-
63
- # cannot rely on exit code for now, successful command returns exit code 1
64
- # return nil if cmd.exit_status != 0
65
- # try to parse json
66
- begin
67
- params = JSON.parse(cmd.stdout)
68
- rescue JSON::ParserError => _e
69
- return @cache
70
- end
71
-
72
- @cache = {
73
- name: params['Name'],
74
- description: params['Description'],
75
- installed: params['Installed'],
76
- type: 'windows-feature',
77
- }
78
- end
79
-
80
- def to_s
81
- "Windows Feature '#{@feature}'"
82
- end
83
- end
84
- end
1
+ # encoding: utf-8
2
+
3
+ # check for a Windows feature
4
+ # Usage:
5
+ # describe windows_feature('DHCP Server') do
6
+ # it{ should be_installed }
7
+ # end
8
+ #
9
+ # deprecated serverspec syntax:
10
+ # describe windows_feature('IIS-Webserver') do
11
+ # it{ should be_installed.by("dism") }
12
+ # end
13
+ #
14
+ # describe windows_feature('Web-Webserver') do
15
+ # it{ should be_installed.by("powershell") }
16
+ # end
17
+ #
18
+ # This implementation uses the Get-WindowsFeature commandlet:
19
+ # Get-WindowsFeature | Where-Object {$_.Name -eq 'XPS Viewer' -or $_.DisplayName -eq 'XPS Viewe
20
+ # r'} | Select-Object -Property Name,DisplayName,Description,Installed,InstallState | ConvertTo-Json
21
+ # {
22
+ # "Name": "XPS-Viewer",
23
+ # "DisplayName": "XPS Viewer",
24
+ # "Description": "The XPS Viewer is used to read, set permissions for, and digitally sign XPS documents.",
25
+ # "Installed": false,
26
+ # "InstallState": 0
27
+ # }
28
+ module Inspec::Resources
29
+ class WindowsFeature < Inspec.resource(1)
30
+ name 'windows_feature'
31
+ supports platform: 'windows'
32
+ desc 'Use the windows_feature InSpec audit resource to test features on Microsoft Windows.'
33
+ example "
34
+ describe windows_feature('dhcp') do
35
+ it { should be_installed }
36
+ end
37
+ "
38
+
39
+ def initialize(feature)
40
+ @feature = feature
41
+ @cache = nil
42
+
43
+ # verify that this resource is only supported on Windows
44
+ return skip_resource 'The `windows_feature` resource is not supported on your OS.' if !inspec.os.windows?
45
+ end
46
+
47
+ # returns true if the package is installed
48
+ def installed?(_provider = nil, _version = nil)
49
+ info[:installed] == true
50
+ end
51
+
52
+ # returns the package description
53
+ def info
54
+ return @cache if !@cache.nil?
55
+ features_cmd = "Get-WindowsFeature | Where-Object {$_.Name -eq '#{@feature}' -or $_.DisplayName -eq '#{@feature}'} | Select-Object -Property Name,DisplayName,Description,Installed,InstallState | ConvertTo-Json"
56
+ cmd = inspec.command(features_cmd)
57
+
58
+ @cache = {
59
+ name: @feature,
60
+ type: 'windows-feature',
61
+ }
62
+
63
+ # cannot rely on exit code for now, successful command returns exit code 1
64
+ # return nil if cmd.exit_status != 0
65
+ # try to parse json
66
+ begin
67
+ params = JSON.parse(cmd.stdout)
68
+ rescue JSON::ParserError => _e
69
+ return @cache
70
+ end
71
+
72
+ @cache = {
73
+ name: params['Name'],
74
+ description: params['Description'],
75
+ installed: params['Installed'],
76
+ type: 'windows-feature',
77
+ }
78
+ end
79
+
80
+ def to_s
81
+ "Windows Feature '#{@feature}'"
82
+ end
83
+ end
84
+ end
@@ -1,35 +1,35 @@
1
- # encoding: utf-8
2
-
3
- module Inspec::Resources
4
- class WindowsHotfix < Inspec.resource(1)
5
- name 'windows_hotfix'
6
- supports platform: 'windows'
7
- desc 'Use the windows_hotfix InSpec audit resource to test if the hotfix has been installed on the Windows system.'
8
- example "
9
- describe windows_hotfix('KB4012212') do
10
- it { should be_installed }
11
- end
12
- "
13
-
14
- attr_accessor :content
15
-
16
- def initialize(hotfix_id = nil)
17
- @id = hotfix_id.upcase
18
- @content = nil
19
- os = inspec.os
20
- return skip_resource 'The `windows_hotfix` resource is not a feature of your OS.' unless os.windows?
21
- query = "get-hotfix -id #{@id}"
22
- cmd = inspec.powershell(query)
23
- @content = cmd.stdout
24
- end
25
-
26
- def to_s
27
- "Windows Hotfix #{@id}"
28
- end
29
-
30
- def installed?
31
- return false if @content.nil?
32
- @content.include?(@id)
33
- end
34
- end
35
- end
1
+ # encoding: utf-8
2
+
3
+ module Inspec::Resources
4
+ class WindowsHotfix < Inspec.resource(1)
5
+ name 'windows_hotfix'
6
+ supports platform: 'windows'
7
+ desc 'Use the windows_hotfix InSpec audit resource to test if the hotfix has been installed on the Windows system.'
8
+ example "
9
+ describe windows_hotfix('KB4012212') do
10
+ it { should be_installed }
11
+ end
12
+ "
13
+
14
+ attr_accessor :content
15
+
16
+ def initialize(hotfix_id = nil)
17
+ @id = hotfix_id.upcase
18
+ @content = nil
19
+ os = inspec.os
20
+ return skip_resource 'The `windows_hotfix` resource is not a feature of your OS.' unless os.windows?
21
+ query = "get-hotfix -id #{@id}"
22
+ cmd = inspec.powershell(query)
23
+ @content = cmd.stdout
24
+ end
25
+
26
+ def to_s
27
+ "Windows Hotfix #{@id}"
28
+ end
29
+
30
+ def installed?
31
+ return false if @content.nil?
32
+ @content.include?(@id)
33
+ end
34
+ end
35
+ end
@@ -1,105 +1,105 @@
1
- # encoding: utf-8
2
- module Inspec::Resources
3
- class WindowsTasks < Inspec.resource(1)
4
- name 'windows_task'
5
- supports platform: 'windows'
6
- desc 'Use the windows_task InSpec audit resource to test task schedules on Microsoft Windows.'
7
- example "
8
- describe windows_task('\\Microsoft\\Windows\\Time Synchronization\\SynchronizeTime') do
9
- it { should be_enabled }
10
- end
11
-
12
- describe windows_task('\\Microsoft\\Windows\\AppID\\PolicyConverter') do
13
- it { should be_disabled }
14
- end
15
-
16
- describe windows_task('\\Microsoft\\Windows\\Defrag\\ScheduledDefrag') do
17
- it { should exist }
18
- end
19
-
20
- describe windows_task('\\Microsoft\\Windows\\AppID\\PolicyConverter') do
21
- its('logon_mode') { should eq 'Interactive/Background' }
22
- its('last_result') { should eq '1' }
23
- its('task_to_run') { should cmp '%Windir%\\system32\\appidpolicyconverter.exe' }
24
- its('run_as_user') { should eq 'LOCAL SERVICE' }
25
- end
26
- "
27
-
28
- def initialize(taskuri)
29
- @taskuri = taskuri
30
- @cache = nil
31
-
32
- # verify that this resource is only supported on Windows
33
- return skip_resource 'The `windows_task` resource is not supported on your OS.' unless inspec.os.windows?
34
- end
35
-
36
- def exists?
37
- return true unless info.nil? || info[:uri].nil?
38
- false
39
- end
40
-
41
- # rubocop:disable Style/WordArray
42
- def enabled?
43
- return false if info.nil? || info[:state].nil?
44
- ['Ready', 'Running'].include?(info[:state])
45
- end
46
-
47
- def disabled?
48
- return false if info.nil? || info[:state].nil?
49
- info[:scheduled_task_state] == 'Disabled' || info[:state] == 'Disabled'
50
- end
51
-
52
- def logon_mode
53
- info[:logon_mode]
54
- end
55
-
56
- def last_result
57
- info[:last_result]
58
- end
59
-
60
- def task_to_run
61
- info[:task_to_run].to_s.strip
62
- end
63
-
64
- def run_as_user
65
- info[:run_as_user]
66
- end
67
-
68
- def type
69
- info[:type] unless info.nil?
70
- end
71
-
72
- def info
73
- return @cache unless @cache.nil?
74
- # PowerShell v5 has Get-ScheduledTask cmdlet,
75
- # _using something with backward support to v3_
76
- # script = "Get-ScheduledTask | ? { $_.URI -eq '#{@taskuri}' } | Select-Object URI,@{N='State';E={$_.State.ToString()}} | ConvertTo-Json"
77
-
78
- # Using schtasks as suggested by @modille but aligning property names to match cmdlet to future proof.
79
- script = "schtasks /query /v /fo csv /tn '#{@taskuri}' | ConvertFrom-Csv | Select @{N='URI';E={$_.TaskName}},@{N='State';E={$_.Status.ToString()}},'Logon Mode','Last Result','Task To Run','Run As User','Scheduled Task State' | ConvertTo-Json -Compress"
80
-
81
- cmd = inspec.powershell(script)
82
-
83
- begin
84
- params = JSON.parse(cmd.stdout)
85
- rescue JSON::ParserError => _e
86
- return nil
87
- end
88
-
89
- @cache = {
90
- uri: params['URI'],
91
- state: params['State'],
92
- logon_mode: params['Logon Mode'],
93
- last_result: params['Last Result'],
94
- task_to_run: params['Task To Run'],
95
- run_as_user: params['Run As User'],
96
- scheduled_task_state: params['Scheduled Task State'],
97
- type: 'windows-task',
98
- }
99
- end
100
-
101
- def to_s
102
- "Windows Task '#{@taskuri}'"
103
- end
104
- end
105
- end
1
+ # encoding: utf-8
2
+ module Inspec::Resources
3
+ class WindowsTasks < Inspec.resource(1)
4
+ name 'windows_task'
5
+ supports platform: 'windows'
6
+ desc 'Use the windows_task InSpec audit resource to test task schedules on Microsoft Windows.'
7
+ example "
8
+ describe windows_task('\\Microsoft\\Windows\\Time Synchronization\\SynchronizeTime') do
9
+ it { should be_enabled }
10
+ end
11
+
12
+ describe windows_task('\\Microsoft\\Windows\\AppID\\PolicyConverter') do
13
+ it { should be_disabled }
14
+ end
15
+
16
+ describe windows_task('\\Microsoft\\Windows\\Defrag\\ScheduledDefrag') do
17
+ it { should exist }
18
+ end
19
+
20
+ describe windows_task('\\Microsoft\\Windows\\AppID\\PolicyConverter') do
21
+ its('logon_mode') { should eq 'Interactive/Background' }
22
+ its('last_result') { should eq '1' }
23
+ its('task_to_run') { should cmp '%Windir%\\system32\\appidpolicyconverter.exe' }
24
+ its('run_as_user') { should eq 'LOCAL SERVICE' }
25
+ end
26
+ "
27
+
28
+ def initialize(taskuri)
29
+ @taskuri = taskuri
30
+ @cache = nil
31
+
32
+ # verify that this resource is only supported on Windows
33
+ return skip_resource 'The `windows_task` resource is not supported on your OS.' unless inspec.os.windows?
34
+ end
35
+
36
+ def exists?
37
+ return true unless info.nil? || info[:uri].nil?
38
+ false
39
+ end
40
+
41
+ # rubocop:disable Style/WordArray
42
+ def enabled?
43
+ return false if info.nil? || info[:state].nil?
44
+ ['Ready', 'Running'].include?(info[:state])
45
+ end
46
+
47
+ def disabled?
48
+ return false if info.nil? || info[:state].nil?
49
+ info[:scheduled_task_state] == 'Disabled' || info[:state] == 'Disabled'
50
+ end
51
+
52
+ def logon_mode
53
+ info[:logon_mode]
54
+ end
55
+
56
+ def last_result
57
+ info[:last_result]
58
+ end
59
+
60
+ def task_to_run
61
+ info[:task_to_run].to_s.strip
62
+ end
63
+
64
+ def run_as_user
65
+ info[:run_as_user]
66
+ end
67
+
68
+ def type
69
+ info[:type] unless info.nil?
70
+ end
71
+
72
+ def info
73
+ return @cache unless @cache.nil?
74
+ # PowerShell v5 has Get-ScheduledTask cmdlet,
75
+ # _using something with backward support to v3_
76
+ # script = "Get-ScheduledTask | ? { $_.URI -eq '#{@taskuri}' } | Select-Object URI,@{N='State';E={$_.State.ToString()}} | ConvertTo-Json"
77
+
78
+ # Using schtasks as suggested by @modille but aligning property names to match cmdlet to future proof.
79
+ script = "schtasks /query /v /fo csv /tn '#{@taskuri}' | ConvertFrom-Csv | Select @{N='URI';E={$_.TaskName}},@{N='State';E={$_.Status.ToString()}},'Logon Mode','Last Result','Task To Run','Run As User','Scheduled Task State' | ConvertTo-Json -Compress"
80
+
81
+ cmd = inspec.powershell(script)
82
+
83
+ begin
84
+ params = JSON.parse(cmd.stdout)
85
+ rescue JSON::ParserError => _e
86
+ return nil
87
+ end
88
+
89
+ @cache = {
90
+ uri: params['URI'],
91
+ state: params['State'],
92
+ logon_mode: params['Logon Mode'],
93
+ last_result: params['Last Result'],
94
+ task_to_run: params['Task To Run'],
95
+ run_as_user: params['Run As User'],
96
+ scheduled_task_state: params['Scheduled Task State'],
97
+ type: 'windows-task',
98
+ }
99
+ end
100
+
101
+ def to_s
102
+ "Windows Task '#{@taskuri}'"
103
+ end
104
+ end
105
+ end
@@ -1,113 +1,113 @@
1
- # encoding: utf-8
2
-
3
- require 'utils/object_traversal'
4
-
5
- module Inspec::Resources
6
- # This resource simplifies the access to wmi
7
- # on CLI you would use:
8
- # WMIC /NAMESPACE:\\root\rsop\computer PATH RSOP_SecuritySettingNumeric WHERE "KeyName = 'MinimumPasswordAge' And precedence=1" GET Setting
9
- # We use Get-WmiObject via Powershell to retrieve all values.
10
- class WMI < Inspec.resource(1)
11
- name 'wmi'
12
- supports platform: 'windows'
13
- desc 'request wmi information'
14
- example "
15
- describe wmi({
16
- class: 'RSOP_SecuritySettingNumeric',
17
- namespace: 'root\\rsop\\computer',
18
- filter: 'KeyName = \'MinimumPasswordAge\' And precedence=1'
19
- }) do
20
- its('Setting') { should eq true }
21
- end
22
- "
23
-
24
- include ObjectTraverser
25
- attr_accessor :content
26
-
27
- def initialize(wmiclass = nil, opts = nil)
28
- # verify that this resource is only supported on Windows
29
- return skip_resource 'The `wmi` resource is not supported on your OS.' unless inspec.os.windows?
30
-
31
- @options = opts || {}
32
- # if wmiclass is not a hash, we have to handle deprecation behavior
33
- if wmiclass.is_a?(Hash)
34
- @options.merge!(wmiclass)
35
- else
36
- warn '[DEPRECATION] `wmi(\'wmiclass\')` is deprecated. Please use `wmi({class: \'wmiclass\'})` instead.'
37
- @options[:class] = wmiclass
38
- end
39
- end
40
-
41
- # returns nil, if not existant or value
42
- def method_missing(*keys)
43
- # catch behavior of rspec its implementation
44
- # @see https://github.com/rspec/rspec-its/blob/master/lib/rspec/its.rb#L110
45
- keys.shift if keys.is_a?(Array) && keys[0] == :[]
46
-
47
- # map all symbols to strings
48
- keys = keys.map { |x| x.to_s.downcase } if keys.is_a?(Array)
49
-
50
- value(keys)
51
- end
52
-
53
- def value(key)
54
- extract_value(key, params)
55
- end
56
-
57
- def params
58
- return @content if defined?(@content)
59
- @content = {}
60
-
61
- # abort if no options are available
62
- return @content unless defined?(@options)
63
-
64
- # filter for supported options
65
- args = @options.select { |key, _value| [:class, :namespace, :query, :filter].include?(key) }
66
-
67
- # convert to Get-WmiObject arguments
68
- params = ''
69
- args.each { |key, value| params += " -#{key} \"#{value.gsub('"', '`"')}\"" }
70
-
71
- # run wmi command and filter empty wmi
72
- script = <<-EOH
73
- Filter Aggregate
74
- {
75
- $arr = @{}
76
- $_.properties | % {
77
- $arr.Add($_.name, $_.value)
78
- }
79
- $arr
80
- }
81
- Get-WmiObject #{params} | Aggregate | ConvertTo-Json
82
- EOH
83
-
84
- # run wmi command
85
- cmd = inspec.powershell(script)
86
- @content = JSON.parse(cmd.stdout)
87
-
88
- # make all keys case-insensitive
89
- @content = lowercase_keys(@content)
90
- rescue JSON::ParserError => _e
91
- @content
92
- end
93
-
94
- def to_s
95
- "WMI with #{@options}"
96
- end
97
-
98
- private
99
-
100
- def lowercase_keys(content)
101
- if content.is_a?(Hash)
102
- content.keys.each do |key|
103
- new_key = key.to_s.downcase
104
- content[new_key] = content.delete(key)
105
- lowercase_keys(content[new_key])
106
- end
107
- elsif content.respond_to?(:each)
108
- content.each { |item| lowercase_keys(item) }
109
- end
110
- content
111
- end
112
- end
113
- end
1
+ # encoding: utf-8
2
+
3
+ require 'utils/object_traversal'
4
+
5
+ module Inspec::Resources
6
+ # This resource simplifies the access to wmi
7
+ # on CLI you would use:
8
+ # WMIC /NAMESPACE:\\root\rsop\computer PATH RSOP_SecuritySettingNumeric WHERE "KeyName = 'MinimumPasswordAge' And precedence=1" GET Setting
9
+ # We use Get-WmiObject via Powershell to retrieve all values.
10
+ class WMI < Inspec.resource(1)
11
+ name 'wmi'
12
+ supports platform: 'windows'
13
+ desc 'request wmi information'
14
+ example "
15
+ describe wmi({
16
+ class: 'RSOP_SecuritySettingNumeric',
17
+ namespace: 'root\\rsop\\computer',
18
+ filter: 'KeyName = \'MinimumPasswordAge\' And precedence=1'
19
+ }) do
20
+ its('Setting') { should eq true }
21
+ end
22
+ "
23
+
24
+ include ObjectTraverser
25
+ attr_accessor :content
26
+
27
+ def initialize(wmiclass = nil, opts = nil)
28
+ # verify that this resource is only supported on Windows
29
+ return skip_resource 'The `wmi` resource is not supported on your OS.' unless inspec.os.windows?
30
+
31
+ @options = opts || {}
32
+ # if wmiclass is not a hash, we have to handle deprecation behavior
33
+ if wmiclass.is_a?(Hash)
34
+ @options.merge!(wmiclass)
35
+ else
36
+ warn '[DEPRECATION] `wmi(\'wmiclass\')` is deprecated. Please use `wmi({class: \'wmiclass\'})` instead.'
37
+ @options[:class] = wmiclass
38
+ end
39
+ end
40
+
41
+ # returns nil, if not existant or value
42
+ def method_missing(*keys)
43
+ # catch behavior of rspec its implementation
44
+ # @see https://github.com/rspec/rspec-its/blob/master/lib/rspec/its.rb#L110
45
+ keys.shift if keys.is_a?(Array) && keys[0] == :[]
46
+
47
+ # map all symbols to strings
48
+ keys = keys.map { |x| x.to_s.downcase } if keys.is_a?(Array)
49
+
50
+ value(keys)
51
+ end
52
+
53
+ def value(key)
54
+ extract_value(key, params)
55
+ end
56
+
57
+ def params
58
+ return @content if defined?(@content)
59
+ @content = {}
60
+
61
+ # abort if no options are available
62
+ return @content unless defined?(@options)
63
+
64
+ # filter for supported options
65
+ args = @options.select { |key, _value| [:class, :namespace, :query, :filter].include?(key) }
66
+
67
+ # convert to Get-WmiObject arguments
68
+ params = ''
69
+ args.each { |key, value| params += " -#{key} \"#{value.gsub('"', '`"')}\"" }
70
+
71
+ # run wmi command and filter empty wmi
72
+ script = <<-EOH
73
+ Filter Aggregate
74
+ {
75
+ $arr = @{}
76
+ $_.properties | % {
77
+ $arr.Add($_.name, $_.value)
78
+ }
79
+ $arr
80
+ }
81
+ Get-WmiObject #{params} | Aggregate | ConvertTo-Json
82
+ EOH
83
+
84
+ # run wmi command
85
+ cmd = inspec.powershell(script)
86
+ @content = JSON.parse(cmd.stdout)
87
+
88
+ # make all keys case-insensitive
89
+ @content = lowercase_keys(@content)
90
+ rescue JSON::ParserError => _e
91
+ @content
92
+ end
93
+
94
+ def to_s
95
+ "WMI with #{@options}"
96
+ end
97
+
98
+ private
99
+
100
+ def lowercase_keys(content)
101
+ if content.is_a?(Hash)
102
+ content.keys.each do |key|
103
+ new_key = key.to_s.downcase
104
+ content[new_key] = content.delete(key)
105
+ lowercase_keys(content[new_key])
106
+ end
107
+ elsif content.respond_to?(:each)
108
+ content.each { |item| lowercase_keys(item) }
109
+ end
110
+ content
111
+ end
112
+ end
113
+ end