inspec 2.1.0 → 2.1.10

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 (489) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +101 -101
  3. data/CHANGELOG.md +3024 -3004
  4. data/Gemfile +55 -55
  5. data/LICENSE +14 -14
  6. data/MAINTAINERS.md +33 -33
  7. data/MAINTAINERS.toml +52 -52
  8. data/README.md +447 -446
  9. data/Rakefile +322 -322
  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 +100 -93
  15. data/docs/glossary.md +99 -99
  16. data/docs/habitat.md +191 -191
  17. data/docs/inspec_and_friends.md +114 -114
  18. data/docs/matchers.md +169 -169
  19. data/docs/migration.md +293 -293
  20. data/docs/platforms.md +118 -118
  21. data/docs/plugin_kitchen_inspec.md +50 -50
  22. data/docs/profiles.md +376 -376
  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_config_recorder.md.erb +71 -71
  36. data/docs/resources/aws_ec2_instance.md.erb +106 -106
  37. data/docs/resources/aws_iam_access_key.md.erb +123 -123
  38. data/docs/resources/aws_iam_access_keys.md.erb +198 -198
  39. data/docs/resources/aws_iam_group.md.erb +46 -46
  40. data/docs/resources/aws_iam_groups.md.erb +43 -43
  41. data/docs/resources/aws_iam_password_policy.md.erb +76 -76
  42. data/docs/resources/aws_iam_policies.md.erb +82 -82
  43. data/docs/resources/aws_iam_policy.md.erb +144 -144
  44. data/docs/resources/aws_iam_role.md.erb +63 -63
  45. data/docs/resources/aws_iam_root_user.md.erb +58 -58
  46. data/docs/resources/aws_iam_user.md.erb +64 -64
  47. data/docs/resources/aws_iam_users.md.erb +89 -89
  48. data/docs/resources/aws_kms_keys.md.erb +84 -84
  49. data/docs/resources/aws_route_table.md.erb +47 -47
  50. data/docs/resources/aws_s3_bucket.md.erb +134 -134
  51. data/docs/resources/aws_s3_bucket_object.md.erb +83 -0
  52. data/docs/resources/aws_security_group.md.erb +151 -151
  53. data/docs/resources/aws_security_groups.md.erb +91 -91
  54. data/docs/resources/aws_sns_subscription.md.erb +125 -0
  55. data/docs/resources/aws_sns_topic.md.erb +63 -63
  56. data/docs/resources/aws_sns_topics.md.erb +52 -0
  57. data/docs/resources/aws_subnet.md.erb +134 -134
  58. data/docs/resources/aws_subnets.md.erb +126 -126
  59. data/docs/resources/aws_vpc.md.erb +120 -120
  60. data/docs/resources/aws_vpcs.md.erb +48 -48
  61. data/docs/resources/azure_generic_resource.md.erb +171 -171
  62. data/docs/resources/azure_resource_group.md.erb +284 -284
  63. data/docs/resources/azure_virtual_machine.md.erb +347 -347
  64. data/docs/resources/azure_virtual_machine_data_disk.md.erb +224 -224
  65. data/docs/resources/bash.md.erb +75 -75
  66. data/docs/resources/bond.md.erb +90 -90
  67. data/docs/resources/bridge.md.erb +57 -57
  68. data/docs/resources/bsd_service.md.erb +67 -67
  69. data/docs/resources/command.md.erb +138 -138
  70. data/docs/resources/cpan.md.erb +79 -79
  71. data/docs/resources/cran.md.erb +64 -64
  72. data/docs/resources/crontab.md.erb +89 -89
  73. data/docs/resources/csv.md.erb +54 -54
  74. data/docs/resources/dh_params.md.erb +205 -205
  75. data/docs/resources/directory.md.erb +30 -30
  76. data/docs/resources/docker.md.erb +219 -219
  77. data/docs/resources/docker_container.md.erb +103 -103
  78. data/docs/resources/docker_image.md.erb +94 -94
  79. data/docs/resources/docker_service.md.erb +114 -114
  80. data/docs/resources/elasticsearch.md.erb +242 -242
  81. data/docs/resources/etc_fstab.md.erb +125 -125
  82. data/docs/resources/etc_group.md.erb +75 -75
  83. data/docs/resources/etc_hosts.md.erb +78 -78
  84. data/docs/resources/etc_hosts_allow.md.erb +74 -74
  85. data/docs/resources/etc_hosts_deny.md.erb +74 -74
  86. data/docs/resources/file.md.erb +526 -526
  87. data/docs/resources/filesystem.md.erb +41 -41
  88. data/docs/resources/firewalld.md.erb +107 -107
  89. data/docs/resources/gem.md.erb +79 -79
  90. data/docs/resources/group.md.erb +61 -61
  91. data/docs/resources/grub_conf.md.erb +101 -101
  92. data/docs/resources/host.md.erb +86 -86
  93. data/docs/resources/http.md.erb +196 -196
  94. data/docs/resources/iis_app.md.erb +122 -122
  95. data/docs/resources/iis_site.md.erb +135 -135
  96. data/docs/resources/inetd_conf.md.erb +94 -94
  97. data/docs/resources/ini.md.erb +76 -76
  98. data/docs/resources/interface.md.erb +58 -58
  99. data/docs/resources/iptables.md.erb +64 -64
  100. data/docs/resources/json.md.erb +63 -63
  101. data/docs/resources/kernel_module.md.erb +120 -120
  102. data/docs/resources/kernel_parameter.md.erb +53 -53
  103. data/docs/resources/key_rsa.md.erb +85 -85
  104. data/docs/resources/launchd_service.md.erb +57 -57
  105. data/docs/resources/limits_conf.md.erb +75 -75
  106. data/docs/resources/{login_def.md.erb → login_defs.md.erb} +71 -71
  107. data/docs/resources/mount.md.erb +69 -69
  108. data/docs/resources/mssql_session.md.erb +60 -60
  109. data/docs/resources/mysql_conf.md.erb +99 -99
  110. data/docs/resources/mysql_session.md.erb +74 -74
  111. data/docs/resources/nginx.md.erb +79 -79
  112. data/docs/resources/nginx_conf.md.erb +138 -128
  113. data/docs/resources/npm.md.erb +60 -60
  114. data/docs/resources/ntp_conf.md.erb +60 -60
  115. data/docs/resources/oneget.md.erb +53 -53
  116. data/docs/resources/oracledb_session.md.erb +52 -52
  117. data/docs/resources/os.md.erb +141 -141
  118. data/docs/resources/os_env.md.erb +78 -78
  119. data/docs/resources/package.md.erb +120 -120
  120. data/docs/resources/packages.md.erb +67 -67
  121. data/docs/resources/parse_config.md.erb +103 -103
  122. data/docs/resources/parse_config_file.md.erb +138 -138
  123. data/docs/resources/passwd.md.erb +141 -141
  124. data/docs/resources/pip.md.erb +67 -67
  125. data/docs/resources/port.md.erb +137 -137
  126. data/docs/resources/postgres_conf.md.erb +79 -79
  127. data/docs/resources/postgres_hba_conf.md.erb +93 -93
  128. data/docs/resources/postgres_ident_conf.md.erb +76 -76
  129. data/docs/resources/postgres_session.md.erb +69 -69
  130. data/docs/resources/powershell.md.erb +102 -102
  131. data/docs/resources/processes.md.erb +109 -109
  132. data/docs/resources/rabbitmq_config.md.erb +41 -41
  133. data/docs/resources/registry_key.md.erb +158 -158
  134. data/docs/resources/runit_service.md.erb +57 -57
  135. data/docs/resources/security_policy.md.erb +47 -47
  136. data/docs/resources/service.md.erb +121 -121
  137. data/docs/resources/shadow.md.erb +146 -146
  138. data/docs/resources/ssh_config.md.erb +73 -80
  139. data/docs/resources/sshd_config.md.erb +83 -83
  140. data/docs/resources/ssl.md.erb +119 -119
  141. data/docs/resources/sys_info.md.erb +42 -42
  142. data/docs/resources/systemd_service.md.erb +57 -57
  143. data/docs/resources/sysv_service.md.erb +57 -57
  144. data/docs/resources/upstart_service.md.erb +57 -57
  145. data/docs/resources/user.md.erb +140 -140
  146. data/docs/resources/users.md.erb +127 -127
  147. data/docs/resources/vbscript.md.erb +55 -55
  148. data/docs/resources/virtualization.md.erb +57 -57
  149. data/docs/resources/windows_feature.md.erb +47 -47
  150. data/docs/resources/windows_hotfix.md.erb +53 -53
  151. data/docs/resources/windows_task.md.erb +95 -95
  152. data/docs/resources/wmi.md.erb +81 -81
  153. data/docs/resources/x509_certificate.md.erb +151 -151
  154. data/docs/resources/xinetd_conf.md.erb +156 -156
  155. data/docs/resources/xml.md.erb +85 -85
  156. data/docs/resources/yaml.md.erb +69 -69
  157. data/docs/resources/yum.md.erb +98 -98
  158. data/docs/resources/zfs_dataset.md.erb +53 -53
  159. data/docs/resources/zfs_pool.md.erb +47 -47
  160. data/docs/ruby_usage.md +203 -203
  161. data/docs/shared/matcher_be.md.erb +1 -1
  162. data/docs/shared/matcher_cmp.md.erb +43 -43
  163. data/docs/shared/matcher_eq.md.erb +3 -3
  164. data/docs/shared/matcher_include.md.erb +1 -1
  165. data/docs/shared/matcher_match.md.erb +1 -1
  166. data/docs/shell.md +217 -217
  167. data/examples/README.md +8 -8
  168. data/examples/inheritance/README.md +65 -65
  169. data/examples/inheritance/controls/example.rb +14 -14
  170. data/examples/inheritance/inspec.yml +15 -15
  171. data/examples/kitchen-ansible/.kitchen.yml +25 -25
  172. data/examples/kitchen-ansible/Gemfile +19 -19
  173. data/examples/kitchen-ansible/README.md +53 -53
  174. data/examples/kitchen-ansible/files/nginx.repo +6 -6
  175. data/examples/kitchen-ansible/tasks/main.yml +16 -16
  176. data/examples/kitchen-ansible/test/integration/default/default.yml +5 -5
  177. data/examples/kitchen-ansible/test/integration/default/web_spec.rb +28 -28
  178. data/examples/kitchen-chef/.kitchen.yml +20 -20
  179. data/examples/kitchen-chef/Berksfile +3 -3
  180. data/examples/kitchen-chef/Gemfile +19 -19
  181. data/examples/kitchen-chef/README.md +27 -27
  182. data/examples/kitchen-chef/metadata.rb +7 -7
  183. data/examples/kitchen-chef/recipes/default.rb +6 -6
  184. data/examples/kitchen-chef/recipes/nginx.rb +30 -30
  185. data/examples/kitchen-chef/test/integration/default/web_spec.rb +28 -28
  186. data/examples/kitchen-puppet/.kitchen.yml +22 -22
  187. data/examples/kitchen-puppet/Gemfile +20 -20
  188. data/examples/kitchen-puppet/Puppetfile +25 -25
  189. data/examples/kitchen-puppet/README.md +53 -53
  190. data/examples/kitchen-puppet/manifests/site.pp +33 -33
  191. data/examples/kitchen-puppet/metadata.json +11 -11
  192. data/examples/kitchen-puppet/test/integration/default/web_spec.rb +28 -28
  193. data/examples/meta-profile/README.md +37 -37
  194. data/examples/meta-profile/controls/example.rb +13 -13
  195. data/examples/meta-profile/inspec.yml +13 -13
  196. data/examples/profile-attribute.yml +2 -2
  197. data/examples/profile-attribute/README.md +14 -14
  198. data/examples/profile-attribute/controls/example.rb +11 -11
  199. data/examples/profile-attribute/inspec.yml +8 -8
  200. data/examples/profile-aws/controls/iam_password_policy_expiration.rb +8 -8
  201. data/examples/profile-aws/controls/iam_password_policy_max_age.rb +8 -8
  202. data/examples/profile-aws/controls/iam_root_user_mfa.rb +8 -8
  203. data/examples/profile-aws/controls/iam_users_access_key_age.rb +8 -8
  204. data/examples/profile-aws/controls/iam_users_console_users_mfa.rb +8 -8
  205. data/examples/profile-aws/inspec.yml +11 -11
  206. data/examples/profile-azure/controls/azure_resource_group_example.rb +24 -24
  207. data/examples/profile-azure/controls/azure_vm_example.rb +29 -29
  208. data/examples/profile-azure/inspec.yml +11 -11
  209. data/examples/profile-sensitive/README.md +29 -29
  210. data/examples/profile-sensitive/controls/sensitive-failures.rb +9 -9
  211. data/examples/profile-sensitive/controls/sensitive.rb +9 -9
  212. data/examples/profile-sensitive/inspec.yml +8 -8
  213. data/examples/profile/README.md +48 -48
  214. data/examples/profile/controls/example.rb +23 -23
  215. data/examples/profile/controls/gordon.rb +36 -36
  216. data/examples/profile/controls/meta.rb +34 -34
  217. data/examples/profile/inspec.yml +10 -10
  218. data/examples/profile/libraries/gordon_config.rb +53 -53
  219. data/inspec.gemspec +47 -47
  220. data/lib/bundles/README.md +3 -3
  221. data/lib/bundles/inspec-artifact.rb +7 -7
  222. data/lib/bundles/inspec-artifact/README.md +1 -1
  223. data/lib/bundles/inspec-artifact/cli.rb +277 -277
  224. data/lib/bundles/inspec-compliance.rb +16 -16
  225. data/lib/bundles/inspec-compliance/.kitchen.yml +20 -20
  226. data/lib/bundles/inspec-compliance/README.md +185 -185
  227. data/lib/bundles/inspec-compliance/api.rb +316 -316
  228. data/lib/bundles/inspec-compliance/api/login.rb +152 -152
  229. data/lib/bundles/inspec-compliance/bootstrap.sh +41 -41
  230. data/lib/bundles/inspec-compliance/cli.rb +254 -254
  231. data/lib/bundles/inspec-compliance/configuration.rb +103 -103
  232. data/lib/bundles/inspec-compliance/http.rb +86 -86
  233. data/lib/bundles/inspec-compliance/support.rb +36 -36
  234. data/lib/bundles/inspec-compliance/target.rb +98 -98
  235. data/lib/bundles/inspec-compliance/test/integration/default/cli.rb +93 -93
  236. data/lib/bundles/inspec-habitat.rb +12 -12
  237. data/lib/bundles/inspec-habitat/cli.rb +36 -36
  238. data/lib/bundles/inspec-habitat/log.rb +10 -10
  239. data/lib/bundles/inspec-habitat/profile.rb +390 -390
  240. data/lib/bundles/inspec-init.rb +8 -8
  241. data/lib/bundles/inspec-init/README.md +31 -31
  242. data/lib/bundles/inspec-init/cli.rb +97 -97
  243. data/lib/bundles/inspec-init/templates/profile/README.md +3 -3
  244. data/lib/bundles/inspec-init/templates/profile/controls/example.rb +19 -19
  245. data/lib/bundles/inspec-init/templates/profile/inspec.yml +8 -8
  246. data/lib/bundles/inspec-supermarket.rb +13 -13
  247. data/lib/bundles/inspec-supermarket/README.md +45 -45
  248. data/lib/bundles/inspec-supermarket/api.rb +84 -84
  249. data/lib/bundles/inspec-supermarket/cli.rb +73 -73
  250. data/lib/bundles/inspec-supermarket/target.rb +34 -34
  251. data/lib/fetchers/git.rb +163 -163
  252. data/lib/fetchers/local.rb +74 -74
  253. data/lib/fetchers/mock.rb +35 -35
  254. data/lib/fetchers/url.rb +204 -204
  255. data/lib/inspec.rb +24 -24
  256. data/lib/inspec/archive/tar.rb +29 -29
  257. data/lib/inspec/archive/zip.rb +19 -19
  258. data/lib/inspec/backend.rb +93 -93
  259. data/lib/inspec/base_cli.rb +357 -355
  260. data/lib/inspec/cached_fetcher.rb +66 -66
  261. data/lib/inspec/cli.rb +292 -292
  262. data/lib/inspec/completions/bash.sh.erb +45 -45
  263. data/lib/inspec/completions/fish.sh.erb +34 -34
  264. data/lib/inspec/completions/zsh.sh.erb +61 -61
  265. data/lib/inspec/control_eval_context.rb +179 -179
  266. data/lib/inspec/dependencies/cache.rb +72 -72
  267. data/lib/inspec/dependencies/dependency_set.rb +92 -92
  268. data/lib/inspec/dependencies/lockfile.rb +115 -115
  269. data/lib/inspec/dependencies/requirement.rb +123 -123
  270. data/lib/inspec/dependencies/resolver.rb +86 -86
  271. data/lib/inspec/describe.rb +27 -27
  272. data/lib/inspec/dsl.rb +66 -66
  273. data/lib/inspec/dsl_shared.rb +33 -33
  274. data/lib/inspec/env_printer.rb +157 -157
  275. data/lib/inspec/errors.rb +13 -13
  276. data/lib/inspec/exceptions.rb +12 -12
  277. data/lib/inspec/expect.rb +45 -45
  278. data/lib/inspec/fetcher.rb +45 -45
  279. data/lib/inspec/file_provider.rb +275 -275
  280. data/lib/inspec/formatters.rb +3 -3
  281. data/lib/inspec/formatters/base.rb +250 -250
  282. data/lib/inspec/formatters/json_rspec.rb +20 -20
  283. data/lib/inspec/formatters/show_progress.rb +12 -12
  284. data/lib/inspec/library_eval_context.rb +58 -58
  285. data/lib/inspec/log.rb +11 -11
  286. data/lib/inspec/metadata.rb +247 -247
  287. data/lib/inspec/method_source.rb +24 -24
  288. data/lib/inspec/objects.rb +14 -14
  289. data/lib/inspec/objects/attribute.rb +65 -65
  290. data/lib/inspec/objects/control.rb +61 -61
  291. data/lib/inspec/objects/describe.rb +92 -92
  292. data/lib/inspec/objects/each_loop.rb +36 -36
  293. data/lib/inspec/objects/list.rb +15 -15
  294. data/lib/inspec/objects/or_test.rb +40 -40
  295. data/lib/inspec/objects/ruby_helper.rb +15 -15
  296. data/lib/inspec/objects/tag.rb +27 -27
  297. data/lib/inspec/objects/test.rb +87 -87
  298. data/lib/inspec/objects/value.rb +27 -27
  299. data/lib/inspec/plugins.rb +60 -60
  300. data/lib/inspec/plugins/cli.rb +24 -24
  301. data/lib/inspec/plugins/fetcher.rb +86 -86
  302. data/lib/inspec/plugins/resource.rb +135 -135
  303. data/lib/inspec/plugins/secret.rb +15 -15
  304. data/lib/inspec/plugins/source_reader.rb +40 -40
  305. data/lib/inspec/polyfill.rb +12 -12
  306. data/lib/inspec/profile.rb +510 -510
  307. data/lib/inspec/profile_context.rb +207 -207
  308. data/lib/inspec/profile_vendor.rb +66 -66
  309. data/lib/inspec/reporters.rb +54 -54
  310. data/lib/inspec/reporters/base.rb +24 -24
  311. data/lib/inspec/reporters/cli.rb +356 -356
  312. data/lib/inspec/reporters/json.rb +116 -116
  313. data/lib/inspec/reporters/json_min.rb +48 -48
  314. data/lib/inspec/reporters/junit.rb +77 -77
  315. data/lib/inspec/require_loader.rb +33 -33
  316. data/lib/inspec/resource.rb +186 -186
  317. data/lib/inspec/rule.rb +266 -266
  318. data/lib/inspec/runner.rb +345 -345
  319. data/lib/inspec/runner_mock.rb +41 -41
  320. data/lib/inspec/runner_rspec.rb +175 -175
  321. data/lib/inspec/runtime_profile.rb +26 -26
  322. data/lib/inspec/schema.rb +213 -213
  323. data/lib/inspec/secrets.rb +19 -19
  324. data/lib/inspec/secrets/yaml.rb +30 -30
  325. data/lib/inspec/shell.rb +220 -220
  326. data/lib/inspec/shell_detector.rb +90 -90
  327. data/lib/inspec/source_reader.rb +29 -29
  328. data/lib/inspec/version.rb +8 -8
  329. data/lib/matchers/matchers.rb +339 -339
  330. data/lib/resource_support/aws.rb +44 -41
  331. data/lib/resource_support/aws/aws_backend_base.rb +12 -12
  332. data/lib/resource_support/aws/aws_backend_factory_mixin.rb +12 -12
  333. data/lib/resource_support/aws/aws_plural_resource_mixin.rb +21 -21
  334. data/lib/resource_support/aws/aws_resource_mixin.rb +66 -66
  335. data/lib/resource_support/aws/aws_singular_resource_mixin.rb +24 -24
  336. data/lib/resources/aide_conf.rb +151 -159
  337. data/lib/resources/apache.rb +48 -48
  338. data/lib/resources/apache_conf.rb +149 -156
  339. data/lib/resources/apt.rb +149 -149
  340. data/lib/resources/audit_policy.rb +63 -63
  341. data/lib/resources/auditd.rb +231 -231
  342. data/lib/resources/auditd_conf.rb +46 -55
  343. data/lib/resources/aws/aws_cloudtrail_trail.rb +77 -77
  344. data/lib/resources/aws/aws_cloudtrail_trails.rb +47 -47
  345. data/lib/resources/aws/aws_cloudwatch_alarm.rb +62 -62
  346. data/lib/resources/aws/aws_cloudwatch_log_metric_filter.rb +100 -100
  347. data/lib/resources/aws/aws_config_recorder.rb +98 -98
  348. data/lib/resources/aws/aws_ec2_instance.rb +157 -157
  349. data/lib/resources/aws/aws_iam_access_key.rb +106 -106
  350. data/lib/resources/aws/aws_iam_access_keys.rb +149 -149
  351. data/lib/resources/aws/aws_iam_group.rb +56 -56
  352. data/lib/resources/aws/aws_iam_groups.rb +52 -52
  353. data/lib/resources/aws/aws_iam_password_policy.rb +116 -116
  354. data/lib/resources/aws/aws_iam_policies.rb +53 -53
  355. data/lib/resources/aws/aws_iam_policy.rb +125 -125
  356. data/lib/resources/aws/aws_iam_role.rb +51 -51
  357. data/lib/resources/aws/aws_iam_root_user.rb +60 -60
  358. data/lib/resources/aws/aws_iam_user.rb +111 -111
  359. data/lib/resources/aws/aws_iam_users.rb +108 -108
  360. data/lib/resources/aws/aws_kms_keys.rb +53 -53
  361. data/lib/resources/aws/aws_route_table.rb +61 -61
  362. data/lib/resources/aws/aws_s3_bucket.rb +115 -115
  363. data/lib/resources/aws/aws_s3_bucket_object.rb +82 -0
  364. data/lib/resources/aws/aws_security_group.rb +93 -93
  365. data/lib/resources/aws/aws_security_groups.rb +68 -68
  366. data/lib/resources/aws/aws_sns_subscription.rb +78 -0
  367. data/lib/resources/aws/aws_sns_topic.rb +53 -53
  368. data/lib/resources/aws/aws_sns_topics.rb +56 -0
  369. data/lib/resources/aws/aws_subnet.rb +88 -88
  370. data/lib/resources/aws/aws_subnets.rb +53 -53
  371. data/lib/resources/aws/aws_vpc.rb +69 -69
  372. data/lib/resources/aws/aws_vpcs.rb +45 -45
  373. data/lib/resources/azure/azure_backend.rb +377 -377
  374. data/lib/resources/azure/azure_generic_resource.rb +59 -59
  375. data/lib/resources/azure/azure_resource_group.rb +152 -152
  376. data/lib/resources/azure/azure_virtual_machine.rb +264 -264
  377. data/lib/resources/azure/azure_virtual_machine_data_disk.rb +136 -136
  378. data/lib/resources/bash.rb +35 -35
  379. data/lib/resources/bond.rb +69 -68
  380. data/lib/resources/bridge.rb +122 -122
  381. data/lib/resources/command.rb +73 -73
  382. data/lib/resources/cpan.rb +58 -58
  383. data/lib/resources/cran.rb +64 -64
  384. data/lib/resources/crontab.rb +169 -169
  385. data/lib/resources/csv.rb +56 -60
  386. data/lib/resources/dh_params.rb +77 -82
  387. data/lib/resources/directory.rb +25 -25
  388. data/lib/resources/docker.rb +236 -236
  389. data/lib/resources/docker_container.rb +89 -89
  390. data/lib/resources/docker_image.rb +83 -83
  391. data/lib/resources/docker_object.rb +57 -57
  392. data/lib/resources/docker_service.rb +90 -90
  393. data/lib/resources/elasticsearch.rb +169 -169
  394. data/lib/resources/etc_fstab.rb +94 -101
  395. data/lib/resources/etc_group.rb +152 -152
  396. data/lib/resources/etc_hosts.rb +66 -82
  397. data/lib/resources/etc_hosts_allow_deny.rb +112 -122
  398. data/lib/resources/file.rb +298 -298
  399. data/lib/resources/filesystem.rb +31 -31
  400. data/lib/resources/firewalld.rb +143 -143
  401. data/lib/resources/gem.rb +70 -70
  402. data/lib/resources/groups.rb +215 -215
  403. data/lib/resources/grub_conf.rb +227 -237
  404. data/lib/resources/host.rb +306 -306
  405. data/lib/resources/http.rb +251 -251
  406. data/lib/resources/iis_app.rb +101 -101
  407. data/lib/resources/iis_site.rb +148 -148
  408. data/lib/resources/inetd_conf.rb +54 -62
  409. data/lib/resources/ini.rb +29 -29
  410. data/lib/resources/interface.rb +129 -129
  411. data/lib/resources/iptables.rb +80 -80
  412. data/lib/resources/json.rb +107 -117
  413. data/lib/resources/kernel_module.rb +107 -107
  414. data/lib/resources/kernel_parameter.rb +58 -58
  415. data/lib/resources/key_rsa.rb +61 -67
  416. data/lib/resources/limits_conf.rb +46 -55
  417. data/lib/resources/login_def.rb +57 -66
  418. data/lib/resources/mount.rb +88 -88
  419. data/lib/resources/mssql_session.rb +101 -101
  420. data/lib/resources/mysql.rb +81 -81
  421. data/lib/resources/mysql_conf.rb +127 -134
  422. data/lib/resources/mysql_session.rb +85 -85
  423. data/lib/resources/nginx.rb +96 -96
  424. data/lib/resources/nginx_conf.rb +226 -227
  425. data/lib/resources/npm.rb +48 -48
  426. data/lib/resources/ntp_conf.rb +51 -58
  427. data/lib/resources/oneget.rb +71 -71
  428. data/lib/resources/oracledb_session.rb +139 -139
  429. data/lib/resources/os.rb +36 -36
  430. data/lib/resources/os_env.rb +76 -76
  431. data/lib/resources/package.rb +370 -370
  432. data/lib/resources/packages.rb +111 -111
  433. data/lib/resources/parse_config.rb +112 -116
  434. data/lib/resources/passwd.rb +76 -74
  435. data/lib/resources/pip.rb +89 -89
  436. data/lib/resources/platform.rb +109 -109
  437. data/lib/resources/port.rb +771 -771
  438. data/lib/resources/postgres.rb +130 -130
  439. data/lib/resources/postgres_conf.rb +114 -121
  440. data/lib/resources/postgres_hba_conf.rb +90 -99
  441. data/lib/resources/postgres_ident_conf.rb +79 -76
  442. data/lib/resources/postgres_session.rb +71 -71
  443. data/lib/resources/powershell.rb +53 -53
  444. data/lib/resources/processes.rb +204 -204
  445. data/lib/resources/rabbitmq_conf.rb +51 -52
  446. data/lib/resources/registry_key.rb +296 -296
  447. data/lib/resources/security_policy.rb +180 -180
  448. data/lib/resources/service.rb +790 -789
  449. data/lib/resources/shadow.rb +149 -146
  450. data/lib/resources/ssh_conf.rb +97 -102
  451. data/lib/resources/ssl.rb +99 -99
  452. data/lib/resources/sys_info.rb +28 -28
  453. data/lib/resources/toml.rb +32 -32
  454. data/lib/resources/users.rb +654 -654
  455. data/lib/resources/vbscript.rb +68 -68
  456. data/lib/resources/virtualization.rb +247 -247
  457. data/lib/resources/windows_feature.rb +84 -84
  458. data/lib/resources/windows_hotfix.rb +35 -35
  459. data/lib/resources/windows_task.rb +102 -102
  460. data/lib/resources/wmi.rb +110 -110
  461. data/lib/resources/x509_certificate.rb +137 -143
  462. data/lib/resources/xinetd.rb +106 -111
  463. data/lib/resources/xml.rb +46 -46
  464. data/lib/resources/yaml.rb +43 -47
  465. data/lib/resources/yum.rb +180 -180
  466. data/lib/resources/zfs_dataset.rb +60 -60
  467. data/lib/resources/zfs_pool.rb +49 -49
  468. data/lib/source_readers/flat.rb +39 -39
  469. data/lib/source_readers/inspec.rb +75 -75
  470. data/lib/utils/command_wrapper.rb +27 -27
  471. data/lib/utils/convert.rb +12 -12
  472. data/lib/utils/database_helpers.rb +77 -77
  473. data/lib/utils/erlang_parser.rb +192 -192
  474. data/lib/utils/file_reader.rb +25 -0
  475. data/lib/utils/filter.rb +272 -272
  476. data/lib/utils/filter_array.rb +27 -27
  477. data/lib/utils/find_files.rb +44 -44
  478. data/lib/utils/hash.rb +41 -41
  479. data/lib/utils/json_log.rb +18 -18
  480. data/lib/utils/latest_version.rb +22 -22
  481. data/lib/utils/modulator.rb +12 -12
  482. data/lib/utils/nginx_parser.rb +85 -85
  483. data/lib/utils/object_traversal.rb +49 -49
  484. data/lib/utils/parser.rb +274 -274
  485. data/lib/utils/plugin_registry.rb +93 -93
  486. data/lib/utils/simpleconfig.rb +120 -120
  487. data/lib/utils/spdx.rb +13 -13
  488. data/lib/utils/spdx.txt +343 -343
  489. metadata +12 -5
@@ -1,100 +1,100 @@
1
- class AwsCloudwatchLogMetricFilter < Inspec.resource(1)
2
- name 'aws_cloudwatch_log_metric_filter'
3
- desc 'Verifies individual Cloudwatch Log Metric Filters'
4
- example <<-EOX
5
- # Look for a LMF by its filter name and log group name. This combination
6
- # will always either find at most one LMF - no duplicates.
7
- describe aws_cloudwatch_log_metric_filter(
8
- filter_name: 'my-filter',
9
- log_group_name: 'my-log-group'
10
- ) do
11
- it { should exist }
12
- end
13
-
14
- # Search for an LMF by pattern and log group.
15
- # This could result in an error if the results are not unique.
16
- describe aws_cloudwatch_log_metric_filter(
17
- log_group_name: 'my-log-group',
18
- pattern: 'my-filter'
19
- ) do
20
- it { should exist }
21
- end
22
- EOX
23
- supports platform: 'aws'
24
- include AwsSingularResourceMixin
25
- attr_reader :filter_name, :log_group_name, :metric_name, :metric_namespace, :pattern
26
-
27
- private
28
-
29
- def validate_params(raw_params)
30
- validated_params = check_resource_param_names(
31
- raw_params: raw_params,
32
- allowed_params: [:filter_name, :log_group_name, :pattern],
33
- )
34
- if validated_params.empty?
35
- raise ArgumentError, 'You must provide either filter_name, log_group, or pattern to aws_cloudwatch_log_metric_filter.'
36
- end
37
- validated_params
38
- end
39
-
40
- def fetch_from_api
41
- # get a backend
42
- backend = BackendFactory.create(inspec_runner)
43
-
44
- # Perform query with remote filtering
45
- aws_search_criteria = {}
46
- aws_search_criteria[:filter_name] = filter_name if filter_name
47
- aws_search_criteria[:log_group_name] = log_group_name if log_group_name
48
- begin
49
- aws_results = backend.describe_metric_filters(aws_search_criteria)
50
- rescue Aws::CloudWatchLogs::Errors::ResourceNotFoundException
51
- @exists = false
52
- return
53
- end
54
-
55
- # Then perform local filtering
56
- if pattern
57
- aws_results.select! { |lmf| lmf.filter_pattern == pattern }
58
- end
59
-
60
- # Check result count. We're a singular resource and can tolerate
61
- # 0 or 1 results, not multiple.
62
- if aws_results.count > 1
63
- raise 'More than one result was returned, but aws_cloudwatch_log_metric_filter '\
64
- 'can only handle a single AWS resource. Consider passing more resource '\
65
- 'parameters to narrow down the search.'
66
- elsif aws_results.empty?
67
- @exists = false
68
- else
69
- @exists = true
70
- # Unpack the funny-shaped object we got back from AWS into our instance vars
71
- lmf = aws_results.first
72
- @filter_name = lmf.filter_name
73
- @log_group_name = lmf.log_group_name
74
- @pattern = lmf.filter_pattern # Note inconsistent name
75
- # AWS SDK returns an array of metric transformations
76
- # but only allows one (mandatory) entry, let's flatten that
77
- @metric_name = lmf.metric_transformations.first.metric_name
78
- @metric_namespace = lmf.metric_transformations.first.metric_namespace
79
- end
80
- end
81
-
82
- class Backend
83
- # Uses the cloudwatch API to really talk to AWS
84
- class AwsClientApi < AwsBackendBase
85
- BackendFactory.set_default_backend(self)
86
- self.aws_client_class = Aws::CloudWatchLogs::Client
87
-
88
- def describe_metric_filters(criteria)
89
- query = {}
90
- query[:filter_name_prefix] = criteria[:filter_name] if criteria[:filter_name]
91
- query[:log_group_name] = criteria[:log_group_name] if criteria[:log_group_name]
92
- # 'pattern' is not available as a remote filter,
93
- # we filter it after the fact locally
94
- # TODO: handle pagination? Max 50/page. Maybe you want a plural resource?
95
- aws_response = aws_service_client.describe_metric_filters(query)
96
- aws_response.metric_filters
97
- end
98
- end
99
- end
100
- end
1
+ class AwsCloudwatchLogMetricFilter < Inspec.resource(1)
2
+ name 'aws_cloudwatch_log_metric_filter'
3
+ desc 'Verifies individual Cloudwatch Log Metric Filters'
4
+ example <<-EOX
5
+ # Look for a LMF by its filter name and log group name. This combination
6
+ # will always either find at most one LMF - no duplicates.
7
+ describe aws_cloudwatch_log_metric_filter(
8
+ filter_name: 'my-filter',
9
+ log_group_name: 'my-log-group'
10
+ ) do
11
+ it { should exist }
12
+ end
13
+
14
+ # Search for an LMF by pattern and log group.
15
+ # This could result in an error if the results are not unique.
16
+ describe aws_cloudwatch_log_metric_filter(
17
+ log_group_name: 'my-log-group',
18
+ pattern: 'my-filter'
19
+ ) do
20
+ it { should exist }
21
+ end
22
+ EOX
23
+ supports platform: 'aws'
24
+ include AwsSingularResourceMixin
25
+ attr_reader :filter_name, :log_group_name, :metric_name, :metric_namespace, :pattern
26
+
27
+ private
28
+
29
+ def validate_params(raw_params)
30
+ validated_params = check_resource_param_names(
31
+ raw_params: raw_params,
32
+ allowed_params: [:filter_name, :log_group_name, :pattern],
33
+ )
34
+ if validated_params.empty?
35
+ raise ArgumentError, 'You must provide either filter_name, log_group, or pattern to aws_cloudwatch_log_metric_filter.'
36
+ end
37
+ validated_params
38
+ end
39
+
40
+ def fetch_from_api
41
+ # get a backend
42
+ backend = BackendFactory.create(inspec_runner)
43
+
44
+ # Perform query with remote filtering
45
+ aws_search_criteria = {}
46
+ aws_search_criteria[:filter_name] = filter_name if filter_name
47
+ aws_search_criteria[:log_group_name] = log_group_name if log_group_name
48
+ begin
49
+ aws_results = backend.describe_metric_filters(aws_search_criteria)
50
+ rescue Aws::CloudWatchLogs::Errors::ResourceNotFoundException
51
+ @exists = false
52
+ return
53
+ end
54
+
55
+ # Then perform local filtering
56
+ if pattern
57
+ aws_results.select! { |lmf| lmf.filter_pattern == pattern }
58
+ end
59
+
60
+ # Check result count. We're a singular resource and can tolerate
61
+ # 0 or 1 results, not multiple.
62
+ if aws_results.count > 1
63
+ raise 'More than one result was returned, but aws_cloudwatch_log_metric_filter '\
64
+ 'can only handle a single AWS resource. Consider passing more resource '\
65
+ 'parameters to narrow down the search.'
66
+ elsif aws_results.empty?
67
+ @exists = false
68
+ else
69
+ @exists = true
70
+ # Unpack the funny-shaped object we got back from AWS into our instance vars
71
+ lmf = aws_results.first
72
+ @filter_name = lmf.filter_name
73
+ @log_group_name = lmf.log_group_name
74
+ @pattern = lmf.filter_pattern # Note inconsistent name
75
+ # AWS SDK returns an array of metric transformations
76
+ # but only allows one (mandatory) entry, let's flatten that
77
+ @metric_name = lmf.metric_transformations.first.metric_name
78
+ @metric_namespace = lmf.metric_transformations.first.metric_namespace
79
+ end
80
+ end
81
+
82
+ class Backend
83
+ # Uses the cloudwatch API to really talk to AWS
84
+ class AwsClientApi < AwsBackendBase
85
+ BackendFactory.set_default_backend(self)
86
+ self.aws_client_class = Aws::CloudWatchLogs::Client
87
+
88
+ def describe_metric_filters(criteria)
89
+ query = {}
90
+ query[:filter_name_prefix] = criteria[:filter_name] if criteria[:filter_name]
91
+ query[:log_group_name] = criteria[:log_group_name] if criteria[:log_group_name]
92
+ # 'pattern' is not available as a remote filter,
93
+ # we filter it after the fact locally
94
+ # TODO: handle pagination? Max 50/page. Maybe you want a plural resource?
95
+ aws_response = aws_service_client.describe_metric_filters(query)
96
+ aws_response.metric_filters
97
+ end
98
+ end
99
+ end
100
+ end
@@ -1,98 +1,98 @@
1
- class AwsConfigurationRecorder < Inspec.resource(1)
2
- name 'aws_config_recorder'
3
- desc 'Verifies settings for AWS Configuration Recorder'
4
- example "
5
- describe aws_config_recorder('My_Recorder') do
6
- it { should exist }
7
- it { should be_recording }
8
- it { should be_all_supported }
9
- it { should have_include_global_resource_types }
10
- end
11
- "
12
- supports platform: 'aws'
13
-
14
- include AwsSingularResourceMixin
15
- attr_reader :role_arn, :resource_types, :recorder_name, :resp
16
-
17
- def to_s
18
- "Configuration_Recorder: #{@recorder_name}"
19
- end
20
-
21
- def recording_all_resource_types?
22
- @recording_all_resource_types
23
- end
24
-
25
- def recording_all_global_types?
26
- @recording_all_global_types
27
- end
28
-
29
- def status
30
- return unless @exists
31
- backend = BackendFactory.create(inspec_runner)
32
- catch_aws_errors do
33
- @resp = backend.describe_configuration_recorder_status(@query)
34
- @status = @resp.configuration_recorders_status.first.to_h
35
- end
36
- end
37
-
38
- def recording?
39
- return unless @exists
40
- status[:recording]
41
- end
42
-
43
- private
44
-
45
- def validate_params(raw_params)
46
- validated_params = check_resource_param_names(
47
- raw_params: raw_params,
48
- allowed_params: [:recorder_name],
49
- allowed_scalar_name: :recorder_name,
50
- allowed_scalar_type: String,
51
- )
52
-
53
- # Must give it a recorder_name
54
- if validated_params[:recorder_name].nil?
55
- raise ArgumentError, 'You must provide recorder_name to aws_config_recorder'
56
- end
57
-
58
- validated_params
59
- end
60
-
61
- def fetch_from_api
62
- backend = BackendFactory.create(inspec_runner)
63
- @query = { configuration_recorder_names: [@recorder_name] }
64
-
65
- catch_aws_errors do
66
- begin
67
- @resp = backend.describe_configuration_recorders(@query)
68
- rescue Aws::ConfigService::Errors::NoSuchConfigurationRecorderException
69
- @exists = false
70
- return
71
- end
72
- @exists = !@resp.empty?
73
- return unless @exists
74
-
75
- @recorder = @resp.configuration_recorders.first.to_h
76
- @recorder_name = @recorder[:name]
77
- @role_arn = @recorder[:role_arn]
78
- @recording_all_resource_types = @recorder[:recording_group][:all_supported]
79
- @recording_all_global_types = @recorder[:recording_group][:include_global_resource_types]
80
- @resource_types = @recorder[:recording_group][:resource_types]
81
- end
82
- end
83
-
84
- class Backend
85
- class AwsClientApi < AwsBackendBase
86
- BackendFactory.set_default_backend(self)
87
- self.aws_client_class = Aws::ConfigService::Client
88
-
89
- def describe_configuration_recorders(query)
90
- aws_service_client.describe_configuration_recorders(query)
91
- end
92
-
93
- def describe_configuration_recorder_status(query)
94
- aws_service_client.describe_configuration_recorder_status(query)
95
- end
96
- end
97
- end
98
- end
1
+ class AwsConfigurationRecorder < Inspec.resource(1)
2
+ name 'aws_config_recorder'
3
+ desc 'Verifies settings for AWS Configuration Recorder'
4
+ example "
5
+ describe aws_config_recorder('My_Recorder') do
6
+ it { should exist }
7
+ it { should be_recording }
8
+ it { should be_all_supported }
9
+ it { should have_include_global_resource_types }
10
+ end
11
+ "
12
+ supports platform: 'aws'
13
+
14
+ include AwsSingularResourceMixin
15
+ attr_reader :role_arn, :resource_types, :recorder_name, :resp
16
+
17
+ def to_s
18
+ "Configuration_Recorder: #{@recorder_name}"
19
+ end
20
+
21
+ def recording_all_resource_types?
22
+ @recording_all_resource_types
23
+ end
24
+
25
+ def recording_all_global_types?
26
+ @recording_all_global_types
27
+ end
28
+
29
+ def status
30
+ return unless @exists
31
+ backend = BackendFactory.create(inspec_runner)
32
+ catch_aws_errors do
33
+ @resp = backend.describe_configuration_recorder_status(@query)
34
+ @status = @resp.configuration_recorders_status.first.to_h
35
+ end
36
+ end
37
+
38
+ def recording?
39
+ return unless @exists
40
+ status[:recording]
41
+ end
42
+
43
+ private
44
+
45
+ def validate_params(raw_params)
46
+ validated_params = check_resource_param_names(
47
+ raw_params: raw_params,
48
+ allowed_params: [:recorder_name],
49
+ allowed_scalar_name: :recorder_name,
50
+ allowed_scalar_type: String,
51
+ )
52
+
53
+ # Must give it a recorder_name
54
+ if validated_params[:recorder_name].nil?
55
+ raise ArgumentError, 'You must provide recorder_name to aws_config_recorder'
56
+ end
57
+
58
+ validated_params
59
+ end
60
+
61
+ def fetch_from_api
62
+ backend = BackendFactory.create(inspec_runner)
63
+ @query = { configuration_recorder_names: [@recorder_name] }
64
+
65
+ catch_aws_errors do
66
+ begin
67
+ @resp = backend.describe_configuration_recorders(@query)
68
+ rescue Aws::ConfigService::Errors::NoSuchConfigurationRecorderException
69
+ @exists = false
70
+ return
71
+ end
72
+ @exists = !@resp.empty?
73
+ return unless @exists
74
+
75
+ @recorder = @resp.configuration_recorders.first.to_h
76
+ @recorder_name = @recorder[:name]
77
+ @role_arn = @recorder[:role_arn]
78
+ @recording_all_resource_types = @recorder[:recording_group][:all_supported]
79
+ @recording_all_global_types = @recorder[:recording_group][:include_global_resource_types]
80
+ @resource_types = @recorder[:recording_group][:resource_types]
81
+ end
82
+ end
83
+
84
+ class Backend
85
+ class AwsClientApi < AwsBackendBase
86
+ BackendFactory.set_default_backend(self)
87
+ self.aws_client_class = Aws::ConfigService::Client
88
+
89
+ def describe_configuration_recorders(query)
90
+ aws_service_client.describe_configuration_recorders(query)
91
+ end
92
+
93
+ def describe_configuration_recorder_status(query)
94
+ aws_service_client.describe_configuration_recorder_status(query)
95
+ end
96
+ end
97
+ end
98
+ end
@@ -1,157 +1,157 @@
1
- # author: Christoph Hartmann
2
- class AwsEc2Instance < Inspec.resource(1)
3
- name 'aws_ec2_instance'
4
- desc 'Verifies settings for an EC2 instance'
5
-
6
- example <<-EOX
7
- describe aws_ec2_instance('i-123456') do
8
- it { should be_running }
9
- it { should have_roles }
10
- end
11
-
12
- describe aws_ec2_instance(name: 'my-instance') do
13
- it { should be_running }
14
- it { should have_roles }
15
- end
16
- EOX
17
- supports platform: 'aws'
18
-
19
- # TODO: rewrite to avoid direct injection, match other resources, use AwsSingularResourceMixin
20
- def initialize(opts, conn = nil)
21
- @opts = opts
22
- @opts.is_a?(Hash) ? @display_name = @opts[:name] : @display_name = opts
23
- @ec2_client = conn ? conn.ec2_client : inspec_runner.backend.aws_client(Aws::EC2::Client)
24
- @ec2_resource = conn ? conn.ec2_resource : inspec_runner.backend.aws_resource(Aws::EC2::Resource, {})
25
- @iam_resource = conn ? conn.iam_resource : inspec_runner.backend.aws_resource(Aws::IAM::Resource, {})
26
- end
27
-
28
- # TODO: DRY up, see https://github.com/chef/inspec/issues/2633
29
- # Copied from resource_support/aws/aws_resource_mixin.rb
30
- def catch_aws_errors
31
- yield
32
- rescue Aws::Errors::MissingCredentialsError
33
- # The AWS error here is unhelpful:
34
- # "unable to sign request without credentials set"
35
- Inspec::Log.error "It appears that you have not set your AWS credentials. You may set them using environment variables, or using the 'aws://region/aws_credentials_profile' target. See https://www.inspec.io/docs/reference/platforms for details."
36
- fail_resource('No AWS credentials available')
37
- rescue Aws::Errors::ServiceError => e
38
- fail_resource e.message
39
- end
40
-
41
- # TODO: DRY up, see https://github.com/chef/inspec/issues/2633
42
- # Copied from resource_support/aws/aws_singular_resource_mixin.rb
43
- def inspec_runner
44
- # When running under inspec-cli, we have an 'inspec' method that
45
- # returns the runner. When running under unit tests, we don't
46
- # have that, but we still have to call this to pass something
47
- # (nil is OK) to the backend.
48
- # TODO: remove with https://github.com/chef/inspec-aws/issues/216
49
- # TODO: remove after rewrite to include AwsSingularResource
50
- inspec if respond_to?(:inspec)
51
- end
52
-
53
- def id
54
- return @instance_id if defined?(@instance_id)
55
- catch_aws_errors do
56
- if @opts.is_a?(Hash)
57
- first = @ec2_resource.instances(
58
- {
59
- filters: [{
60
- name: 'tag:Name',
61
- values: [@opts[:name]],
62
- }],
63
- },
64
- ).first
65
- # catch case where the instance is not known
66
- @instance_id = first.id unless first.nil?
67
- else
68
- @instance_id = @opts
69
- end
70
- end
71
- end
72
- alias instance_id id
73
-
74
- def exists?
75
- return false if instance.nil?
76
- instance.exists?
77
- end
78
-
79
- # returns the instance state
80
- def state
81
- catch_aws_errors do
82
- instance&.state&.name
83
- end
84
- end
85
-
86
- # helper methods for each state
87
- %w{
88
- pending running shutting-down
89
- terminated stopping stopped unknown
90
- }.each do |state_name|
91
- define_method state_name.tr('-', '_') + '?' do
92
- state == state_name
93
- end
94
- end
95
-
96
- # attributes that we want to expose
97
- %w{
98
- public_ip_address private_ip_address key_name private_dns_name
99
- public_dns_name subnet_id architecture root_device_type
100
- root_device_name virtualization_type client_token launch_time
101
- instance_type image_id vpc_id
102
- }.each do |attribute|
103
- define_method attribute do
104
- catch_aws_errors do
105
- instance.send(attribute) if instance
106
- end
107
- end
108
- end
109
-
110
- # Don't document this - it's a bit hard to use. Our current doctrine
111
- # is to use dumb things, like arrays of strings - use security_group_ids instead.
112
- def security_groups
113
- catch_aws_errors do
114
- @security_groups ||= instance.security_groups.map { |sg|
115
- { id: sg.group_id, name: sg.group_name }
116
- }
117
- end
118
- end
119
-
120
- def security_group_ids
121
- catch_aws_errors do
122
- @security_group_ids ||= instance.security_groups.map(&:group_id)
123
- end
124
- end
125
-
126
- def tags
127
- catch_aws_errors do
128
- @tags ||= instance.tags.map { |tag| { key: tag.key, value: tag.value } }
129
- end
130
- end
131
-
132
- def to_s
133
- "EC2 Instance #{@display_name}"
134
- end
135
-
136
- def has_roles?
137
- catch_aws_errors do
138
- instance_profile = instance.iam_instance_profile
139
-
140
- if instance_profile
141
- roles = @iam_resource.instance_profile(
142
- instance_profile.arn.gsub(%r{^.*\/}, ''),
143
- ).roles
144
- else
145
- roles = nil
146
- end
147
-
148
- roles && !roles.empty?
149
- end
150
- end
151
-
152
- private
153
-
154
- def instance
155
- catch_aws_errors { @instance ||= @ec2_resource.instance(id) }
156
- end
157
- end
1
+ # author: Christoph Hartmann
2
+ class AwsEc2Instance < Inspec.resource(1)
3
+ name 'aws_ec2_instance'
4
+ desc 'Verifies settings for an EC2 instance'
5
+
6
+ example <<-EOX
7
+ describe aws_ec2_instance('i-123456') do
8
+ it { should be_running }
9
+ it { should have_roles }
10
+ end
11
+
12
+ describe aws_ec2_instance(name: 'my-instance') do
13
+ it { should be_running }
14
+ it { should have_roles }
15
+ end
16
+ EOX
17
+ supports platform: 'aws'
18
+
19
+ # TODO: rewrite to avoid direct injection, match other resources, use AwsSingularResourceMixin
20
+ def initialize(opts, conn = nil)
21
+ @opts = opts
22
+ @opts.is_a?(Hash) ? @display_name = @opts[:name] : @display_name = opts
23
+ @ec2_client = conn ? conn.ec2_client : inspec_runner.backend.aws_client(Aws::EC2::Client)
24
+ @ec2_resource = conn ? conn.ec2_resource : inspec_runner.backend.aws_resource(Aws::EC2::Resource, {})
25
+ @iam_resource = conn ? conn.iam_resource : inspec_runner.backend.aws_resource(Aws::IAM::Resource, {})
26
+ end
27
+
28
+ # TODO: DRY up, see https://github.com/chef/inspec/issues/2633
29
+ # Copied from resource_support/aws/aws_resource_mixin.rb
30
+ def catch_aws_errors
31
+ yield
32
+ rescue Aws::Errors::MissingCredentialsError
33
+ # The AWS error here is unhelpful:
34
+ # "unable to sign request without credentials set"
35
+ Inspec::Log.error "It appears that you have not set your AWS credentials. You may set them using environment variables, or using the 'aws://region/aws_credentials_profile' target. See https://www.inspec.io/docs/reference/platforms for details."
36
+ fail_resource('No AWS credentials available')
37
+ rescue Aws::Errors::ServiceError => e
38
+ fail_resource e.message
39
+ end
40
+
41
+ # TODO: DRY up, see https://github.com/chef/inspec/issues/2633
42
+ # Copied from resource_support/aws/aws_singular_resource_mixin.rb
43
+ def inspec_runner
44
+ # When running under inspec-cli, we have an 'inspec' method that
45
+ # returns the runner. When running under unit tests, we don't
46
+ # have that, but we still have to call this to pass something
47
+ # (nil is OK) to the backend.
48
+ # TODO: remove with https://github.com/chef/inspec-aws/issues/216
49
+ # TODO: remove after rewrite to include AwsSingularResource
50
+ inspec if respond_to?(:inspec)
51
+ end
52
+
53
+ def id
54
+ return @instance_id if defined?(@instance_id)
55
+ catch_aws_errors do
56
+ if @opts.is_a?(Hash)
57
+ first = @ec2_resource.instances(
58
+ {
59
+ filters: [{
60
+ name: 'tag:Name',
61
+ values: [@opts[:name]],
62
+ }],
63
+ },
64
+ ).first
65
+ # catch case where the instance is not known
66
+ @instance_id = first.id unless first.nil?
67
+ else
68
+ @instance_id = @opts
69
+ end
70
+ end
71
+ end
72
+ alias instance_id id
73
+
74
+ def exists?
75
+ return false if instance.nil?
76
+ instance.exists?
77
+ end
78
+
79
+ # returns the instance state
80
+ def state
81
+ catch_aws_errors do
82
+ instance&.state&.name
83
+ end
84
+ end
85
+
86
+ # helper methods for each state
87
+ %w{
88
+ pending running shutting-down
89
+ terminated stopping stopped unknown
90
+ }.each do |state_name|
91
+ define_method state_name.tr('-', '_') + '?' do
92
+ state == state_name
93
+ end
94
+ end
95
+
96
+ # attributes that we want to expose
97
+ %w{
98
+ public_ip_address private_ip_address key_name private_dns_name
99
+ public_dns_name subnet_id architecture root_device_type
100
+ root_device_name virtualization_type client_token launch_time
101
+ instance_type image_id vpc_id
102
+ }.each do |attribute|
103
+ define_method attribute do
104
+ catch_aws_errors do
105
+ instance.send(attribute) if instance
106
+ end
107
+ end
108
+ end
109
+
110
+ # Don't document this - it's a bit hard to use. Our current doctrine
111
+ # is to use dumb things, like arrays of strings - use security_group_ids instead.
112
+ def security_groups
113
+ catch_aws_errors do
114
+ @security_groups ||= instance.security_groups.map { |sg|
115
+ { id: sg.group_id, name: sg.group_name }
116
+ }
117
+ end
118
+ end
119
+
120
+ def security_group_ids
121
+ catch_aws_errors do
122
+ @security_group_ids ||= instance.security_groups.map(&:group_id)
123
+ end
124
+ end
125
+
126
+ def tags
127
+ catch_aws_errors do
128
+ @tags ||= instance.tags.map { |tag| { key: tag.key, value: tag.value } }
129
+ end
130
+ end
131
+
132
+ def to_s
133
+ "EC2 Instance #{@display_name}"
134
+ end
135
+
136
+ def has_roles?
137
+ catch_aws_errors do
138
+ instance_profile = instance.iam_instance_profile
139
+
140
+ if instance_profile
141
+ roles = @iam_resource.instance_profile(
142
+ instance_profile.arn.gsub(%r{^.*\/}, ''),
143
+ ).roles
144
+ else
145
+ roles = nil
146
+ end
147
+
148
+ roles && !roles.empty?
149
+ end
150
+ end
151
+
152
+ private
153
+
154
+ def instance
155
+ catch_aws_errors { @instance ||= @ec2_resource.instance(id) }
156
+ end
157
+ end