inspec 4.18.51 → 4.18.85

Sign up to get free protection for your applications and to get access to all the features.
Files changed (371) hide show
  1. checksums.yaml +4 -4
  2. data/inspec.gemspec +15 -37
  3. data/lib/resource_support/aws/aws_resource_mixin.rb +1 -1
  4. metadata +22 -709
  5. data/Gemfile +0 -61
  6. data/LICENSE +0 -14
  7. data/README.md +0 -474
  8. data/etc/deprecations.json +0 -125
  9. data/etc/plugin_filters.json +0 -45
  10. data/lib/bundles/README.md +0 -3
  11. data/lib/bundles/inspec-compliance/api.rb +0 -7
  12. data/lib/bundles/inspec-compliance/configuration.rb +0 -7
  13. data/lib/bundles/inspec-compliance/http.rb +0 -7
  14. data/lib/bundles/inspec-compliance/support.rb +0 -7
  15. data/lib/bundles/inspec-compliance/target.rb +0 -7
  16. data/lib/bundles/inspec-supermarket.rb +0 -9
  17. data/lib/bundles/inspec-supermarket/README.md +0 -45
  18. data/lib/bundles/inspec-supermarket/api.rb +0 -87
  19. data/lib/bundles/inspec-supermarket/cli.rb +0 -71
  20. data/lib/bundles/inspec-supermarket/target.rb +0 -31
  21. data/lib/inspec.rb +0 -30
  22. data/lib/inspec/archive/tar.rb +0 -25
  23. data/lib/inspec/archive/zip.rb +0 -15
  24. data/lib/inspec/backend.rb +0 -101
  25. data/lib/inspec/base_cli.rb +0 -318
  26. data/lib/inspec/cached_fetcher.rb +0 -65
  27. data/lib/inspec/cli.rb +0 -469
  28. data/lib/inspec/completions/bash.sh.erb +0 -45
  29. data/lib/inspec/completions/fish.sh.erb +0 -34
  30. data/lib/inspec/completions/zsh.sh.erb +0 -61
  31. data/lib/inspec/config.rb +0 -511
  32. data/lib/inspec/control_eval_context.rb +0 -248
  33. data/lib/inspec/dependencies/cache.rb +0 -74
  34. data/lib/inspec/dependencies/dependency_set.rb +0 -93
  35. data/lib/inspec/dependencies/lockfile.rb +0 -115
  36. data/lib/inspec/dependencies/requirement.rb +0 -135
  37. data/lib/inspec/dependencies/resolver.rb +0 -86
  38. data/lib/inspec/describe_base.rb +0 -53
  39. data/lib/inspec/dist.rb +0 -20
  40. data/lib/inspec/dsl.rb +0 -115
  41. data/lib/inspec/dsl_shared.rb +0 -32
  42. data/lib/inspec/env_printer.rb +0 -156
  43. data/lib/inspec/errors.rb +0 -18
  44. data/lib/inspec/exceptions.rb +0 -11
  45. data/lib/inspec/expect.rb +0 -42
  46. data/lib/inspec/fetcher.rb +0 -48
  47. data/lib/inspec/fetcher/git.rb +0 -211
  48. data/lib/inspec/fetcher/local.rb +0 -116
  49. data/lib/inspec/fetcher/mock.rb +0 -34
  50. data/lib/inspec/fetcher/url.rb +0 -281
  51. data/lib/inspec/file_provider.rb +0 -318
  52. data/lib/inspec/formatters.rb +0 -3
  53. data/lib/inspec/formatters/base.rb +0 -269
  54. data/lib/inspec/formatters/json_rspec.rb +0 -20
  55. data/lib/inspec/formatters/show_progress.rb +0 -12
  56. data/lib/inspec/globals.rb +0 -9
  57. data/lib/inspec/impact.rb +0 -36
  58. data/lib/inspec/input.rb +0 -421
  59. data/lib/inspec/input_dsl_helpers.rb +0 -26
  60. data/lib/inspec/input_registry.rb +0 -315
  61. data/lib/inspec/library_eval_context.rb +0 -55
  62. data/lib/inspec/log.rb +0 -7
  63. data/lib/inspec/metadata.rb +0 -253
  64. data/lib/inspec/method_source.rb +0 -20
  65. data/lib/inspec/objects.rb +0 -14
  66. data/lib/inspec/objects/control.rb +0 -85
  67. data/lib/inspec/objects/describe.rb +0 -106
  68. data/lib/inspec/objects/each_loop.rb +0 -41
  69. data/lib/inspec/objects/input.rb +0 -49
  70. data/lib/inspec/objects/list.rb +0 -15
  71. data/lib/inspec/objects/or_test.rb +0 -45
  72. data/lib/inspec/objects/ruby_helper.rb +0 -13
  73. data/lib/inspec/objects/tag.rb +0 -32
  74. data/lib/inspec/objects/test.rb +0 -94
  75. data/lib/inspec/objects/value.rb +0 -32
  76. data/lib/inspec/plugin/v1.rb +0 -2
  77. data/lib/inspec/plugin/v1/plugin_types/cli.rb +0 -22
  78. data/lib/inspec/plugin/v1/plugin_types/fetcher.rb +0 -83
  79. data/lib/inspec/plugin/v1/plugin_types/resource.rb +0 -176
  80. data/lib/inspec/plugin/v1/plugin_types/secret.rb +0 -11
  81. data/lib/inspec/plugin/v1/plugin_types/source_reader.rb +0 -36
  82. data/lib/inspec/plugin/v1/plugins.rb +0 -59
  83. data/lib/inspec/plugin/v1/registry.rb +0 -90
  84. data/lib/inspec/plugin/v2.rb +0 -46
  85. data/lib/inspec/plugin/v2/activator.rb +0 -40
  86. data/lib/inspec/plugin/v2/config_file.rb +0 -151
  87. data/lib/inspec/plugin/v2/filter.rb +0 -96
  88. data/lib/inspec/plugin/v2/installer.rb +0 -512
  89. data/lib/inspec/plugin/v2/loader.rb +0 -321
  90. data/lib/inspec/plugin/v2/plugin_base.rb +0 -112
  91. data/lib/inspec/plugin/v2/plugin_types/cli.rb +0 -49
  92. data/lib/inspec/plugin/v2/plugin_types/dsl.rb +0 -11
  93. data/lib/inspec/plugin/v2/plugin_types/input.rb +0 -34
  94. data/lib/inspec/plugin/v2/plugin_types/mock.rb +0 -12
  95. data/lib/inspec/plugin/v2/registry.rb +0 -98
  96. data/lib/inspec/plugin/v2/status.rb +0 -29
  97. data/lib/inspec/profile.rb +0 -658
  98. data/lib/inspec/profile_context.rb +0 -203
  99. data/lib/inspec/profile_vendor.rb +0 -84
  100. data/lib/inspec/reporters.rb +0 -73
  101. data/lib/inspec/reporters/automate.rb +0 -78
  102. data/lib/inspec/reporters/base.rb +0 -25
  103. data/lib/inspec/reporters/cli.rb +0 -370
  104. data/lib/inspec/reporters/json.rb +0 -113
  105. data/lib/inspec/reporters/json_automate.rb +0 -80
  106. data/lib/inspec/reporters/json_min.rb +0 -48
  107. data/lib/inspec/reporters/junit.rb +0 -77
  108. data/lib/inspec/reporters/yaml.rb +0 -20
  109. data/lib/inspec/require_loader.rb +0 -29
  110. data/lib/inspec/resource.rb +0 -114
  111. data/lib/inspec/resources.rb +0 -130
  112. data/lib/inspec/resources/aide_conf.rb +0 -153
  113. data/lib/inspec/resources/apache.rb +0 -47
  114. data/lib/inspec/resources/apache_conf.rb +0 -156
  115. data/lib/inspec/resources/apt.rb +0 -151
  116. data/lib/inspec/resources/audit_policy.rb +0 -64
  117. data/lib/inspec/resources/auditd.rb +0 -251
  118. data/lib/inspec/resources/auditd_conf.rb +0 -45
  119. data/lib/inspec/resources/bash.rb +0 -33
  120. data/lib/inspec/resources/bond.rb +0 -70
  121. data/lib/inspec/resources/bridge.rb +0 -125
  122. data/lib/inspec/resources/bsd_service.rb +0 -2
  123. data/lib/inspec/resources/chocolatey_package.rb +0 -82
  124. data/lib/inspec/resources/command.rb +0 -91
  125. data/lib/inspec/resources/cpan.rb +0 -58
  126. data/lib/inspec/resources/cran.rb +0 -64
  127. data/lib/inspec/resources/crontab.rb +0 -173
  128. data/lib/inspec/resources/csv.rb +0 -56
  129. data/lib/inspec/resources/dh_params.rb +0 -83
  130. data/lib/inspec/resources/directory.rb +0 -23
  131. data/lib/inspec/resources/docker.rb +0 -274
  132. data/lib/inspec/resources/docker_container.rb +0 -91
  133. data/lib/inspec/resources/docker_image.rb +0 -84
  134. data/lib/inspec/resources/docker_object.rb +0 -52
  135. data/lib/inspec/resources/docker_plugin.rb +0 -64
  136. data/lib/inspec/resources/docker_service.rb +0 -91
  137. data/lib/inspec/resources/elasticsearch.rb +0 -165
  138. data/lib/inspec/resources/etc_fstab.rb +0 -96
  139. data/lib/inspec/resources/etc_group.rb +0 -157
  140. data/lib/inspec/resources/etc_hosts.rb +0 -68
  141. data/lib/inspec/resources/etc_hosts_allow.rb +0 -2
  142. data/lib/inspec/resources/etc_hosts_allow_deny.rb +0 -114
  143. data/lib/inspec/resources/etc_hosts_deny.rb +0 -2
  144. data/lib/inspec/resources/file.rb +0 -339
  145. data/lib/inspec/resources/filesystem.rb +0 -139
  146. data/lib/inspec/resources/firewalld.rb +0 -148
  147. data/lib/inspec/resources/gem.rb +0 -80
  148. data/lib/inspec/resources/group.rb +0 -2
  149. data/lib/inspec/resources/groups.rb +0 -241
  150. data/lib/inspec/resources/grub_conf.rb +0 -230
  151. data/lib/inspec/resources/host.rb +0 -310
  152. data/lib/inspec/resources/http.rb +0 -275
  153. data/lib/inspec/resources/iis_app.rb +0 -101
  154. data/lib/inspec/resources/iis_app_pool.rb +0 -127
  155. data/lib/inspec/resources/iis_site.rb +0 -148
  156. data/lib/inspec/resources/iis_website.rb +0 -2
  157. data/lib/inspec/resources/inetd_conf.rb +0 -53
  158. data/lib/inspec/resources/ini.rb +0 -28
  159. data/lib/inspec/resources/interface.rb +0 -204
  160. data/lib/inspec/resources/ip6tables.rb +0 -79
  161. data/lib/inspec/resources/iptables.rb +0 -80
  162. data/lib/inspec/resources/json.rb +0 -116
  163. data/lib/inspec/resources/kernel_module.rb +0 -106
  164. data/lib/inspec/resources/kernel_parameter.rb +0 -54
  165. data/lib/inspec/resources/key_rsa.rb +0 -66
  166. data/lib/inspec/resources/ksh.rb +0 -33
  167. data/lib/inspec/resources/launchd_service.rb +0 -2
  168. data/lib/inspec/resources/limits_conf.rb +0 -45
  169. data/lib/inspec/resources/linux_kernel_parameter.rb +0 -2
  170. data/lib/inspec/resources/login_defs.rb +0 -56
  171. data/lib/inspec/resources/mount.rb +0 -88
  172. data/lib/inspec/resources/mssql_session.rb +0 -117
  173. data/lib/inspec/resources/mysql.rb +0 -81
  174. data/lib/inspec/resources/mysql_conf.rb +0 -128
  175. data/lib/inspec/resources/mysql_session.rb +0 -88
  176. data/lib/inspec/resources/nginx.rb +0 -96
  177. data/lib/inspec/resources/nginx_conf.rb +0 -232
  178. data/lib/inspec/resources/noop.rb +0 -9
  179. data/lib/inspec/resources/npm.rb +0 -68
  180. data/lib/inspec/resources/ntp_conf.rb +0 -51
  181. data/lib/inspec/resources/oneget.rb +0 -71
  182. data/lib/inspec/resources/oracledb_session.rb +0 -149
  183. data/lib/inspec/resources/os.rb +0 -34
  184. data/lib/inspec/resources/os_env.rb +0 -86
  185. data/lib/inspec/resources/package.rb +0 -391
  186. data/lib/inspec/resources/packages.rb +0 -111
  187. data/lib/inspec/resources/parse_config.rb +0 -112
  188. data/lib/inspec/resources/parse_config_file.rb +0 -2
  189. data/lib/inspec/resources/passwd.rb +0 -73
  190. data/lib/inspec/resources/pip.rb +0 -132
  191. data/lib/inspec/resources/platform.rb +0 -112
  192. data/lib/inspec/resources/port.rb +0 -791
  193. data/lib/inspec/resources/postfix_conf.rb +0 -35
  194. data/lib/inspec/resources/postgres.rb +0 -152
  195. data/lib/inspec/resources/postgres_conf.rb +0 -116
  196. data/lib/inspec/resources/postgres_hba_conf.rb +0 -86
  197. data/lib/inspec/resources/postgres_ident_conf.rb +0 -75
  198. data/lib/inspec/resources/postgres_session.rb +0 -70
  199. data/lib/inspec/resources/powershell.rb +0 -67
  200. data/lib/inspec/resources/ppa.rb +0 -2
  201. data/lib/inspec/resources/processes.rb +0 -219
  202. data/lib/inspec/resources/rabbitmq_conf.rb +0 -2
  203. data/lib/inspec/resources/rabbitmq_config.rb +0 -52
  204. data/lib/inspec/resources/registry_key.rb +0 -296
  205. data/lib/inspec/resources/runit_service.rb +0 -2
  206. data/lib/inspec/resources/script.rb +0 -1
  207. data/lib/inspec/resources/security_identifier.rb +0 -91
  208. data/lib/inspec/resources/security_policy.rb +0 -182
  209. data/lib/inspec/resources/service.rb +0 -820
  210. data/lib/inspec/resources/shadow.rb +0 -150
  211. data/lib/inspec/resources/ssh_config.rb +0 -98
  212. data/lib/inspec/resources/sshd_config.rb +0 -2
  213. data/lib/inspec/resources/ssl.rb +0 -99
  214. data/lib/inspec/resources/sys_info.rb +0 -119
  215. data/lib/inspec/resources/systemd_service.rb +0 -2
  216. data/lib/inspec/resources/sysv_service.rb +0 -2
  217. data/lib/inspec/resources/toml.rb +0 -30
  218. data/lib/inspec/resources/upstart_service.rb +0 -2
  219. data/lib/inspec/resources/user.rb +0 -1
  220. data/lib/inspec/resources/users.rb +0 -742
  221. data/lib/inspec/resources/vbscript.rb +0 -67
  222. data/lib/inspec/resources/virtualization.rb +0 -255
  223. data/lib/inspec/resources/windows_feature.rb +0 -126
  224. data/lib/inspec/resources/windows_hotfix.rb +0 -37
  225. data/lib/inspec/resources/windows_registry_key.rb +0 -2
  226. data/lib/inspec/resources/windows_task.rb +0 -112
  227. data/lib/inspec/resources/wmi.rb +0 -109
  228. data/lib/inspec/resources/x509_certificate.rb +0 -143
  229. data/lib/inspec/resources/xinetd_conf.rb +0 -103
  230. data/lib/inspec/resources/xml.rb +0 -48
  231. data/lib/inspec/resources/yaml.rb +0 -42
  232. data/lib/inspec/resources/yum.rb +0 -162
  233. data/lib/inspec/resources/zfs_dataset.rb +0 -62
  234. data/lib/inspec/resources/zfs_pool.rb +0 -50
  235. data/lib/inspec/rspec_extensions.rb +0 -116
  236. data/lib/inspec/rule.rb +0 -389
  237. data/lib/inspec/runner.rb +0 -333
  238. data/lib/inspec/runner_mock.rb +0 -37
  239. data/lib/inspec/runner_rspec.rb +0 -184
  240. data/lib/inspec/runtime_profile.rb +0 -23
  241. data/lib/inspec/schema.rb +0 -245
  242. data/lib/inspec/secrets.rb +0 -15
  243. data/lib/inspec/secrets/yaml.rb +0 -29
  244. data/lib/inspec/shell.rb +0 -211
  245. data/lib/inspec/shell_detector.rb +0 -89
  246. data/lib/inspec/source_reader.rb +0 -26
  247. data/lib/inspec/ui.rb +0 -213
  248. data/lib/inspec/ui_table_helper.rb +0 -12
  249. data/lib/inspec/utils/command_wrapper.rb +0 -23
  250. data/lib/inspec/utils/convert.rb +0 -8
  251. data/lib/inspec/utils/database_helpers.rb +0 -75
  252. data/lib/inspec/utils/deprecation.rb +0 -6
  253. data/lib/inspec/utils/deprecation/config_file.rb +0 -109
  254. data/lib/inspec/utils/deprecation/deprecator.rb +0 -118
  255. data/lib/inspec/utils/deprecation/errors.rb +0 -14
  256. data/lib/inspec/utils/deprecation/global_method.rb +0 -9
  257. data/lib/inspec/utils/enumerable_delegation.rb +0 -7
  258. data/lib/inspec/utils/erlang_parser.rb +0 -190
  259. data/lib/inspec/utils/file_reader.rb +0 -24
  260. data/lib/inspec/utils/filter.rb +0 -461
  261. data/lib/inspec/utils/filter_array.rb +0 -25
  262. data/lib/inspec/utils/find_files.rb +0 -44
  263. data/lib/inspec/utils/hash.rb +0 -37
  264. data/lib/inspec/utils/json_log.rb +0 -15
  265. data/lib/inspec/utils/modulator.rb +0 -9
  266. data/lib/inspec/utils/nginx_parser.rb +0 -101
  267. data/lib/inspec/utils/object_traversal.rb +0 -47
  268. data/lib/inspec/utils/parser.rb +0 -277
  269. data/lib/inspec/utils/pkey_reader.rb +0 -17
  270. data/lib/inspec/utils/simpleconfig.rb +0 -121
  271. data/lib/inspec/utils/spdx.rb +0 -10
  272. data/lib/inspec/utils/spdx.txt +0 -383
  273. data/lib/inspec/utils/telemetry.rb +0 -3
  274. data/lib/inspec/utils/telemetry/collector.rb +0 -81
  275. data/lib/inspec/utils/telemetry/data_series.rb +0 -44
  276. data/lib/inspec/utils/telemetry/global_methods.rb +0 -22
  277. data/lib/inspec/version.rb +0 -3
  278. data/lib/matchers/matchers.rb +0 -341
  279. data/lib/plugins/README.md +0 -16
  280. data/lib/plugins/inspec-artifact/lib/inspec-artifact.rb +0 -12
  281. data/lib/plugins/inspec-artifact/lib/inspec-artifact/base.rb +0 -170
  282. data/lib/plugins/inspec-artifact/lib/inspec-artifact/cli.rb +0 -116
  283. data/lib/plugins/inspec-artifact/test/functional/inspec_artifact_test.rb +0 -50
  284. data/lib/plugins/inspec-compliance/README.md +0 -207
  285. data/lib/plugins/inspec-compliance/lib/inspec-compliance.rb +0 -12
  286. data/lib/plugins/inspec-compliance/lib/inspec-compliance/api.rb +0 -362
  287. data/lib/plugins/inspec-compliance/lib/inspec-compliance/api/login.rb +0 -198
  288. data/lib/plugins/inspec-compliance/lib/inspec-compliance/cli.rb +0 -269
  289. data/lib/plugins/inspec-compliance/lib/inspec-compliance/configuration.rb +0 -103
  290. data/lib/plugins/inspec-compliance/lib/inspec-compliance/http.rb +0 -117
  291. data/lib/plugins/inspec-compliance/lib/inspec-compliance/images/cc-token.png +0 -0
  292. data/lib/plugins/inspec-compliance/lib/inspec-compliance/support.rb +0 -34
  293. data/lib/plugins/inspec-compliance/lib/inspec-compliance/target.rb +0 -146
  294. data/lib/plugins/inspec-compliance/test/functional/inspec_compliance_test.rb +0 -53
  295. data/lib/plugins/inspec-compliance/test/integration/default/cli.rb +0 -91
  296. data/lib/plugins/inspec-compliance/test/unit/api/login_test.rb +0 -190
  297. data/lib/plugins/inspec-compliance/test/unit/api_test.rb +0 -386
  298. data/lib/plugins/inspec-compliance/test/unit/target_test.rb +0 -155
  299. data/lib/plugins/inspec-habitat/Berksfile +0 -5
  300. data/lib/plugins/inspec-habitat/README.md +0 -150
  301. data/lib/plugins/inspec-habitat/kitchen.yml +0 -28
  302. data/lib/plugins/inspec-habitat/lib/inspec-habitat.rb +0 -11
  303. data/lib/plugins/inspec-habitat/lib/inspec-habitat/cli.rb +0 -41
  304. data/lib/plugins/inspec-habitat/lib/inspec-habitat/profile.rb +0 -265
  305. data/lib/plugins/inspec-habitat/templates/habitat/plan.sh.erb +0 -6
  306. data/lib/plugins/inspec-habitat/test/cookbooks/inspec_habitat_fixture/Berksfile +0 -2
  307. data/lib/plugins/inspec-habitat/test/cookbooks/inspec_habitat_fixture/README.md +0 -3
  308. data/lib/plugins/inspec-habitat/test/cookbooks/inspec_habitat_fixture/files/hab_setup.exp +0 -28
  309. data/lib/plugins/inspec-habitat/test/cookbooks/inspec_habitat_fixture/metadata.rb +0 -9
  310. data/lib/plugins/inspec-habitat/test/cookbooks/inspec_habitat_fixture/recipes/default.rb +0 -61
  311. data/lib/plugins/inspec-habitat/test/functional/inspec_habitat_test.rb +0 -34
  312. data/lib/plugins/inspec-habitat/test/integration/default/inspec_habitat/README.md +0 -3
  313. data/lib/plugins/inspec-habitat/test/integration/default/inspec_habitat/controls/inspec_habitat.rb +0 -40
  314. data/lib/plugins/inspec-habitat/test/integration/default/inspec_habitat/inspec.yml +0 -10
  315. data/lib/plugins/inspec-habitat/test/support/example_profile/README.md +0 -3
  316. data/lib/plugins/inspec-habitat/test/support/example_profile/controls/example.rb +0 -7
  317. data/lib/plugins/inspec-habitat/test/support/example_profile/inspec.yml +0 -10
  318. data/lib/plugins/inspec-habitat/test/unit/profile_test.rb +0 -242
  319. data/lib/plugins/inspec-init/README.md +0 -31
  320. data/lib/plugins/inspec-init/lib/inspec-init.rb +0 -12
  321. data/lib/plugins/inspec-init/lib/inspec-init/cli.rb +0 -15
  322. data/lib/plugins/inspec-init/lib/inspec-init/cli_plugin.rb +0 -243
  323. data/lib/plugins/inspec-init/lib/inspec-init/cli_profile.rb +0 -47
  324. data/lib/plugins/inspec-init/lib/inspec-init/renderer.rb +0 -97
  325. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/Gemfile +0 -11
  326. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/LICENSE +0 -2
  327. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/README.md +0 -28
  328. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/Rakefile +0 -40
  329. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/lib/inspec-plugin-template.rb +0 -14
  330. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/lib/inspec-plugin-template/cli_command.rb +0 -62
  331. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/lib/inspec-plugin-template/plugin.rb +0 -53
  332. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/lib/inspec-plugin-template/version.rb +0 -8
  333. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/test/fixtures/README.md +0 -24
  334. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/test/functional/README.md +0 -12
  335. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/test/functional/inspec_plugin_template_test.rb +0 -110
  336. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/test/helper.rb +0 -24
  337. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/test/unit/README.md +0 -17
  338. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/test/unit/cli_args_test.rb +0 -67
  339. data/lib/plugins/inspec-init/templates/plugins/inspec-plugin-template/test/unit/plugin_def_test.rb +0 -51
  340. data/lib/plugins/inspec-init/templates/profiles/aws/libraries/.gitkeep +0 -0
  341. data/lib/plugins/inspec-init/templates/profiles/azure/libraries/.gitkeep +0 -0
  342. data/lib/plugins/inspec-init/templates/profiles/gcp/libraries/.gitkeep +0 -0
  343. data/lib/plugins/inspec-init/templates/profiles/os/README.md +0 -3
  344. data/lib/plugins/inspec-init/templates/profiles/os/controls/example.rb +0 -18
  345. data/lib/plugins/inspec-init/templates/profiles/os/inspec.yml +0 -10
  346. data/lib/plugins/inspec-init/templates/profiles/os/libraries/.gitkeep +0 -0
  347. data/lib/plugins/inspec-init/test/functional/inspec_init_plugin_test.rb +0 -184
  348. data/lib/plugins/inspec-init/test/functional/inspec_init_profile_test.rb +0 -121
  349. data/lib/plugins/inspec-plugin-manager-cli/README.md +0 -6
  350. data/lib/plugins/inspec-plugin-manager-cli/lib/inspec-plugin-manager-cli.rb +0 -17
  351. data/lib/plugins/inspec-plugin-manager-cli/lib/inspec-plugin-manager-cli/cli_command.rb +0 -518
  352. data/lib/plugins/inspec-plugin-manager-cli/lib/inspec-plugin-manager-cli/plugin.rb +0 -12
  353. data/lib/plugins/inspec-plugin-manager-cli/test/fixtures/config_dirs/empty/.gitkeep +0 -0
  354. data/lib/plugins/inspec-plugin-manager-cli/test/fixtures/plugins/inspec-egg-white-omelette/lib/inspec-egg-white-omelette.rb +0 -2
  355. data/lib/plugins/inspec-plugin-manager-cli/test/fixtures/plugins/inspec-egg-white-omelette/lib/inspec-egg-white-omelette/.gitkeep +0 -0
  356. data/lib/plugins/inspec-plugin-manager-cli/test/fixtures/plugins/inspec-wrong-structure/.gitkeep +0 -0
  357. data/lib/plugins/inspec-plugin-manager-cli/test/fixtures/plugins/wrong-name/lib/wrong-name.rb +0 -1
  358. data/lib/plugins/inspec-plugin-manager-cli/test/fixtures/plugins/wrong-name/lib/wrong-name/.gitkeep +0 -0
  359. data/lib/plugins/inspec-plugin-manager-cli/test/functional/help_test.rb +0 -23
  360. data/lib/plugins/inspec-plugin-manager-cli/test/functional/helper.rb +0 -62
  361. data/lib/plugins/inspec-plugin-manager-cli/test/functional/install_test.rb +0 -368
  362. data/lib/plugins/inspec-plugin-manager-cli/test/functional/list_test.rb +0 -101
  363. data/lib/plugins/inspec-plugin-manager-cli/test/functional/search_test.rb +0 -129
  364. data/lib/plugins/inspec-plugin-manager-cli/test/functional/uninstall_test.rb +0 -63
  365. data/lib/plugins/inspec-plugin-manager-cli/test/functional/update_test.rb +0 -84
  366. data/lib/plugins/inspec-plugin-manager-cli/test/unit/cli_args_test.rb +0 -77
  367. data/lib/plugins/inspec-plugin-manager-cli/test/unit/plugin_def_test.rb +0 -39
  368. data/lib/plugins/shared/core_plugin_test_helper.rb +0 -153
  369. data/lib/plugins/things-for-train-integration.rb +0 -14
  370. data/lib/source_readers/flat.rb +0 -36
  371. data/lib/source_readers/inspec.rb +0 -66
@@ -1,56 +0,0 @@
1
- require "inspec/resources/json"
2
-
3
- # Parses a csv document
4
- # This implementation was inspired by a blog post
5
- # @see http://technicalpickles.com/posts/parsing-csv-with-ruby
6
- module Inspec::Resources
7
- class CsvConfig < JsonConfig
8
- name "csv"
9
- desc "Use the csv InSpec audit resource to test configuration data in a CSV file."
10
- example <<~EXAMPLE
11
- describe csv('example.csv') do
12
- its('name') { should eq(['John', 'Alice']) }
13
- end
14
- EXAMPLE
15
-
16
- # override the parse method from JsonConfig
17
- # Assuming a header row of name,col1,col2, it will output an array of hashes like so:
18
- # [
19
- # { 'name' => 'row1', 'col1' => 'value1', 'col2' => 'value2' },
20
- # { 'name' => 'row2', 'col1' => 'value3', 'col2' => 'value4' }
21
- # ]
22
- def parse(content)
23
- require "csv"
24
-
25
- # convert empty field to nil
26
- CSV::Converters[:blank_to_nil] = lambda do |field|
27
- field && field.empty? ? nil : field
28
- end
29
-
30
- # implicit conversion of values
31
- csv = CSV.new(content, headers: true, converters: %i{all blank_to_nil})
32
-
33
- # convert to hash
34
- csv.to_a.map(&:to_hash)
35
- rescue => e
36
- raise Inspec::Exceptions::ResourceFailed, "Unable to parse CSV: #{e.message}"
37
- end
38
-
39
- # override the value method from JsonConfig
40
- # The format of the CSV hash as created by #parse is very different
41
- # than what the YAML, JSON, and INI resources create, so using the
42
- # #value method from JsonConfig (which uses ObjectTraverser.extract_value)
43
- # doesn't make sense here.
44
- def value(key)
45
- @params.map { |x| x[key.first.to_s] }.compact
46
- end
47
-
48
- private
49
-
50
- # used by JsonConfig to build up a full to_s method
51
- # based on whether a file path, content, or command was supplied.
52
- def resource_base_name
53
- "CSV"
54
- end
55
- end
56
- end
@@ -1,83 +0,0 @@
1
- require "openssl"
2
- require "inspec/utils/file_reader"
3
-
4
- module Inspec::Resources
5
- class DhParams < Inspec.resource(1)
6
- name "dh_params"
7
- supports platform: "unix"
8
- desc '
9
- Use the `dh_params` InSpec audit resource to test Diffie-Hellman (DH)
10
- parameters.
11
- '
12
-
13
- example <<~EXAMPLE
14
- describe dh_params('/path/to/file.dh_pem') do
15
- it { should be_dh_params }
16
- it { should be_valid }
17
- its('generator') { should eq 2 }
18
- its('modulus') { should eq '00:91:a0:15:89:e5:bc:38:93:12:02:fc:...' }
19
- its('prime_length') { should eq 2048 }
20
- its('pem') { should eq '-----BEGIN DH PARAMETERS...' }
21
- its('text') { should eq 'PKCS#3 DH Parameters: (2048 bit)...' }
22
- end
23
- EXAMPLE
24
-
25
- include FileReader
26
-
27
- def initialize(filename)
28
- @dh_params_path = filename
29
- @dh_params = OpenSSL::PKey::DH.new read_file_content(@dh_params_path)
30
- end
31
-
32
- # it { should be_dh_params }
33
- def dh_params?
34
- !@dh_params.nil?
35
- end
36
-
37
- # its('generator') { should eq 2 }
38
- def generator
39
- return if @dh_params.nil?
40
-
41
- @dh_params.g.to_i
42
- end
43
-
44
- # its('modulus') { should eq '00:91:a0:15:89:e5:bc:38:93:12:02:fc:...' }
45
- def modulus
46
- return if @dh_params.nil?
47
-
48
- "00:" + @dh_params.p.to_s(16).downcase.scan(/.{2}/).join(":")
49
- end
50
-
51
- # its('pem') { should eq '-----BEGIN DH PARAMETERS...' }
52
- def pem
53
- return if @dh_params.nil?
54
-
55
- @dh_params.to_pem
56
- end
57
-
58
- # its('prime_length') { should be 2048 }
59
- def prime_length
60
- return if @dh_params.nil?
61
-
62
- @dh_params.p.num_bits
63
- end
64
-
65
- # its('text') { should eq 'human-readable-text' }
66
- def text
67
- return if @dh_params.nil?
68
-
69
- @dh_params.to_text
70
- end
71
-
72
- # it { should be_valid }
73
- def valid?
74
- return if @dh_params.nil?
75
-
76
- @dh_params.params_ok?
77
- end
78
-
79
- def to_s
80
- "dh_params #{@dh_params_path}"
81
- end
82
- end
83
- end
@@ -1,23 +0,0 @@
1
- require "inspec/resources/file"
2
-
3
- module Inspec::Resources
4
- class Directory < FileResource
5
- name "directory"
6
- supports platform: "unix"
7
- supports platform: "windows"
8
- desc "Use the directory InSpec audit resource to test if the file type is a directory. This is equivalent to using the file InSpec audit resource and the be_directory matcher, but provides a simpler and more direct way to test directories. All of the matchers available to file may be used with directory."
9
- example <<~EXAMPLE
10
- describe directory('path') do
11
- it { should be_directory }
12
- end
13
- EXAMPLE
14
-
15
- def exist?
16
- file.exist? && file.directory?
17
- end
18
-
19
- def to_s
20
- "Directory #{source_path}"
21
- end
22
- end
23
- end
@@ -1,274 +0,0 @@
1
- #
2
- # Copyright 2017, Christoph Hartmann
3
- #
4
-
5
- require "inspec/resources/command"
6
- require "inspec/utils/filter"
7
- require "hashie/mash"
8
-
9
- module Inspec::Resources
10
- class DockerContainerFilter
11
- # use filtertable for containers
12
- filter = FilterTable.create
13
- filter.register_custom_matcher(:exists?) { |x| !x.entries.empty? }
14
- filter.register_column(:commands, field: "command")
15
- .register_column(:ids, field: "id")
16
- .register_column(:images, field: "image")
17
- .register_column(:labels, field: "labels", style: :simple)
18
- .register_column(:local_volumes, field: "localvolumes")
19
- .register_column(:mounts, field: "mounts")
20
- .register_column(:names, field: "names")
21
- .register_column(:networks, field: "networks")
22
- .register_column(:ports, field: "ports")
23
- .register_column(:running_for, field: "runningfor")
24
- .register_column(:sizes, field: "size")
25
- .register_column(:status, field: "status")
26
- .register_custom_matcher(:running?) do |x|
27
- x.where { status.downcase.start_with?("up") }
28
- end
29
- filter.install_filter_methods_on_resource(self, :containers)
30
-
31
- attr_reader :containers
32
- def initialize(containers)
33
- @containers = containers
34
- end
35
- end
36
-
37
- class DockerImageFilter
38
- filter = FilterTable.create
39
- filter.register_custom_matcher(:exists?) { |x| !x.entries.empty? }
40
- filter.register_column(:ids, field: "id")
41
- .register_column(:repositories, field: "repository")
42
- .register_column(:tags, field: "tag")
43
- .register_column(:sizes, field: "size")
44
- .register_column(:digests, field: "digest")
45
- .register_column(:created, field: "createdat")
46
- .register_column(:created_since, field: "createdsize")
47
- filter.install_filter_methods_on_resource(self, :images)
48
-
49
- attr_reader :images
50
- def initialize(images)
51
- @images = images
52
- end
53
- end
54
-
55
- class DockerPluginFilter
56
- filter = FilterTable.create
57
- filter.add(:ids, field: "id")
58
- .add(:names, field: "name")
59
- .add(:versions, field: "version")
60
- .add(:enabled, field: "enabled")
61
- filter.connect(self, :plugins)
62
-
63
- attr_reader :plugins
64
- def initialize(plugins)
65
- @plugins = plugins
66
- end
67
- end
68
-
69
- class DockerServiceFilter
70
- filter = FilterTable.create
71
- filter.register_custom_matcher(:exists?) { |x| !x.entries.empty? }
72
- filter.register_column(:ids, field: "id")
73
- .register_column(:names, field: "name")
74
- .register_column(:modes, field: "mode")
75
- .register_column(:replicas, field: "replicas")
76
- .register_column(:images, field: "image")
77
- .register_column(:ports, field: "ports")
78
- filter.install_filter_methods_on_resource(self, :services)
79
-
80
- attr_reader :services
81
- def initialize(services)
82
- @services = services
83
- end
84
- end
85
-
86
- # This resource helps to parse information from the docker host
87
- # For compatability with Serverspec we also offer the following resouses:
88
- # - docker_container
89
- # - docker_image
90
- class Docker < Inspec.resource(1)
91
- name "docker"
92
- supports platform: "unix"
93
- desc "
94
- A resource to retrieve information about docker
95
- "
96
-
97
- example <<~EXAMPLE
98
- describe docker.containers do
99
- its('images') { should_not include 'u12:latest' }
100
- end
101
-
102
- describe docker.images do
103
- its('repositories') { should_not include 'inssecure_image' }
104
- end
105
-
106
- describe docker.plugins.where { name == 'rexray/ebs' } do
107
- it { should exist }
108
- end
109
-
110
- describe docker.services do
111
- its('images') { should_not include 'inssecure_image' }
112
- end
113
-
114
- describe docker.version do
115
- its('Server.Version') { should cmp >= '1.12'}
116
- its('Client.Version') { should cmp >= '1.12'}
117
- end
118
-
119
- describe docker.object(id) do
120
- its('Configuration.Path') { should eq 'value' }
121
- end
122
-
123
- docker.containers.ids.each do |id|
124
- # call docker inspect for a specific container id
125
- describe docker.object(id) do
126
- its(%w(HostConfig Privileged)) { should cmp false }
127
- its(%w(HostConfig Privileged)) { should_not cmp true }
128
- end
129
- end
130
- EXAMPLE
131
-
132
- def containers
133
- DockerContainerFilter.new(parse_containers)
134
- end
135
-
136
- def images
137
- DockerImageFilter.new(parse_images)
138
- end
139
-
140
- def plugins
141
- DockerPluginFilter.new(parse_plugins)
142
- end
143
-
144
- def services
145
- DockerServiceFilter.new(parse_services)
146
- end
147
-
148
- def version
149
- return @version if defined?(@version)
150
-
151
- data = {}
152
- cmd = inspec.command("docker version --format '{{ json . }}'")
153
- data = JSON.parse(cmd.stdout) if cmd.exit_status == 0
154
- @version = Hashie::Mash.new(data)
155
- rescue JSON::ParserError => _e
156
- Hashie::Mash.new({})
157
- end
158
-
159
- def info
160
- return @info if defined?(@info)
161
-
162
- data = {}
163
- # docke info format is only supported for Docker 17.03+
164
- cmd = inspec.command("docker info --format '{{ json . }}'")
165
- data = JSON.parse(cmd.stdout) if cmd.exit_status == 0
166
- @info = Hashie::Mash.new(data)
167
- rescue JSON::ParserError => _e
168
- Hashie::Mash.new({})
169
- end
170
-
171
- # returns information about docker objects
172
- def object(id)
173
- return @inspect if defined?(@inspect)
174
-
175
- data = JSON.parse(inspec.command("docker inspect #{id}").stdout)
176
- data = data[0] if data.is_a?(Array)
177
- @inspect = Hashie::Mash.new(data)
178
- rescue JSON::ParserError => _e
179
- Hashie::Mash.new({})
180
- end
181
-
182
- def to_s
183
- "Docker Host"
184
- end
185
-
186
- private
187
-
188
- def parse_json_command(labels, subcommand)
189
- # build command
190
- format = labels.map { |label| "\"#{label}\": {{json .#{label}}}" }
191
- raw = inspec.command("docker #{subcommand} --format '{#{format.join(", ")}}'").stdout
192
- output = []
193
- # since docker is not outputting valid json, we need to parse each row
194
- raw.each_line do |entry|
195
- # convert all keys to lower_case to work well with ruby and filter table
196
- row = JSON.parse(entry).map do |key, value|
197
- [key.downcase, value]
198
- end.to_h
199
-
200
- # ensure all keys are there
201
- row = ensure_keys(row, labels)
202
-
203
- # strip off any linked container names
204
- # Depending on how it was linked, the actual container name may come before
205
- # or after the link information, so we'll just look for the first name that
206
- # does not include a slash since that is not a valid character in a container name
207
- if row["names"]
208
- row["names"] = row["names"].split(",").find { |c| !c.include?("/") }
209
- end
210
-
211
- # Split labels on ',' or set to empty array
212
- # Allows for `docker.containers.where { labels.include?('app=redis') }`
213
- row["labels"] = row.key?("labels") ? row["labels"].split(",") : []
214
-
215
- output.push(row)
216
- end
217
-
218
- output
219
- rescue JSON::ParserError => _e
220
- warn "Could not parse `docker #{subcommand}` output"
221
- []
222
- end
223
-
224
- def parse_containers
225
- # @see https://github.com/moby/moby/issues/20625, works for docker 1.13+
226
- # raw_containers = inspec.command('docker ps -a --no-trunc --format \'{{ json . }}\'').stdout
227
- # therefore we stick with older approach
228
- labels = %w{Command CreatedAt ID Image Labels Mounts Names Ports RunningFor Size Status}
229
-
230
- # Networks LocalVolumes work with 1.13+ only
231
- if !version.empty? && Gem::Version.new(version["Client"]["Version"]) >= Gem::Version.new("1.13")
232
- labels.push("Networks")
233
- labels.push("LocalVolumes")
234
- end
235
- parse_json_command(labels, "ps -a --no-trunc")
236
- end
237
-
238
- def parse_services
239
- parse_json_command(%w{ID Name Mode Replicas Image Ports}, "service ls")
240
- end
241
-
242
- def ensure_keys(entry, labels)
243
- labels.each do |key|
244
- entry[key.downcase] = nil unless entry.key?(key.downcase)
245
- end
246
- entry
247
- end
248
-
249
- def parse_images
250
- # docker does not support the `json .` function here, therefore we need to emulate that behavior.
251
- raw_images = inspec.command('docker images -a --no-trunc --format \'{ "id": {{json .ID}}, "repository": {{json .Repository}}, "tag": {{json .Tag}}, "size": {{json .Size}}, "digest": {{json .Digest}}, "createdat": {{json .CreatedAt}}, "createdsize": {{json .CreatedSince}} }\'').stdout
252
- c_images = []
253
- raw_images.each_line do |entry|
254
- c_images.push(JSON.parse(entry))
255
- end
256
- c_images
257
- rescue JSON::ParserError => _e
258
- warn "Could not parse `docker images` output"
259
- []
260
- end
261
-
262
- def parse_plugins
263
- plugins = inspec.command('docker plugin ls --format \'{"id": {{json .ID}}, "name": "{{ with split .Name ":"}}{{index . 0}}{{end}}", "version": "{{ with split .Name ":"}}{{index . 1}}{{end}}", "enabled": {{json .Enabled}} }\'').stdout
264
- c_plugins = []
265
- plugins.each_line do |entry|
266
- c_plugins.push(JSON.parse(entry))
267
- end
268
- c_plugins
269
- rescue JSON::ParserError => _e
270
- warn "Could not parse `docker plugin ls` output"
271
- []
272
- end
273
- end
274
- end
@@ -1,91 +0,0 @@
1
- #
2
- # Copyright 2017, Christoph Hartmann
3
-
4
- require "inspec/resources/docker"
5
- require_relative "docker_object"
6
-
7
- module Inspec::Resources
8
- class DockerContainer < Inspec.resource(1)
9
- include Inspec::Resources::DockerObject
10
-
11
- name "docker_container"
12
- supports platform: "unix"
13
- desc ""
14
- example <<~EXAMPLE
15
- describe docker_container('an-echo-server') do
16
- it { should exist }
17
- it { should be_running }
18
- its('id') { should_not eq '' }
19
- its('image') { should eq 'busybox:latest' }
20
- its('repo') { should eq 'busybox' }
21
- its('tag') { should eq 'latest' }
22
- its('ports') { should eq [] }
23
- its('command') { should eq 'nc -ll -p 1234 -e /bin/cat' }
24
- its('labels') { should include 'app=example' }
25
- end
26
-
27
- describe docker_container(id: 'e2c52a183358') do
28
- it { should exist }
29
- it { should be_running }
30
- end
31
- EXAMPLE
32
-
33
- def initialize(opts = {})
34
- # if a string is provided, we expect it is the name
35
- if opts.is_a?(String)
36
- @opts = { name: opts }
37
- else
38
- @opts = opts
39
- end
40
- end
41
-
42
- def running?
43
- status.downcase.start_with?("up") if object_info.entries.length == 1
44
- end
45
-
46
- def status
47
- object_info.status[0] if object_info.entries.length == 1
48
- end
49
-
50
- def labels
51
- object_info.labels
52
- end
53
-
54
- def ports
55
- object_info.ports[0] if object_info.entries.length == 1
56
- end
57
-
58
- def command
59
- return unless object_info.entries.length == 1
60
-
61
- cmd = object_info.commands[0]
62
- cmd.slice(1, cmd.length - 2)
63
- end
64
-
65
- def image
66
- object_info.images[0] if object_info.entries.length == 1
67
- end
68
-
69
- def repo
70
- parse_components_from_image(image)[:repo] if object_info.entries.size == 1
71
- end
72
-
73
- def tag
74
- parse_components_from_image(image)[:tag] if object_info.entries.size == 1
75
- end
76
-
77
- def to_s
78
- name = @opts[:name] || @opts[:id]
79
- "Docker Container #{name}"
80
- end
81
-
82
- private
83
-
84
- def object_info
85
- return @info if defined?(@info)
86
-
87
- opts = @opts
88
- @info = inspec.docker.containers.where { names == opts[:name] || (!id.nil? && !opts[:id].nil? && (id == opts[:id] || id.start_with?(opts[:id]))) }
89
- end
90
- end
91
- end