chef-dk 0.13.21 → 0.14.25
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.
- checksums.yaml +4 -4
- data/CONTRIBUTING.md +186 -186
- data/Gemfile +37 -14
- data/Gemfile.lock +178 -72
- data/LICENSE +201 -201
- data/README.md +11 -148
- data/acceptance/.shared/kitchen_acceptance/.kitchen.digitalocean.yml +27 -27
- data/acceptance/.shared/kitchen_acceptance/.kitchen.ec2.yml +288 -288
- data/acceptance/.shared/kitchen_acceptance/.kitchen.vagrant.yml +52 -52
- data/acceptance/.shared/kitchen_acceptance/libraries/kitchen.rb +51 -51
- data/acceptance/.shared/kitchen_acceptance/metadata.rb +1 -1
- data/acceptance/Gemfile +2 -1
- data/acceptance/Gemfile.lock +39 -42
- data/acceptance/README.md +132 -132
- data/acceptance/trivial/.acceptance/acceptance-cookbook/.gitignore +2 -2
- data/acceptance/trivial/.acceptance/acceptance-cookbook/metadata.rb +2 -2
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
- data/acceptance/trivial/.kitchen.yml +7 -7
- data/acceptance/trivial/test/integration/chefdk-current-install/inspec/chef_client_spec.rb +5 -5
- data/bin/chef +25 -25
- data/lib/chef-dk.rb +19 -19
- data/lib/chef-dk/authenticated_http.rb +40 -40
- data/lib/chef-dk/chef_runner.rb +107 -107
- data/lib/chef-dk/cli.rb +200 -200
- data/lib/chef-dk/command/base.rb +79 -79
- data/lib/chef-dk/command/clean_policy_cookbooks.rb +116 -116
- data/lib/chef-dk/command/clean_policy_revisions.rb +113 -113
- data/lib/chef-dk/command/delete_policy.rb +122 -122
- data/lib/chef-dk/command/delete_policy_group.rb +122 -122
- data/lib/chef-dk/command/diff.rb +316 -316
- data/lib/chef-dk/command/env.rb +90 -90
- data/lib/chef-dk/command/exec.rb +45 -45
- data/lib/chef-dk/command/export.rb +157 -157
- data/lib/chef-dk/command/gem.rb +47 -47
- data/lib/chef-dk/command/generate.rb +120 -120
- data/lib/chef-dk/command/generator_commands.rb +83 -80
- data/lib/chef-dk/command/generator_commands/app.rb +107 -107
- data/lib/chef-dk/command/generator_commands/attribute.rb +37 -37
- data/lib/chef-dk/command/generator_commands/base.rb +148 -148
- data/lib/chef-dk/command/generator_commands/cookbook.rb +153 -153
- data/lib/chef-dk/command/generator_commands/cookbook_code_file.rb +100 -100
- data/lib/chef-dk/command/generator_commands/cookbook_file.rb +45 -45
- data/lib/chef-dk/command/generator_commands/generator_generator.rb +177 -177
- data/lib/chef-dk/command/generator_commands/lwrp.rb +36 -36
- data/lib/chef-dk/command/generator_commands/policyfile.rb +127 -127
- data/lib/chef-dk/command/generator_commands/recipe.rb +36 -36
- data/lib/chef-dk/command/generator_commands/repo.rb +125 -125
- data/lib/chef-dk/command/generator_commands/template.rb +46 -46
- data/lib/chef-dk/command/install.rb +121 -121
- data/lib/chef-dk/command/provision.rb +438 -438
- data/lib/chef-dk/command/push.rb +118 -118
- data/lib/chef-dk/command/push_archive.rb +126 -126
- data/lib/chef-dk/command/shell_init.rb +180 -180
- data/lib/chef-dk/command/show_policy.rb +165 -165
- data/lib/chef-dk/command/undelete.rb +155 -155
- data/lib/chef-dk/command/update.rb +148 -148
- data/lib/chef-dk/command/verify.rb +106 -29
- data/lib/chef-dk/completions/bash.sh.erb +5 -5
- data/lib/chef-dk/completions/chef.fish.erb +10 -10
- data/lib/chef-dk/completions/zsh.zsh.erb +21 -21
- data/lib/chef-dk/component_test.rb +30 -1
- data/lib/chef-dk/configurable.rb +69 -69
- data/lib/chef-dk/cookbook_metadata.rb +45 -45
- data/lib/chef-dk/cookbook_omnifetch.rb +32 -32
- data/lib/chef-dk/cookbook_profiler/git.rb +151 -151
- data/lib/chef-dk/cookbook_profiler/identifiers.rb +72 -72
- data/lib/chef-dk/cookbook_profiler/null_scm.rb +32 -32
- data/lib/chef-dk/exceptions.rb +129 -129
- data/lib/chef-dk/generator.rb +163 -163
- data/lib/chef-dk/helpers.rb +159 -159
- data/lib/chef-dk/pager.rb +106 -106
- data/lib/chef-dk/policyfile/chef_repo_cookbook_source.rb +138 -138
- data/lib/chef-dk/policyfile/chef_server_cookbook_source.rb +54 -54
- data/lib/chef-dk/policyfile/community_cookbook_source.rb +97 -97
- data/lib/chef-dk/policyfile/comparison_base.rb +124 -124
- data/lib/chef-dk/policyfile/cookbook_location_specification.rb +154 -154
- data/lib/chef-dk/policyfile/cookbook_locks.rb +466 -466
- data/lib/chef-dk/policyfile/cookbook_sources.rb +22 -22
- data/lib/chef-dk/policyfile/delivery_supermarket_source.rb +90 -90
- data/lib/chef-dk/policyfile/differ.rb +266 -266
- data/lib/chef-dk/policyfile/dsl.rb +261 -261
- data/lib/chef-dk/policyfile/lister.rb +232 -232
- data/lib/chef-dk/policyfile/null_cookbook_source.rb +45 -45
- data/lib/chef-dk/policyfile/read_cookbook_for_compat_mode_upload.rb +124 -124
- data/lib/chef-dk/policyfile/reports/install.rb +70 -70
- data/lib/chef-dk/policyfile/reports/table_printer.rb +58 -58
- data/lib/chef-dk/policyfile/reports/upload.rb +70 -70
- data/lib/chef-dk/policyfile/solution_dependencies.rb +298 -298
- data/lib/chef-dk/policyfile/storage_config.rb +100 -100
- data/lib/chef-dk/policyfile/undo_record.rb +142 -142
- data/lib/chef-dk/policyfile/undo_stack.rb +130 -130
- data/lib/chef-dk/policyfile/uploader.rb +213 -213
- data/lib/chef-dk/policyfile_compiler.rb +419 -419
- data/lib/chef-dk/policyfile_lock.rb +552 -552
- data/lib/chef-dk/policyfile_services/clean_policies.rb +95 -95
- data/lib/chef-dk/policyfile_services/clean_policy_cookbooks.rb +125 -125
- data/lib/chef-dk/policyfile_services/export_repo.rb +421 -421
- data/lib/chef-dk/policyfile_services/install.rb +126 -126
- data/lib/chef-dk/policyfile_services/push.rb +114 -114
- data/lib/chef-dk/policyfile_services/push_archive.rb +204 -204
- data/lib/chef-dk/policyfile_services/rm_policy.rb +142 -142
- data/lib/chef-dk/policyfile_services/rm_policy_group.rb +86 -86
- data/lib/chef-dk/policyfile_services/show_policy.rb +237 -237
- data/lib/chef-dk/policyfile_services/undelete.rb +108 -108
- data/lib/chef-dk/policyfile_services/update_attributes.rb +104 -104
- data/lib/chef-dk/service_exception_inspectors.rb +25 -25
- data/lib/chef-dk/service_exception_inspectors/base.rb +40 -40
- data/lib/chef-dk/service_exception_inspectors/http.rb +121 -121
- data/lib/chef-dk/service_exceptions.rb +143 -143
- data/lib/chef-dk/shell_out.rb +36 -36
- data/lib/chef-dk/skeletons/code_generator/files/default/Berksfile +3 -3
- data/lib/chef-dk/skeletons/code_generator/files/default/chefignore +102 -102
- data/lib/chef-dk/skeletons/code_generator/files/default/cookbook_readmes/README-policy.md +9 -9
- data/lib/chef-dk/skeletons/code_generator/files/default/cookbook_readmes/README.md +54 -54
- data/lib/chef-dk/skeletons/code_generator/files/default/gitignore +16 -16
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/README.md +28 -28
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/README.md +27 -27
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/attributes/default.rb +7 -7
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/metadata.rb +3 -3
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/recipes/default.rb +8 -8
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/data_bags/README.md +58 -58
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/data_bags/example/example_item.json +3 -3
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/dot-chef-repo.txt +6 -6
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/environments/README.md +9 -9
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/environments/example.json +12 -12
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/policies/README.md +24 -24
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/roles/README.md +9 -9
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/roles/example.json +12 -12
- data/lib/chef-dk/skeletons/code_generator/files/default/serverspec_spec_helper.rb +8 -8
- data/lib/chef-dk/skeletons/code_generator/files/default/spec_helper.rb +2 -2
- data/lib/chef-dk/skeletons/code_generator/files/default/spec_helper_policyfile.rb +2 -2
- data/lib/chef-dk/skeletons/code_generator/metadata.rb +8 -8
- data/lib/chef-dk/skeletons/code_generator/recipes/app.rb +97 -97
- data/lib/chef-dk/skeletons/code_generator/recipes/attribute.rb +12 -12
- data/lib/chef-dk/skeletons/code_generator/recipes/cookbook.rb +117 -117
- data/lib/chef-dk/skeletons/code_generator/recipes/cookbook_file.rb +24 -24
- data/lib/chef-dk/skeletons/code_generator/recipes/lwrp.rb +23 -23
- data/lib/chef-dk/skeletons/code_generator/recipes/policyfile.rb +8 -8
- data/lib/chef-dk/skeletons/code_generator/recipes/recipe.rb +27 -27
- data/lib/chef-dk/skeletons/code_generator/recipes/repo.rb +67 -67
- data/lib/chef-dk/skeletons/code_generator/recipes/template.rb +32 -32
- data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.all_rights.erb +3 -3
- data/lib/chef-dk/skeletons/code_generator/templates/default/{LICENSE.apache2.erb → LICENSE.apachev2.erb} +201 -201
- data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.gplv2.erb +339 -339
- data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.gplv3.erb +674 -674
- data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.mit.erb +21 -21
- data/lib/chef-dk/skeletons/code_generator/templates/default/Policyfile.rb.erb +25 -25
- data/lib/chef-dk/skeletons/code_generator/templates/default/README.md.erb +4 -4
- data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen.yml.erb +21 -21
- data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen_policyfile.yml.erb +32 -32
- data/lib/chef-dk/skeletons/code_generator/templates/default/metadata.rb.erb +7 -7
- data/lib/chef-dk/skeletons/code_generator/templates/default/recipe.rb.erb +5 -5
- data/lib/chef-dk/skeletons/code_generator/templates/default/recipe_spec.rb.erb +20 -20
- data/lib/chef-dk/skeletons/code_generator/templates/default/repo/gitignore.erb +11 -11
- data/lib/chef-dk/skeletons/code_generator/templates/default/serverspec_default_spec.rb.erb +9 -9
- data/lib/chef-dk/ui.rb +58 -58
- data/lib/chef-dk/version.rb +1 -1
- data/lib/kitchen/provisioner/policyfile_zero.rb +195 -195
- data/omnibus_overrides.rb +19 -11
- data/spec/shared/a_file_generator.rb +125 -125
- data/spec/shared/a_generated_file.rb +12 -12
- data/spec/shared/command_with_ui_object.rb +11 -11
- data/spec/shared/custom_generator_cookbook.rb +130 -130
- data/spec/shared/fixture_cookbook_checksums.rb +47 -47
- data/spec/shared/setup_git_cookbooks.rb +53 -53
- data/spec/spec_helper.rb +51 -51
- data/spec/test_helpers.rb +84 -84
- data/spec/unit/chef_runner_spec.rb +139 -139
- data/spec/unit/cli_spec.rb +357 -357
- data/spec/unit/command/base_spec.rb +173 -169
- data/spec/unit/command/clean_policy_cookbooks_spec.rb +181 -181
- data/spec/unit/command/clean_policy_revisions_spec.rb +181 -181
- data/spec/unit/command/delete_policy_group_spec.rb +207 -207
- data/spec/unit/command/delete_policy_spec.rb +207 -207
- data/spec/unit/command/diff_spec.rb +312 -312
- data/spec/unit/command/env_spec.rb +52 -52
- data/spec/unit/command/exec_spec.rb +179 -179
- data/spec/unit/command/export_spec.rb +200 -200
- data/spec/unit/command/generate_spec.rb +142 -142
- data/spec/unit/command/generator_commands/app_spec.rb +169 -169
- data/spec/unit/command/generator_commands/attribute_spec.rb +32 -32
- data/spec/unit/command/generator_commands/base_spec.rb +136 -136
- data/spec/unit/command/generator_commands/cookbook_file_spec.rb +32 -32
- data/spec/unit/command/generator_commands/cookbook_spec.rb +450 -450
- data/spec/unit/command/generator_commands/generator_generator_spec.rb +229 -229
- data/spec/unit/command/generator_commands/lwrp_spec.rb +32 -32
- data/spec/unit/command/generator_commands/policyfile_spec.rb +225 -225
- data/spec/unit/command/generator_commands/recipe_spec.rb +34 -34
- data/spec/unit/command/generator_commands/repo_spec.rb +374 -367
- data/spec/unit/command/generator_commands/template_spec.rb +32 -32
- data/spec/unit/command/install_spec.rb +179 -179
- data/spec/unit/command/provision_spec.rb +592 -592
- data/spec/unit/command/push_archive_spec.rb +153 -153
- data/spec/unit/command/push_spec.rb +199 -199
- data/spec/unit/command/shell_init_spec.rb +329 -329
- data/spec/unit/command/show_policy_spec.rb +235 -235
- data/spec/unit/command/undelete_spec.rb +246 -246
- data/spec/unit/command/update_spec.rb +275 -275
- data/spec/unit/command/verify_spec.rb +15 -6
- data/spec/unit/commands_map_spec.rb +57 -57
- data/spec/unit/component_test_spec.rb +128 -126
- data/spec/unit/configurable_spec.rb +41 -41
- data/spec/unit/cookbook_metadata_spec.rb +98 -98
- data/spec/unit/cookbook_profiler/git_spec.rb +176 -176
- data/spec/unit/cookbook_profiler/identifiers_spec.rb +83 -83
- data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_one.rb +9 -9
- data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_two.rb +9 -9
- data/spec/unit/fixtures/command/cli_test_command.rb +26 -26
- data/spec/unit/fixtures/command/explicit_path_example.rb +7 -7
- data/spec/unit/fixtures/configurable/test_config_loader.rb +5 -5
- data/spec/unit/fixtures/configurable/test_configurable.rb +10 -10
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -16
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/Berksfile +3 -3
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -4
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/chefignore +96 -96
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -8
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -8
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/.kitchen.yml +16 -16
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/Berksfile +3 -3
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/README.md +4 -4
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/chefignore +96 -96
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/metadata.rb +8 -8
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/recipes/default.rb +8 -8
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/.kitchen.yml +16 -16
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/Berksfile +3 -3
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/README.md +4 -4
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/chefignore +96 -96
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/metadata.rb +8 -8
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/recipes/default.rb +8 -8
- data/spec/unit/fixtures/cookbooks_api/pruned_small_universe.json +1321 -1321
- data/spec/unit/fixtures/cookbooks_api/small_universe.json +2987 -2987
- data/spec/unit/fixtures/cookbooks_api/universe.json +1 -1
- data/spec/unit/fixtures/cookbooks_api/update_fixtures.rb +36 -36
- data/spec/unit/fixtures/dev_cookbooks/README.md +16 -16
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/integration_test +2 -2
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/verify_me +5 -5
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/chef/verify_me +3 -3
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/test-kitchen/verify_me +2 -2
- data/spec/unit/fixtures/example_cookbook/.gitignore +17 -17
- data/spec/unit/fixtures/example_cookbook/.kitchen.yml +16 -16
- data/spec/unit/fixtures/example_cookbook/Berksfile +3 -3
- data/spec/unit/fixtures/example_cookbook/README.md +4 -4
- data/spec/unit/fixtures/example_cookbook/chefignore +96 -96
- data/spec/unit/fixtures/example_cookbook/metadata.rb +8 -8
- data/spec/unit/fixtures/example_cookbook/recipes/default.rb +8 -8
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/.gitignore +17 -17
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/.kitchen.yml +16 -16
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/Berksfile +3 -3
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/README.md +4 -4
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/chefignore +96 -96
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/metadata.json +5 -5
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/recipes/default.rb +8 -8
- data/spec/unit/fixtures/example_cookbook_no_metadata/.gitignore +17 -17
- data/spec/unit/fixtures/example_cookbook_no_metadata/.kitchen.yml +16 -16
- data/spec/unit/fixtures/example_cookbook_no_metadata/Berksfile +3 -3
- data/spec/unit/fixtures/example_cookbook_no_metadata/README.md +4 -4
- data/spec/unit/fixtures/example_cookbook_no_metadata/chefignore +96 -96
- data/spec/unit/fixtures/example_cookbook_no_metadata/recipes/default.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/README.md +4 -4
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/chefignore +96 -96
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/metadata.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/recipes/default.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/Berksfile +3 -3
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/README.md +4 -4
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/chefignore +96 -96
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/metadata.rb +9 -9
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/recipes/default.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/.kitchen.yml +16 -16
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/Berksfile +3 -3
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/README.md +4 -4
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/chefignore +96 -96
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/metadata.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/recipes/default.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/metadata-missing/README.md +2 -2
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -16
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -4
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -8
- data/spec/unit/generator_spec.rb +119 -120
- data/spec/unit/helpers_spec.rb +92 -92
- data/spec/unit/pager_spec.rb +119 -119
- data/spec/unit/policyfile/chef_repo_cookbook_source_spec.rb +93 -93
- data/spec/unit/policyfile/chef_server_cookbook_source_spec.rb +34 -34
- data/spec/unit/policyfile/community_cookbook_source_spec.rb +84 -84
- data/spec/unit/policyfile/comparison_base_spec.rb +343 -343
- data/spec/unit/policyfile/cookbook_location_specification_spec.rb +277 -277
- data/spec/unit/policyfile/cookbook_locks_spec.rb +529 -529
- data/spec/unit/policyfile/delivery_supermarket_source_spec.rb +130 -130
- data/spec/unit/policyfile/differ_spec.rb +687 -687
- data/spec/unit/policyfile/lister_spec.rb +272 -272
- data/spec/unit/policyfile/null_cookbook_source_spec.rb +35 -35
- data/spec/unit/policyfile/read_cookbook_for_compat_mode_upload_spec.rb +92 -92
- data/spec/unit/policyfile/reports/install_spec.rb +115 -115
- data/spec/unit/policyfile/reports/upload_spec.rb +96 -96
- data/spec/unit/policyfile/solution_dependencies_spec.rb +145 -145
- data/spec/unit/policyfile/storage_config_spec.rb +172 -172
- data/spec/unit/policyfile/undo_record_spec.rb +260 -260
- data/spec/unit/policyfile/undo_stack_spec.rb +266 -266
- data/spec/unit/policyfile/uploader_spec.rb +410 -410
- data/spec/unit/policyfile_demands_spec.rb +1203 -1203
- data/spec/unit/policyfile_evaluation_spec.rb +642 -642
- data/spec/unit/policyfile_lock_build_spec.rb +1056 -1056
- data/spec/unit/policyfile_lock_install_spec.rb +138 -138
- data/spec/unit/policyfile_lock_serialization_spec.rb +425 -425
- data/spec/unit/policyfile_lock_validation_spec.rb +611 -611
- data/spec/unit/policyfile_services/clean_policies_spec.rb +236 -236
- data/spec/unit/policyfile_services/clean_policy_cookbooks_spec.rb +275 -275
- data/spec/unit/policyfile_services/export_repo_spec.rb +481 -481
- data/spec/unit/policyfile_services/install_spec.rb +211 -211
- data/spec/unit/policyfile_services/push_archive_spec.rb +378 -378
- data/spec/unit/policyfile_services/push_spec.rb +233 -233
- data/spec/unit/policyfile_services/rm_policy_group_spec.rb +241 -241
- data/spec/unit/policyfile_services/rm_policy_spec.rb +266 -266
- data/spec/unit/policyfile_services/show_policy_spec.rb +889 -889
- data/spec/unit/policyfile_services/undelete_spec.rb +304 -304
- data/spec/unit/policyfile_services/update_attributes_spec.rb +217 -217
- data/spec/unit/service_exception_inspectors/base_spec.rb +43 -43
- data/spec/unit/service_exception_inspectors/http_spec.rb +140 -140
- data/spec/unit/shell_out_spec.rb +34 -34
- data/spec/unit/tasks/helpers_spec.rb +75 -0
- data/tasks/bin/bundle-platform +0 -0
- data/tasks/bin/bundle-platform.bat +0 -0
- data/tasks/bin/create-override-gemfile +110 -0
- data/tasks/bundle.rb +27 -11
- data/tasks/bundle_util.rb +6 -5
- data/tasks/dependencies.rb +97 -122
- data/tasks/gemfile_util.rb +357 -66
- data/tasks/helpers.rb +47 -0
- data/tasks/version.rb +1 -5
- data/version_policy.rb +66 -41
- data/warning.txt +9 -9
- metadata +7 -5
- data/Gemfile.windows +0 -34
- data/Gemfile.windows.lock +0 -936
|
@@ -1,86 +1,86 @@
|
|
|
1
|
-
#
|
|
2
|
-
# Copyright:: Copyright (c) 2015 Chef Software Inc.
|
|
3
|
-
# License:: Apache License, Version 2.0
|
|
4
|
-
#
|
|
5
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
-
# you may not use this file except in compliance with the License.
|
|
7
|
-
# You may obtain a copy of the License at
|
|
8
|
-
#
|
|
9
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
-
#
|
|
11
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
12
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
-
# See the License for the specific language governing permissions and
|
|
15
|
-
# limitations under the License.
|
|
16
|
-
#
|
|
17
|
-
|
|
18
|
-
require 'chef-dk/service_exceptions'
|
|
19
|
-
require 'chef-dk/authenticated_http'
|
|
20
|
-
require 'chef-dk/policyfile/undo_stack'
|
|
21
|
-
require 'chef-dk/policyfile/undo_record'
|
|
22
|
-
|
|
23
|
-
module ChefDK
|
|
24
|
-
module PolicyfileServices
|
|
25
|
-
|
|
26
|
-
class RmPolicyGroup
|
|
27
|
-
|
|
28
|
-
attr_reader :policy_group
|
|
29
|
-
|
|
30
|
-
# @api private
|
|
31
|
-
attr_reader :chef_config
|
|
32
|
-
|
|
33
|
-
# @api private
|
|
34
|
-
attr_reader :ui
|
|
35
|
-
|
|
36
|
-
# @api private
|
|
37
|
-
attr_reader :undo_record
|
|
38
|
-
|
|
39
|
-
# @api private
|
|
40
|
-
attr_reader :undo_stack
|
|
41
|
-
|
|
42
|
-
def initialize(config: nil, ui: nil, policy_group: nil)
|
|
43
|
-
@chef_config = config
|
|
44
|
-
@ui = ui
|
|
45
|
-
@policy_group = policy_group
|
|
46
|
-
|
|
47
|
-
@undo_record = Policyfile::UndoRecord.new
|
|
48
|
-
@undo_stack = Policyfile::UndoStack.new
|
|
49
|
-
end
|
|
50
|
-
|
|
51
|
-
def run
|
|
52
|
-
undo_record.description = "delete-policy-group #{policy_group}"
|
|
53
|
-
policy_group_list = http_client.get("/policy_groups")
|
|
54
|
-
|
|
55
|
-
unless policy_group_list.has_key?(policy_group)
|
|
56
|
-
ui.err("Policy group '#{policy_group}' does not exist on the server")
|
|
57
|
-
return false
|
|
58
|
-
end
|
|
59
|
-
policy_group_info = policy_group_list[policy_group]
|
|
60
|
-
|
|
61
|
-
policies_in_group = policy_group_info["policies"] || []
|
|
62
|
-
policies_in_group.each do |name, revision_info|
|
|
63
|
-
rev_id = revision_info["revision_id"]
|
|
64
|
-
policy_revision_data = http_client.get("/policies/#{name}/revisions/#{rev_id}")
|
|
65
|
-
undo_record.add_policy_revision(name, policy_group, policy_revision_data)
|
|
66
|
-
end
|
|
67
|
-
http_client.delete("/policy_groups/#{policy_group}")
|
|
68
|
-
undo_record.add_policy_group(policy_group)
|
|
69
|
-
ui.err("Removed policy group '#{policy_group}'.")
|
|
70
|
-
undo_stack.push(undo_record)
|
|
71
|
-
rescue => e
|
|
72
|
-
raise DeletePolicyGroupError.new("Failed to delete policy group '#{policy_group}'", e)
|
|
73
|
-
end
|
|
74
|
-
|
|
75
|
-
# @api private
|
|
76
|
-
# An instance of ChefDK::AuthenticatedHTTP configured with the user's
|
|
77
|
-
# server URL and credentials.
|
|
78
|
-
def http_client
|
|
79
|
-
@http_client ||= ChefDK::AuthenticatedHTTP.new(chef_config.chef_server_url,
|
|
80
|
-
signing_key_filename: chef_config.client_key,
|
|
81
|
-
client_name: chef_config.node_name)
|
|
82
|
-
end
|
|
83
|
-
end
|
|
84
|
-
end
|
|
85
|
-
end
|
|
86
|
-
|
|
1
|
+
#
|
|
2
|
+
# Copyright:: Copyright (c) 2015 Chef Software Inc.
|
|
3
|
+
# License:: Apache License, Version 2.0
|
|
4
|
+
#
|
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
# you may not use this file except in compliance with the License.
|
|
7
|
+
# You may obtain a copy of the License at
|
|
8
|
+
#
|
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
#
|
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
# See the License for the specific language governing permissions and
|
|
15
|
+
# limitations under the License.
|
|
16
|
+
#
|
|
17
|
+
|
|
18
|
+
require 'chef-dk/service_exceptions'
|
|
19
|
+
require 'chef-dk/authenticated_http'
|
|
20
|
+
require 'chef-dk/policyfile/undo_stack'
|
|
21
|
+
require 'chef-dk/policyfile/undo_record'
|
|
22
|
+
|
|
23
|
+
module ChefDK
|
|
24
|
+
module PolicyfileServices
|
|
25
|
+
|
|
26
|
+
class RmPolicyGroup
|
|
27
|
+
|
|
28
|
+
attr_reader :policy_group
|
|
29
|
+
|
|
30
|
+
# @api private
|
|
31
|
+
attr_reader :chef_config
|
|
32
|
+
|
|
33
|
+
# @api private
|
|
34
|
+
attr_reader :ui
|
|
35
|
+
|
|
36
|
+
# @api private
|
|
37
|
+
attr_reader :undo_record
|
|
38
|
+
|
|
39
|
+
# @api private
|
|
40
|
+
attr_reader :undo_stack
|
|
41
|
+
|
|
42
|
+
def initialize(config: nil, ui: nil, policy_group: nil)
|
|
43
|
+
@chef_config = config
|
|
44
|
+
@ui = ui
|
|
45
|
+
@policy_group = policy_group
|
|
46
|
+
|
|
47
|
+
@undo_record = Policyfile::UndoRecord.new
|
|
48
|
+
@undo_stack = Policyfile::UndoStack.new
|
|
49
|
+
end
|
|
50
|
+
|
|
51
|
+
def run
|
|
52
|
+
undo_record.description = "delete-policy-group #{policy_group}"
|
|
53
|
+
policy_group_list = http_client.get("/policy_groups")
|
|
54
|
+
|
|
55
|
+
unless policy_group_list.has_key?(policy_group)
|
|
56
|
+
ui.err("Policy group '#{policy_group}' does not exist on the server")
|
|
57
|
+
return false
|
|
58
|
+
end
|
|
59
|
+
policy_group_info = policy_group_list[policy_group]
|
|
60
|
+
|
|
61
|
+
policies_in_group = policy_group_info["policies"] || []
|
|
62
|
+
policies_in_group.each do |name, revision_info|
|
|
63
|
+
rev_id = revision_info["revision_id"]
|
|
64
|
+
policy_revision_data = http_client.get("/policies/#{name}/revisions/#{rev_id}")
|
|
65
|
+
undo_record.add_policy_revision(name, policy_group, policy_revision_data)
|
|
66
|
+
end
|
|
67
|
+
http_client.delete("/policy_groups/#{policy_group}")
|
|
68
|
+
undo_record.add_policy_group(policy_group)
|
|
69
|
+
ui.err("Removed policy group '#{policy_group}'.")
|
|
70
|
+
undo_stack.push(undo_record)
|
|
71
|
+
rescue => e
|
|
72
|
+
raise DeletePolicyGroupError.new("Failed to delete policy group '#{policy_group}'", e)
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
# @api private
|
|
76
|
+
# An instance of ChefDK::AuthenticatedHTTP configured with the user's
|
|
77
|
+
# server URL and credentials.
|
|
78
|
+
def http_client
|
|
79
|
+
@http_client ||= ChefDK::AuthenticatedHTTP.new(chef_config.chef_server_url,
|
|
80
|
+
signing_key_filename: chef_config.client_key,
|
|
81
|
+
client_name: chef_config.node_name)
|
|
82
|
+
end
|
|
83
|
+
end
|
|
84
|
+
end
|
|
85
|
+
end
|
|
86
|
+
|
|
@@ -1,237 +1,237 @@
|
|
|
1
|
-
#
|
|
2
|
-
# Copyright:: Copyright (c) 2015 Chef Software Inc.
|
|
3
|
-
# License:: Apache License, Version 2.0
|
|
4
|
-
#
|
|
5
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
-
# you may not use this file except in compliance with the License.
|
|
7
|
-
# You may obtain a copy of the License at
|
|
8
|
-
#
|
|
9
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
-
#
|
|
11
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
12
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
-
# See the License for the specific language governing permissions and
|
|
15
|
-
# limitations under the License.
|
|
16
|
-
#
|
|
17
|
-
|
|
18
|
-
require 'chef-dk/policyfile/comparison_base'
|
|
19
|
-
require 'chef-dk/policyfile/lister'
|
|
20
|
-
require 'chef-dk/pager'
|
|
21
|
-
|
|
22
|
-
module ChefDK
|
|
23
|
-
module PolicyfileServices
|
|
24
|
-
class ShowPolicy
|
|
25
|
-
class ReportPrinter
|
|
26
|
-
|
|
27
|
-
attr_reader :ui
|
|
28
|
-
|
|
29
|
-
def initialize(ui)
|
|
30
|
-
@ui = ui
|
|
31
|
-
end
|
|
32
|
-
|
|
33
|
-
def h1(heading)
|
|
34
|
-
ui.msg(heading)
|
|
35
|
-
ui.msg("=" * heading.size)
|
|
36
|
-
ui.msg("")
|
|
37
|
-
end
|
|
38
|
-
|
|
39
|
-
def h2(heading)
|
|
40
|
-
ui.msg(heading)
|
|
41
|
-
ui.msg("-" * heading.size)
|
|
42
|
-
ui.msg("")
|
|
43
|
-
end
|
|
44
|
-
|
|
45
|
-
def table_list(items)
|
|
46
|
-
left_justify_size = items.keys.map(&:size).max.to_i + 2
|
|
47
|
-
items.each do |name, value|
|
|
48
|
-
justified_name = "#{name}:".ljust(left_justify_size)
|
|
49
|
-
ui.msg("* #{justified_name} #{value}")
|
|
50
|
-
end
|
|
51
|
-
|
|
52
|
-
ui.msg("")
|
|
53
|
-
end
|
|
54
|
-
|
|
55
|
-
def list(items)
|
|
56
|
-
items.each { |item| ui.msg("* #{item}") }
|
|
57
|
-
ui.msg("")
|
|
58
|
-
end
|
|
59
|
-
end
|
|
60
|
-
|
|
61
|
-
attr_reader :policy_lister
|
|
62
|
-
|
|
63
|
-
attr_reader :ui
|
|
64
|
-
|
|
65
|
-
attr_reader :policy_name
|
|
66
|
-
|
|
67
|
-
attr_reader :chef_config
|
|
68
|
-
|
|
69
|
-
attr_reader :policy_group
|
|
70
|
-
|
|
71
|
-
def initialize(config: nil, ui: nil, policy_name: nil, policy_group: nil, show_orphans: false, summary_diff: false, pager: false)
|
|
72
|
-
@chef_config = config
|
|
73
|
-
@ui = ui
|
|
74
|
-
@policy_name = policy_name
|
|
75
|
-
@policy_group = policy_group
|
|
76
|
-
@show_orphans = show_orphans
|
|
77
|
-
@summary_diff = summary_diff
|
|
78
|
-
@enable_pager = pager
|
|
79
|
-
end
|
|
80
|
-
|
|
81
|
-
def run
|
|
82
|
-
if show_policy_revision?
|
|
83
|
-
display_policy_revision
|
|
84
|
-
elsif show_all_policies?
|
|
85
|
-
display_all_policies
|
|
86
|
-
else
|
|
87
|
-
display_single_policy
|
|
88
|
-
end
|
|
89
|
-
true
|
|
90
|
-
rescue PolicyfileNestedException
|
|
91
|
-
raise
|
|
92
|
-
rescue => e
|
|
93
|
-
raise PolicyfileListError.new("Failed to list policyfile data from the server", e)
|
|
94
|
-
end
|
|
95
|
-
|
|
96
|
-
def show_policy_revision?
|
|
97
|
-
!!policy_group
|
|
98
|
-
end
|
|
99
|
-
|
|
100
|
-
def show_all_policies?
|
|
101
|
-
!policy_name
|
|
102
|
-
end
|
|
103
|
-
|
|
104
|
-
def show_orphans?
|
|
105
|
-
@show_orphans
|
|
106
|
-
end
|
|
107
|
-
|
|
108
|
-
def show_summary_diff?
|
|
109
|
-
@summary_diff
|
|
110
|
-
end
|
|
111
|
-
|
|
112
|
-
def enable_pager?
|
|
113
|
-
@enable_pager
|
|
114
|
-
end
|
|
115
|
-
|
|
116
|
-
def report
|
|
117
|
-
@report ||= ReportPrinter.new(ui)
|
|
118
|
-
end
|
|
119
|
-
|
|
120
|
-
def policy_lister
|
|
121
|
-
@policy_info_fetcher ||= Policyfile::Lister.new(config: chef_config)
|
|
122
|
-
end
|
|
123
|
-
|
|
124
|
-
def display_policy_revision
|
|
125
|
-
lock = Policyfile::ComparisonBase::PolicyGroup.new(policy_group, policy_name, http_client).lock
|
|
126
|
-
pager = Pager.new(enable_pager: enable_pager?)
|
|
127
|
-
pager.with_pager { |p| p.ui.msg(FFI_Yajl::Encoder.encode(lock, pretty: true)) }
|
|
128
|
-
end
|
|
129
|
-
|
|
130
|
-
def display_all_policies
|
|
131
|
-
if policy_lister.empty?
|
|
132
|
-
ui.err("No policies or policy groups exist on the server")
|
|
133
|
-
return
|
|
134
|
-
end
|
|
135
|
-
if policy_lister.policies_by_name.empty?
|
|
136
|
-
ui.err("No policies exist on the server")
|
|
137
|
-
return
|
|
138
|
-
end
|
|
139
|
-
policy_lister.revision_ids_by_group_for_each_policy do |policy_name, rev_id_by_group|
|
|
140
|
-
report.h1(policy_name)
|
|
141
|
-
|
|
142
|
-
if rev_id_by_group.empty?
|
|
143
|
-
ui.err("Policy #{policy_name} is not assigned to any groups")
|
|
144
|
-
ui.err("")
|
|
145
|
-
else
|
|
146
|
-
rev_ids_for_report = format_rev_ids_for_report(rev_id_by_group)
|
|
147
|
-
report.table_list(rev_ids_for_report)
|
|
148
|
-
end
|
|
149
|
-
|
|
150
|
-
if show_orphans?
|
|
151
|
-
orphans = policy_lister.orphaned_revisions(policy_name)
|
|
152
|
-
|
|
153
|
-
unless orphans.empty?
|
|
154
|
-
report.h2("Orphaned:")
|
|
155
|
-
formatted_orphans = orphans.map { |id| shorten_rev_id(id) }
|
|
156
|
-
report.list(formatted_orphans)
|
|
157
|
-
end
|
|
158
|
-
end
|
|
159
|
-
end
|
|
160
|
-
end
|
|
161
|
-
|
|
162
|
-
def display_single_policy
|
|
163
|
-
report.h1(policy_name)
|
|
164
|
-
rev_id_by_group = policy_lister.revision_ids_by_group_for(policy_name)
|
|
165
|
-
|
|
166
|
-
if rev_id_by_group.empty? || rev_id_by_group.all? { |_k, rev| rev.nil? }
|
|
167
|
-
ui.err("No policies named '#{policy_name}' are associated with a policy group")
|
|
168
|
-
ui.err("")
|
|
169
|
-
elsif show_summary_diff?
|
|
170
|
-
unique_rev_ids = rev_id_by_group.unique_revision_ids
|
|
171
|
-
revision_info = policy_lister.revision_info_for(policy_name, unique_rev_ids)
|
|
172
|
-
|
|
173
|
-
ljust_size = rev_id_by_group.max_group_name_length + 2
|
|
174
|
-
|
|
175
|
-
cbs_with_differing_ids = revision_info.cbs_with_differing_ids
|
|
176
|
-
|
|
177
|
-
rev_id_by_group.each do |group_name, rev_id|
|
|
178
|
-
heading = "#{group_name}:".ljust(ljust_size) + shorten_rev_id(rev_id)
|
|
179
|
-
report.h2(heading)
|
|
180
|
-
|
|
181
|
-
differing_cbs_version_info = cbs_with_differing_ids.inject({}) do |cb_version_info, cb_name|
|
|
182
|
-
|
|
183
|
-
version, identifier = revision_info.cb_info_for(rev_id, cb_name)
|
|
184
|
-
|
|
185
|
-
cb_info_for_report =
|
|
186
|
-
if !version.nil?
|
|
187
|
-
"#{version} (#{shorten_rev_id(identifier)})"
|
|
188
|
-
else
|
|
189
|
-
"*NONE*"
|
|
190
|
-
end
|
|
191
|
-
|
|
192
|
-
cb_version_info[cb_name] = cb_info_for_report
|
|
193
|
-
|
|
194
|
-
cb_version_info
|
|
195
|
-
end
|
|
196
|
-
|
|
197
|
-
report.table_list(differing_cbs_version_info)
|
|
198
|
-
end
|
|
199
|
-
|
|
200
|
-
else
|
|
201
|
-
rev_ids_for_report = format_rev_ids_for_report(rev_id_by_group)
|
|
202
|
-
report.table_list(rev_ids_for_report)
|
|
203
|
-
end
|
|
204
|
-
|
|
205
|
-
if show_orphans?
|
|
206
|
-
orphans = policy_lister.orphaned_revisions(policy_name)
|
|
207
|
-
|
|
208
|
-
unless orphans.empty?
|
|
209
|
-
report.h2("Orphaned:")
|
|
210
|
-
formatted_orphans = orphans.map { |id| shorten_rev_id(id) }
|
|
211
|
-
report.list(formatted_orphans)
|
|
212
|
-
end
|
|
213
|
-
end
|
|
214
|
-
end
|
|
215
|
-
|
|
216
|
-
def shorten_rev_id(revision_id)
|
|
217
|
-
revision_id[0,10]
|
|
218
|
-
end
|
|
219
|
-
|
|
220
|
-
def http_client
|
|
221
|
-
@http_client ||= ChefDK::AuthenticatedHTTP.new(chef_config.chef_server_url,
|
|
222
|
-
signing_key_filename: chef_config.client_key,
|
|
223
|
-
client_name: chef_config.node_name)
|
|
224
|
-
end
|
|
225
|
-
|
|
226
|
-
private
|
|
227
|
-
|
|
228
|
-
def format_rev_ids_for_report(rev_id_by_group)
|
|
229
|
-
rev_id_by_group.format_revision_ids do |rev_id|
|
|
230
|
-
rev_id ? rev_id[0,10] : "*NOT APPLIED*"
|
|
231
|
-
end
|
|
232
|
-
end
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
end
|
|
236
|
-
end
|
|
237
|
-
end
|
|
1
|
+
#
|
|
2
|
+
# Copyright:: Copyright (c) 2015 Chef Software Inc.
|
|
3
|
+
# License:: Apache License, Version 2.0
|
|
4
|
+
#
|
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
# you may not use this file except in compliance with the License.
|
|
7
|
+
# You may obtain a copy of the License at
|
|
8
|
+
#
|
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
#
|
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
# See the License for the specific language governing permissions and
|
|
15
|
+
# limitations under the License.
|
|
16
|
+
#
|
|
17
|
+
|
|
18
|
+
require 'chef-dk/policyfile/comparison_base'
|
|
19
|
+
require 'chef-dk/policyfile/lister'
|
|
20
|
+
require 'chef-dk/pager'
|
|
21
|
+
|
|
22
|
+
module ChefDK
|
|
23
|
+
module PolicyfileServices
|
|
24
|
+
class ShowPolicy
|
|
25
|
+
class ReportPrinter
|
|
26
|
+
|
|
27
|
+
attr_reader :ui
|
|
28
|
+
|
|
29
|
+
def initialize(ui)
|
|
30
|
+
@ui = ui
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
def h1(heading)
|
|
34
|
+
ui.msg(heading)
|
|
35
|
+
ui.msg("=" * heading.size)
|
|
36
|
+
ui.msg("")
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
def h2(heading)
|
|
40
|
+
ui.msg(heading)
|
|
41
|
+
ui.msg("-" * heading.size)
|
|
42
|
+
ui.msg("")
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
def table_list(items)
|
|
46
|
+
left_justify_size = items.keys.map(&:size).max.to_i + 2
|
|
47
|
+
items.each do |name, value|
|
|
48
|
+
justified_name = "#{name}:".ljust(left_justify_size)
|
|
49
|
+
ui.msg("* #{justified_name} #{value}")
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
ui.msg("")
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
def list(items)
|
|
56
|
+
items.each { |item| ui.msg("* #{item}") }
|
|
57
|
+
ui.msg("")
|
|
58
|
+
end
|
|
59
|
+
end
|
|
60
|
+
|
|
61
|
+
attr_reader :policy_lister
|
|
62
|
+
|
|
63
|
+
attr_reader :ui
|
|
64
|
+
|
|
65
|
+
attr_reader :policy_name
|
|
66
|
+
|
|
67
|
+
attr_reader :chef_config
|
|
68
|
+
|
|
69
|
+
attr_reader :policy_group
|
|
70
|
+
|
|
71
|
+
def initialize(config: nil, ui: nil, policy_name: nil, policy_group: nil, show_orphans: false, summary_diff: false, pager: false)
|
|
72
|
+
@chef_config = config
|
|
73
|
+
@ui = ui
|
|
74
|
+
@policy_name = policy_name
|
|
75
|
+
@policy_group = policy_group
|
|
76
|
+
@show_orphans = show_orphans
|
|
77
|
+
@summary_diff = summary_diff
|
|
78
|
+
@enable_pager = pager
|
|
79
|
+
end
|
|
80
|
+
|
|
81
|
+
def run
|
|
82
|
+
if show_policy_revision?
|
|
83
|
+
display_policy_revision
|
|
84
|
+
elsif show_all_policies?
|
|
85
|
+
display_all_policies
|
|
86
|
+
else
|
|
87
|
+
display_single_policy
|
|
88
|
+
end
|
|
89
|
+
true
|
|
90
|
+
rescue PolicyfileNestedException
|
|
91
|
+
raise
|
|
92
|
+
rescue => e
|
|
93
|
+
raise PolicyfileListError.new("Failed to list policyfile data from the server", e)
|
|
94
|
+
end
|
|
95
|
+
|
|
96
|
+
def show_policy_revision?
|
|
97
|
+
!!policy_group
|
|
98
|
+
end
|
|
99
|
+
|
|
100
|
+
def show_all_policies?
|
|
101
|
+
!policy_name
|
|
102
|
+
end
|
|
103
|
+
|
|
104
|
+
def show_orphans?
|
|
105
|
+
@show_orphans
|
|
106
|
+
end
|
|
107
|
+
|
|
108
|
+
def show_summary_diff?
|
|
109
|
+
@summary_diff
|
|
110
|
+
end
|
|
111
|
+
|
|
112
|
+
def enable_pager?
|
|
113
|
+
@enable_pager
|
|
114
|
+
end
|
|
115
|
+
|
|
116
|
+
def report
|
|
117
|
+
@report ||= ReportPrinter.new(ui)
|
|
118
|
+
end
|
|
119
|
+
|
|
120
|
+
def policy_lister
|
|
121
|
+
@policy_info_fetcher ||= Policyfile::Lister.new(config: chef_config)
|
|
122
|
+
end
|
|
123
|
+
|
|
124
|
+
def display_policy_revision
|
|
125
|
+
lock = Policyfile::ComparisonBase::PolicyGroup.new(policy_group, policy_name, http_client).lock
|
|
126
|
+
pager = Pager.new(enable_pager: enable_pager?)
|
|
127
|
+
pager.with_pager { |p| p.ui.msg(FFI_Yajl::Encoder.encode(lock, pretty: true)) }
|
|
128
|
+
end
|
|
129
|
+
|
|
130
|
+
def display_all_policies
|
|
131
|
+
if policy_lister.empty?
|
|
132
|
+
ui.err("No policies or policy groups exist on the server")
|
|
133
|
+
return
|
|
134
|
+
end
|
|
135
|
+
if policy_lister.policies_by_name.empty?
|
|
136
|
+
ui.err("No policies exist on the server")
|
|
137
|
+
return
|
|
138
|
+
end
|
|
139
|
+
policy_lister.revision_ids_by_group_for_each_policy do |policy_name, rev_id_by_group|
|
|
140
|
+
report.h1(policy_name)
|
|
141
|
+
|
|
142
|
+
if rev_id_by_group.empty?
|
|
143
|
+
ui.err("Policy #{policy_name} is not assigned to any groups")
|
|
144
|
+
ui.err("")
|
|
145
|
+
else
|
|
146
|
+
rev_ids_for_report = format_rev_ids_for_report(rev_id_by_group)
|
|
147
|
+
report.table_list(rev_ids_for_report)
|
|
148
|
+
end
|
|
149
|
+
|
|
150
|
+
if show_orphans?
|
|
151
|
+
orphans = policy_lister.orphaned_revisions(policy_name)
|
|
152
|
+
|
|
153
|
+
unless orphans.empty?
|
|
154
|
+
report.h2("Orphaned:")
|
|
155
|
+
formatted_orphans = orphans.map { |id| shorten_rev_id(id) }
|
|
156
|
+
report.list(formatted_orphans)
|
|
157
|
+
end
|
|
158
|
+
end
|
|
159
|
+
end
|
|
160
|
+
end
|
|
161
|
+
|
|
162
|
+
def display_single_policy
|
|
163
|
+
report.h1(policy_name)
|
|
164
|
+
rev_id_by_group = policy_lister.revision_ids_by_group_for(policy_name)
|
|
165
|
+
|
|
166
|
+
if rev_id_by_group.empty? || rev_id_by_group.all? { |_k, rev| rev.nil? }
|
|
167
|
+
ui.err("No policies named '#{policy_name}' are associated with a policy group")
|
|
168
|
+
ui.err("")
|
|
169
|
+
elsif show_summary_diff?
|
|
170
|
+
unique_rev_ids = rev_id_by_group.unique_revision_ids
|
|
171
|
+
revision_info = policy_lister.revision_info_for(policy_name, unique_rev_ids)
|
|
172
|
+
|
|
173
|
+
ljust_size = rev_id_by_group.max_group_name_length + 2
|
|
174
|
+
|
|
175
|
+
cbs_with_differing_ids = revision_info.cbs_with_differing_ids
|
|
176
|
+
|
|
177
|
+
rev_id_by_group.each do |group_name, rev_id|
|
|
178
|
+
heading = "#{group_name}:".ljust(ljust_size) + shorten_rev_id(rev_id)
|
|
179
|
+
report.h2(heading)
|
|
180
|
+
|
|
181
|
+
differing_cbs_version_info = cbs_with_differing_ids.inject({}) do |cb_version_info, cb_name|
|
|
182
|
+
|
|
183
|
+
version, identifier = revision_info.cb_info_for(rev_id, cb_name)
|
|
184
|
+
|
|
185
|
+
cb_info_for_report =
|
|
186
|
+
if !version.nil?
|
|
187
|
+
"#{version} (#{shorten_rev_id(identifier)})"
|
|
188
|
+
else
|
|
189
|
+
"*NONE*"
|
|
190
|
+
end
|
|
191
|
+
|
|
192
|
+
cb_version_info[cb_name] = cb_info_for_report
|
|
193
|
+
|
|
194
|
+
cb_version_info
|
|
195
|
+
end
|
|
196
|
+
|
|
197
|
+
report.table_list(differing_cbs_version_info)
|
|
198
|
+
end
|
|
199
|
+
|
|
200
|
+
else
|
|
201
|
+
rev_ids_for_report = format_rev_ids_for_report(rev_id_by_group)
|
|
202
|
+
report.table_list(rev_ids_for_report)
|
|
203
|
+
end
|
|
204
|
+
|
|
205
|
+
if show_orphans?
|
|
206
|
+
orphans = policy_lister.orphaned_revisions(policy_name)
|
|
207
|
+
|
|
208
|
+
unless orphans.empty?
|
|
209
|
+
report.h2("Orphaned:")
|
|
210
|
+
formatted_orphans = orphans.map { |id| shorten_rev_id(id) }
|
|
211
|
+
report.list(formatted_orphans)
|
|
212
|
+
end
|
|
213
|
+
end
|
|
214
|
+
end
|
|
215
|
+
|
|
216
|
+
def shorten_rev_id(revision_id)
|
|
217
|
+
revision_id[0,10]
|
|
218
|
+
end
|
|
219
|
+
|
|
220
|
+
def http_client
|
|
221
|
+
@http_client ||= ChefDK::AuthenticatedHTTP.new(chef_config.chef_server_url,
|
|
222
|
+
signing_key_filename: chef_config.client_key,
|
|
223
|
+
client_name: chef_config.node_name)
|
|
224
|
+
end
|
|
225
|
+
|
|
226
|
+
private
|
|
227
|
+
|
|
228
|
+
def format_rev_ids_for_report(rev_id_by_group)
|
|
229
|
+
rev_id_by_group.format_revision_ids do |rev_id|
|
|
230
|
+
rev_id ? rev_id[0,10] : "*NOT APPLIED*"
|
|
231
|
+
end
|
|
232
|
+
end
|
|
233
|
+
|
|
234
|
+
|
|
235
|
+
end
|
|
236
|
+
end
|
|
237
|
+
end
|