mbailey-chef 0.9.12.1
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE +201 -0
- data/README.rdoc +172 -0
- data/bin/chef-client +26 -0
- data/bin/chef-solo +25 -0
- data/bin/knife +26 -0
- data/bin/shef +34 -0
- data/distro/README +2 -0
- data/distro/common/man/man1/chef-indexer.1 +42 -0
- data/distro/common/man/man1/chef-server-webui.1 +106 -0
- data/distro/common/man/man1/chef-server.1 +107 -0
- data/distro/common/man/man1/chef-solr-indexer.1 +55 -0
- data/distro/common/man/man1/chef-solr.1 +55 -0
- data/distro/common/man/man8/chef-client.8 +63 -0
- data/distro/common/man/man8/chef-solo.8 +57 -0
- data/distro/common/man/man8/chef-solr-rebuild.8 +37 -0
- data/distro/common/man/man8/knife.8 +1349 -0
- data/distro/common/man/man8/shef.8 +45 -0
- data/distro/common/markdown/README +3 -0
- data/distro/common/markdown/knife.mkd +832 -0
- data/distro/debian/etc/default/chef-client +4 -0
- data/distro/debian/etc/default/chef-server +9 -0
- data/distro/debian/etc/default/chef-server-webui +9 -0
- data/distro/debian/etc/default/chef-solr +7 -0
- data/distro/debian/etc/default/chef-solr-indexer +7 -0
- data/distro/debian/etc/init/chef-client.conf +17 -0
- data/distro/debian/etc/init/chef-server-webui.conf +17 -0
- data/distro/debian/etc/init/chef-server.conf +17 -0
- data/distro/debian/etc/init/chef-solr-indexer.conf +17 -0
- data/distro/debian/etc/init/chef-solr.conf +17 -0
- data/distro/debian/etc/init.d/chef-client +175 -0
- data/distro/debian/etc/init.d/chef-server +122 -0
- data/distro/debian/etc/init.d/chef-server-webui +123 -0
- data/distro/debian/etc/init.d/chef-solr +177 -0
- data/distro/debian/etc/init.d/chef-solr-indexer +176 -0
- data/distro/redhat/etc/init.d/chef-client +106 -0
- data/distro/redhat/etc/init.d/chef-server +112 -0
- data/distro/redhat/etc/init.d/chef-server-webui +112 -0
- data/distro/redhat/etc/init.d/chef-solr +104 -0
- data/distro/redhat/etc/init.d/chef-solr-indexer +104 -0
- data/distro/redhat/etc/logrotate.d/chef-client +8 -0
- data/distro/redhat/etc/logrotate.d/chef-server +8 -0
- data/distro/redhat/etc/logrotate.d/chef-server-webui +8 -0
- data/distro/redhat/etc/logrotate.d/chef-solr +8 -0
- data/distro/redhat/etc/logrotate.d/chef-solr-indexer +8 -0
- data/distro/redhat/etc/sysconfig/chef-client +15 -0
- data/distro/redhat/etc/sysconfig/chef-server +14 -0
- data/distro/redhat/etc/sysconfig/chef-server-webui +14 -0
- data/distro/redhat/etc/sysconfig/chef-solr +8 -0
- data/distro/redhat/etc/sysconfig/chef-solr-indexer +7 -0
- data/lib/chef/api_client.rb +264 -0
- data/lib/chef/application/agent.rb +18 -0
- data/lib/chef/application/client.rb +246 -0
- data/lib/chef/application/knife.rb +171 -0
- data/lib/chef/application/solo.rb +215 -0
- data/lib/chef/application.rb +127 -0
- data/lib/chef/applications.rb +4 -0
- data/lib/chef/certificate.rb +194 -0
- data/lib/chef/checksum.rb +182 -0
- data/lib/chef/checksum_cache.rb +173 -0
- data/lib/chef/client.rb +304 -0
- data/lib/chef/config.rb +240 -0
- data/lib/chef/cookbook/cookbook_collection.rb +44 -0
- data/lib/chef/cookbook/file_system_file_vendor.rb +54 -0
- data/lib/chef/cookbook/file_vendor.rb +48 -0
- data/lib/chef/cookbook/metadata/version.rb +87 -0
- data/lib/chef/cookbook/metadata.rb +500 -0
- data/lib/chef/cookbook/remote_file_vendor.rb +87 -0
- data/lib/chef/cookbook/syntax_check.rb +136 -0
- data/lib/chef/cookbook_loader.rb +227 -0
- data/lib/chef/cookbook_site_streaming_uploader.rb +244 -0
- data/lib/chef/cookbook_uploader.rb +103 -0
- data/lib/chef/cookbook_version.rb +930 -0
- data/lib/chef/couchdb.rb +239 -0
- data/lib/chef/daemon.rb +172 -0
- data/lib/chef/data_bag.rb +215 -0
- data/lib/chef/data_bag_item.rb +228 -0
- data/lib/chef/exceptions.rb +66 -0
- data/lib/chef/file_access_control.rb +140 -0
- data/lib/chef/file_cache.rb +218 -0
- data/lib/chef/handler/json_file.rb +58 -0
- data/lib/chef/handler.rb +206 -0
- data/lib/chef/index_queue/amqp_client.rb +113 -0
- data/lib/chef/index_queue/consumer.rb +76 -0
- data/lib/chef/index_queue/indexable.rb +76 -0
- data/lib/chef/index_queue.rb +29 -0
- data/lib/chef/knife/bootstrap/archlinux-gems.erb +44 -0
- data/lib/chef/knife/bootstrap/centos5-gems.erb +41 -0
- data/lib/chef/knife/bootstrap/client-install.vbs +80 -0
- data/lib/chef/knife/bootstrap/fedora13-gems.erb +38 -0
- data/lib/chef/knife/bootstrap/ubuntu10.04-apt.erb +32 -0
- data/lib/chef/knife/bootstrap/ubuntu10.04-gems.erb +43 -0
- data/lib/chef/knife/bootstrap/windows-gems.erb +34 -0
- data/lib/chef/knife/bootstrap.rb +181 -0
- data/lib/chef/knife/client_bulk_delete.rb +40 -0
- data/lib/chef/knife/client_create.rb +70 -0
- data/lib/chef/knife/client_delete.rb +45 -0
- data/lib/chef/knife/client_edit.rb +45 -0
- data/lib/chef/knife/client_list.rb +40 -0
- data/lib/chef/knife/client_reregister.rb +56 -0
- data/lib/chef/knife/client_show.rb +50 -0
- data/lib/chef/knife/configure.rb +140 -0
- data/lib/chef/knife/configure_client.rb +52 -0
- data/lib/chef/knife/cookbook_bulk_delete.rb +58 -0
- data/lib/chef/knife/cookbook_create.rb +209 -0
- data/lib/chef/knife/cookbook_delete.rb +143 -0
- data/lib/chef/knife/cookbook_download.rb +130 -0
- data/lib/chef/knife/cookbook_list.rb +41 -0
- data/lib/chef/knife/cookbook_metadata.rb +82 -0
- data/lib/chef/knife/cookbook_metadata_from_file.rb +40 -0
- data/lib/chef/knife/cookbook_show.rb +98 -0
- data/lib/chef/knife/cookbook_site_download.rb +58 -0
- data/lib/chef/knife/cookbook_site_list.rb +56 -0
- data/lib/chef/knife/cookbook_site_search.rb +51 -0
- data/lib/chef/knife/cookbook_site_share.rb +109 -0
- data/lib/chef/knife/cookbook_site_show.rb +57 -0
- data/lib/chef/knife/cookbook_site_unshare.rb +52 -0
- data/lib/chef/knife/cookbook_site_vendor.rb +133 -0
- data/lib/chef/knife/cookbook_test.rb +82 -0
- data/lib/chef/knife/cookbook_upload.rb +95 -0
- data/lib/chef/knife/data_bag_create.rb +59 -0
- data/lib/chef/knife/data_bag_delete.rb +48 -0
- data/lib/chef/knife/data_bag_edit.rb +50 -0
- data/lib/chef/knife/data_bag_from_file.rb +44 -0
- data/lib/chef/knife/data_bag_list.rb +43 -0
- data/lib/chef/knife/data_bag_show.rb +41 -0
- data/lib/chef/knife/ec2_instance_data.rb +46 -0
- data/lib/chef/knife/ec2_server_create.rb +216 -0
- data/lib/chef/knife/ec2_server_delete.rb +90 -0
- data/lib/chef/knife/ec2_server_list.rb +88 -0
- data/lib/chef/knife/exec.rb +52 -0
- data/lib/chef/knife/index_rebuild.rb +51 -0
- data/lib/chef/knife/node_bulk_delete.rb +43 -0
- data/lib/chef/knife/node_create.rb +47 -0
- data/lib/chef/knife/node_delete.rb +44 -0
- data/lib/chef/knife/node_edit.rb +44 -0
- data/lib/chef/knife/node_from_file.rb +42 -0
- data/lib/chef/knife/node_list.rb +41 -0
- data/lib/chef/knife/node_run_list_add.rb +64 -0
- data/lib/chef/knife/node_run_list_remove.rb +45 -0
- data/lib/chef/knife/node_show.rb +54 -0
- data/lib/chef/knife/rackspace_server_create.rb +156 -0
- data/lib/chef/knife/rackspace_server_delete.rb +57 -0
- data/lib/chef/knife/rackspace_server_list.rb +59 -0
- data/lib/chef/knife/recipe_list.rb +32 -0
- data/lib/chef/knife/role_bulk_delete.rb +44 -0
- data/lib/chef/knife/role_create.rb +52 -0
- data/lib/chef/knife/role_delete.rb +44 -0
- data/lib/chef/knife/role_edit.rb +45 -0
- data/lib/chef/knife/role_from_file.rb +46 -0
- data/lib/chef/knife/role_list.rb +40 -0
- data/lib/chef/knife/role_show.rb +51 -0
- data/lib/chef/knife/search.rb +94 -0
- data/lib/chef/knife/slicehost_images_list.rb +53 -0
- data/lib/chef/knife/slicehost_server_create.rb +103 -0
- data/lib/chef/knife/slicehost_server_delete.rb +61 -0
- data/lib/chef/knife/slicehost_server_list.rb +64 -0
- data/lib/chef/knife/ssh.rb +328 -0
- data/lib/chef/knife/status.rb +87 -0
- data/lib/chef/knife/terremark_server_create.rb +152 -0
- data/lib/chef/knife/terremark_server_delete.rb +87 -0
- data/lib/chef/knife/terremark_server_list.rb +77 -0
- data/lib/chef/knife/windows_bootstrap.rb +154 -0
- data/lib/chef/knife.rb +522 -0
- data/lib/chef/log.rb +61 -0
- data/lib/chef/mixin/check_helper.rb +31 -0
- data/lib/chef/mixin/checksum.rb +32 -0
- data/lib/chef/mixin/command/unix.rb +215 -0
- data/lib/chef/mixin/command/windows.rb +72 -0
- data/lib/chef/mixin/command.rb +220 -0
- data/lib/chef/mixin/convert_to_class_name.rb +63 -0
- data/lib/chef/mixin/create_path.rb +56 -0
- data/lib/chef/mixin/deep_merge.rb +225 -0
- data/lib/chef/mixin/deprecation.rb +65 -0
- data/lib/chef/mixin/find_preferred_file.rb +92 -0
- data/lib/chef/mixin/from_file.rb +50 -0
- data/lib/chef/mixin/language.rb +156 -0
- data/lib/chef/mixin/language_include_attribute.rb +61 -0
- data/lib/chef/mixin/language_include_recipe.rb +52 -0
- data/lib/chef/mixin/params_validate.rb +225 -0
- data/lib/chef/mixin/recipe_definition_dsl_core.rb +81 -0
- data/lib/chef/mixin/shell_out.rb +38 -0
- data/lib/chef/mixin/template.rb +95 -0
- data/lib/chef/mixin/xml_escape.rb +140 -0
- data/lib/chef/mixins.rb +16 -0
- data/lib/chef/monkey_patches/dir.rb +36 -0
- data/lib/chef/monkey_patches/string.rb +28 -0
- data/lib/chef/monkey_patches/tempfile.rb +64 -0
- data/lib/chef/node/attribute.rb +465 -0
- data/lib/chef/node.rb +601 -0
- data/lib/chef/openid_registration.rb +187 -0
- data/lib/chef/platform.rb +371 -0
- data/lib/chef/provider/breakpoint.rb +36 -0
- data/lib/chef/provider/cookbook_file.rb +100 -0
- data/lib/chef/provider/cron/solaris.rb +195 -0
- data/lib/chef/provider/cron.rb +186 -0
- data/lib/chef/provider/deploy/revision.rb +73 -0
- data/lib/chef/provider/deploy/timestamped.rb +33 -0
- data/lib/chef/provider/deploy.rb +319 -0
- data/lib/chef/provider/directory.rb +72 -0
- data/lib/chef/provider/env/windows.rb +75 -0
- data/lib/chef/provider/env.rb +152 -0
- data/lib/chef/provider/erl_call.rb +72 -0
- data/lib/chef/provider/execute.rb +58 -0
- data/lib/chef/provider/file.rb +213 -0
- data/lib/chef/provider/git.rb +211 -0
- data/lib/chef/provider/group/dscl.rb +121 -0
- data/lib/chef/provider/group/gpasswd.rb +53 -0
- data/lib/chef/provider/group/groupadd.rb +78 -0
- data/lib/chef/provider/group/pw.rb +84 -0
- data/lib/chef/provider/group/usermod.rb +57 -0
- data/lib/chef/provider/group/windows.rb +79 -0
- data/lib/chef/provider/group.rb +133 -0
- data/lib/chef/provider/http_request.rb +122 -0
- data/lib/chef/provider/ifconfig.rb +132 -0
- data/lib/chef/provider/link.rb +161 -0
- data/lib/chef/provider/log.rb +54 -0
- data/lib/chef/provider/mdadm.rb +91 -0
- data/lib/chef/provider/mount/mount.rb +232 -0
- data/lib/chef/provider/mount/windows.rb +80 -0
- data/lib/chef/provider/mount.rb +117 -0
- data/lib/chef/provider/ohai.rb +41 -0
- data/lib/chef/provider/package/apt.rb +110 -0
- data/lib/chef/provider/package/dpkg.rb +112 -0
- data/lib/chef/provider/package/easy_install.rb +114 -0
- data/lib/chef/provider/package/freebsd.rb +123 -0
- data/lib/chef/provider/package/macports.rb +105 -0
- data/lib/chef/provider/package/pacman.rb +101 -0
- data/lib/chef/provider/package/portage.rb +124 -0
- data/lib/chef/provider/package/rpm.rb +101 -0
- data/lib/chef/provider/package/rubygems.rb +462 -0
- data/lib/chef/provider/package/solaris.rb +127 -0
- data/lib/chef/provider/package/yum-dump.py +128 -0
- data/lib/chef/provider/package/yum.rb +222 -0
- data/lib/chef/provider/package/zypper.rb +133 -0
- data/lib/chef/provider/package.rb +160 -0
- data/lib/chef/provider/remote_directory.rb +140 -0
- data/lib/chef/provider/remote_file.rb +120 -0
- data/lib/chef/provider/route.rb +195 -0
- data/lib/chef/provider/ruby_block.rb +33 -0
- data/lib/chef/provider/script.rb +55 -0
- data/lib/chef/provider/service/arch.rb +109 -0
- data/lib/chef/provider/service/debian.rb +105 -0
- data/lib/chef/provider/service/freebsd.rb +156 -0
- data/lib/chef/provider/service/gentoo.rb +54 -0
- data/lib/chef/provider/service/init.rb +71 -0
- data/lib/chef/provider/service/redhat.rb +60 -0
- data/lib/chef/provider/service/simple.rb +118 -0
- data/lib/chef/provider/service/solaris.rb +85 -0
- data/lib/chef/provider/service/upstart.rb +192 -0
- data/lib/chef/provider/service/windows.rb +129 -0
- data/lib/chef/provider/service.rb +128 -0
- data/lib/chef/provider/subversion.rb +159 -0
- data/lib/chef/provider/template.rb +105 -0
- data/lib/chef/provider/user/dscl.rb +280 -0
- data/lib/chef/provider/user/pw.rb +113 -0
- data/lib/chef/provider/user/useradd.rb +137 -0
- data/lib/chef/provider/user/windows.rb +124 -0
- data/lib/chef/provider/user.rb +187 -0
- data/lib/chef/provider.rb +124 -0
- data/lib/chef/providers.rb +91 -0
- data/lib/chef/recipe.rb +130 -0
- data/lib/chef/resource/apt_package.rb +34 -0
- data/lib/chef/resource/bash.rb +33 -0
- data/lib/chef/resource/breakpoint.rb +35 -0
- data/lib/chef/resource/cookbook_file.rb +45 -0
- data/lib/chef/resource/cron.rb +188 -0
- data/lib/chef/resource/csh.rb +33 -0
- data/lib/chef/resource/deploy.rb +371 -0
- data/lib/chef/resource/deploy_revision.rb +35 -0
- data/lib/chef/resource/directory.rb +76 -0
- data/lib/chef/resource/dpkg_package.rb +34 -0
- data/lib/chef/resource/easy_install_package.rb +41 -0
- data/lib/chef/resource/env.rb +58 -0
- data/lib/chef/resource/erl_call.rb +83 -0
- data/lib/chef/resource/execute.rb +127 -0
- data/lib/chef/resource/file.rb +92 -0
- data/lib/chef/resource/freebsd_package.rb +35 -0
- data/lib/chef/resource/gem_package.rb +49 -0
- data/lib/chef/resource/git.rb +36 -0
- data/lib/chef/resource/group.rb +70 -0
- data/lib/chef/resource/http_request.rb +61 -0
- data/lib/chef/resource/ifconfig.rb +134 -0
- data/lib/chef/resource/link.rb +78 -0
- data/lib/chef/resource/log.rb +62 -0
- data/lib/chef/resource/macports_package.rb +29 -0
- data/lib/chef/resource/mdadm.rb +82 -0
- data/lib/chef/resource/mount.rb +135 -0
- data/lib/chef/resource/ohai.rb +40 -0
- data/lib/chef/resource/package.rb +80 -0
- data/lib/chef/resource/pacman_package.rb +33 -0
- data/lib/chef/resource/perl.rb +33 -0
- data/lib/chef/resource/portage_package.rb +33 -0
- data/lib/chef/resource/python.rb +33 -0
- data/lib/chef/resource/remote_directory.rb +109 -0
- data/lib/chef/resource/remote_file.rb +83 -0
- data/lib/chef/resource/route.rb +135 -0
- data/lib/chef/resource/rpm_package.rb +34 -0
- data/lib/chef/resource/ruby.rb +33 -0
- data/lib/chef/resource/ruby_block.rb +40 -0
- data/lib/chef/resource/scm.rb +146 -0
- data/lib/chef/resource/script.rb +60 -0
- data/lib/chef/resource/service.rb +160 -0
- data/lib/chef/resource/solaris_package.rb +36 -0
- data/lib/chef/resource/subversion.rb +36 -0
- data/lib/chef/resource/template.rb +69 -0
- data/lib/chef/resource/timestamped_deploy.rb +31 -0
- data/lib/chef/resource/user.rb +130 -0
- data/lib/chef/resource/yum_package.rb +43 -0
- data/lib/chef/resource.rb +523 -0
- data/lib/chef/resource_collection/stepable_iterator.rb +124 -0
- data/lib/chef/resource_collection.rb +217 -0
- data/lib/chef/resource_definition.rb +67 -0
- data/lib/chef/resource_definition_list.rb +38 -0
- data/lib/chef/resources.rb +64 -0
- data/lib/chef/rest/auth_credentials.rb +78 -0
- data/lib/chef/rest/cookie_jar.rb +31 -0
- data/lib/chef/rest/rest_request.rb +188 -0
- data/lib/chef/rest.rb +394 -0
- data/lib/chef/role.rb +287 -0
- data/lib/chef/run_context.rb +110 -0
- data/lib/chef/run_list/run_list_expansion.rb +172 -0
- data/lib/chef/run_list/run_list_item.rb +78 -0
- data/lib/chef/run_list.rb +150 -0
- data/lib/chef/run_status.rb +121 -0
- data/lib/chef/runner.rb +107 -0
- data/lib/chef/sandbox.rb +153 -0
- data/lib/chef/search/query.rb +60 -0
- data/lib/chef/shef/ext.rb +568 -0
- data/lib/chef/shef/model_wrapper.rb +120 -0
- data/lib/chef/shef/shef_rest.rb +28 -0
- data/lib/chef/shef/shef_session.rb +271 -0
- data/lib/chef/shef.rb +325 -0
- data/lib/chef/shell_out.rb +413 -0
- data/lib/chef/streaming_cookbook_uploader.rb +201 -0
- data/lib/chef/tasks/chef_repo.rake +256 -0
- data/lib/chef/util/file_edit.rb +122 -0
- data/lib/chef/util/windows/net_group.rb +101 -0
- data/lib/chef/util/windows/net_use.rb +121 -0
- data/lib/chef/util/windows/net_user.rb +198 -0
- data/lib/chef/util/windows/volume.rb +59 -0
- data/lib/chef/util/windows.rb +56 -0
- data/lib/chef/version.rb +21 -0
- data/lib/chef/webui_user.rb +231 -0
- data/lib/chef.rb +39 -0
- metadata +533 -0
data/lib/chef/sandbox.rb
ADDED
@@ -0,0 +1,153 @@
|
|
1
|
+
#
|
2
|
+
# Author:: Tim Hinderliter (<tim@opscode.com>)
|
3
|
+
# Copyright:: Copyright (c) 2010 Opscode, Inc.
|
4
|
+
# License:: Apache License, Version 2.0
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
|
18
|
+
require 'chef/log'
|
19
|
+
require 'uuidtools'
|
20
|
+
|
21
|
+
class Chef
|
22
|
+
class Sandbox
|
23
|
+
attr_accessor :is_completed, :create_time
|
24
|
+
alias_method :is_completed?, :is_completed
|
25
|
+
attr_reader :guid
|
26
|
+
|
27
|
+
alias :name :guid
|
28
|
+
|
29
|
+
attr_accessor :couchdb, :couchdb_id, :couchdb_rev
|
30
|
+
|
31
|
+
# list of checksum ids
|
32
|
+
attr_accessor :checksums
|
33
|
+
|
34
|
+
DESIGN_DOCUMENT = {
|
35
|
+
"version" => 1,
|
36
|
+
"language" => "javascript",
|
37
|
+
"views" => {
|
38
|
+
"all" => {
|
39
|
+
"map" => <<-EOJS
|
40
|
+
function(doc) {
|
41
|
+
if (doc.chef_type == "sandbox") {
|
42
|
+
emit(doc.guid, doc);
|
43
|
+
}
|
44
|
+
}
|
45
|
+
EOJS
|
46
|
+
},
|
47
|
+
"all_id" => {
|
48
|
+
"map" => <<-EOJS
|
49
|
+
function(doc) {
|
50
|
+
if (doc.chef_type == "sandbox") {
|
51
|
+
emit(doc.guid, doc.guid);
|
52
|
+
}
|
53
|
+
}
|
54
|
+
EOJS
|
55
|
+
},
|
56
|
+
"all_incomplete" => {
|
57
|
+
"map" => <<-EOJS
|
58
|
+
function(doc) {
|
59
|
+
if (doc.chef_type == "sandbox" && !doc.is_completed) {
|
60
|
+
emit(doc.guid, doc.guid);
|
61
|
+
}
|
62
|
+
}
|
63
|
+
EOJS
|
64
|
+
},
|
65
|
+
"all_completed" => {
|
66
|
+
"map" => <<-EOJS
|
67
|
+
function(doc) {
|
68
|
+
if (doc.chef_type == "sandbox" && doc.is_completed) {
|
69
|
+
emit(doc.guid, doc.guid);
|
70
|
+
}
|
71
|
+
}
|
72
|
+
EOJS
|
73
|
+
},
|
74
|
+
}
|
75
|
+
}
|
76
|
+
|
77
|
+
# Creates a new Chef::Sandbox object.
|
78
|
+
#
|
79
|
+
# === Returns
|
80
|
+
# object<Chef::Sandbox>:: Duh. :)
|
81
|
+
def initialize(guid=nil, couchdb=nil)
|
82
|
+
@guid = guid || UUIDTools::UUID.random_create.to_s.gsub(/\-/,'').downcase
|
83
|
+
@is_completed = false
|
84
|
+
@create_time = Time.now.iso8601
|
85
|
+
@checksums = Array.new
|
86
|
+
end
|
87
|
+
|
88
|
+
def include?(checksum)
|
89
|
+
@checksums.include?(checksum)
|
90
|
+
end
|
91
|
+
|
92
|
+
alias :member? :include?
|
93
|
+
|
94
|
+
def to_json(*a)
|
95
|
+
result = {
|
96
|
+
:guid => guid,
|
97
|
+
:name => name, # same as guid, used for id_map
|
98
|
+
:checksums => checksums,
|
99
|
+
:create_time => create_time,
|
100
|
+
:is_completed => is_completed,
|
101
|
+
:json_class => self.class.name,
|
102
|
+
:chef_type => 'sandbox'
|
103
|
+
}
|
104
|
+
result["_rev"] = @couchdb_rev if @couchdb_rev
|
105
|
+
result.to_json(*a)
|
106
|
+
end
|
107
|
+
|
108
|
+
def self.json_create(o)
|
109
|
+
sandbox = new(o['guid'])
|
110
|
+
sandbox.checksums = o['checksums']
|
111
|
+
sandbox.create_time = o['create_time']
|
112
|
+
sandbox.is_completed = o['is_completed']
|
113
|
+
if o.has_key?('_rev')
|
114
|
+
sandbox.couchdb_rev = o["_rev"]
|
115
|
+
o.delete("_rev")
|
116
|
+
end
|
117
|
+
if o.has_key?("_id")
|
118
|
+
sandbox.couchdb_id = o["_id"]
|
119
|
+
#sandbox.index_id = sandbox.couchdb_id
|
120
|
+
o.delete("_id")
|
121
|
+
end
|
122
|
+
sandbox
|
123
|
+
end
|
124
|
+
|
125
|
+
##
|
126
|
+
# Couchdb
|
127
|
+
##
|
128
|
+
|
129
|
+
def self.create_design_document(couchdb=nil)
|
130
|
+
(couchdb || Chef::CouchDB.new).create_design_document("sandboxes", DESIGN_DOCUMENT)
|
131
|
+
end
|
132
|
+
|
133
|
+
def self.cdb_list(inflate=false, couchdb=nil)
|
134
|
+
rs = (couchdb || Chef::CouchDB.new).list("sandboxes", inflate)
|
135
|
+
lookup = (inflate ? "value" : "key")
|
136
|
+
rs["rows"].collect { |r| r[lookup] }
|
137
|
+
end
|
138
|
+
|
139
|
+
def self.cdb_load(guid, couchdb=nil)
|
140
|
+
# Probably want to look for a view here at some point
|
141
|
+
(couchdb || Chef::CouchDB.new).load("sandbox", guid)
|
142
|
+
end
|
143
|
+
|
144
|
+
def cdb_destroy
|
145
|
+
(couchdb || Chef::CouchDB.new).delete("sandbox", guid, @couchdb_rev)
|
146
|
+
end
|
147
|
+
|
148
|
+
def cdb_save(couchdb=nil)
|
149
|
+
@couchdb_rev = (couchdb || Chef::CouchDB.new).store("sandbox", guid, self)["rev"]
|
150
|
+
end
|
151
|
+
|
152
|
+
end
|
153
|
+
end
|
@@ -0,0 +1,60 @@
|
|
1
|
+
#
|
2
|
+
# Author:: Adam Jacob (<adam@opscode.com>)
|
3
|
+
# Copyright:: Copyright (c) 2008 Opscode, Inc.
|
4
|
+
# License:: Apache License, Version 2.0
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
#
|
18
|
+
|
19
|
+
require 'chef/config'
|
20
|
+
require 'uri'
|
21
|
+
|
22
|
+
class Chef
|
23
|
+
class Search
|
24
|
+
class Query
|
25
|
+
|
26
|
+
attr_accessor :rest
|
27
|
+
|
28
|
+
def initialize(url=nil)
|
29
|
+
@rest = Chef::REST.new(url ||Chef::Config[:search_url])
|
30
|
+
end
|
31
|
+
|
32
|
+
# Search Solr for objects of a given type, for a given query. If you give
|
33
|
+
# it a block, it will handle the paging for you dynamically.
|
34
|
+
def search(type, query="*:*", sort='X_CHEF_id_CHEF_X asc', start=0, rows=1000, &block)
|
35
|
+
raise ArgumentError, "Type must be a string or a symbol!" unless (type.kind_of?(String) || type.kind_of?(Symbol))
|
36
|
+
|
37
|
+
response = @rest.get_rest("search/#{type}?q=#{escape(query)}&sort=#{escape(sort)}&start=#{escape(start)}&rows=#{escape(rows)}")
|
38
|
+
if block
|
39
|
+
response["rows"].each { |o| block.call(o) unless o.nil?}
|
40
|
+
unless (response["start"] + response["rows"].length) >= response["total"]
|
41
|
+
nstart = response["start"] + rows
|
42
|
+
search(type, query, sort, nstart, rows, &block)
|
43
|
+
end
|
44
|
+
true
|
45
|
+
else
|
46
|
+
[ response["rows"], response["start"], response["total"] ]
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
def list_indexes
|
51
|
+
response = @rest.get_rest("search")
|
52
|
+
end
|
53
|
+
|
54
|
+
private
|
55
|
+
def escape(s)
|
56
|
+
s && URI.escape(s.to_s)
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
@@ -0,0 +1,568 @@
|
|
1
|
+
#--
|
2
|
+
# Author:: Daniel DeLeo (<dan@kallistec.com>)
|
3
|
+
# Copyright:: Copyright (c) 2009 Daniel DeLeo
|
4
|
+
# License:: Apache License, Version 2.0
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
#
|
18
|
+
|
19
|
+
require 'tempfile'
|
20
|
+
require 'chef/recipe'
|
21
|
+
require 'fileutils'
|
22
|
+
require 'chef/version'
|
23
|
+
require 'chef/shef/shef_session'
|
24
|
+
require 'chef/shef/model_wrapper'
|
25
|
+
require 'chef/shef/shef_rest'
|
26
|
+
|
27
|
+
module Shef
|
28
|
+
module Extensions
|
29
|
+
|
30
|
+
Help = Struct.new(:cmd, :desc, :explanation)
|
31
|
+
|
32
|
+
# Extensions to be included in every 'main' object in shef. These objects
|
33
|
+
# are extended with this module.
|
34
|
+
module ObjectCoreExtensions
|
35
|
+
|
36
|
+
def ensure_session_select_defined
|
37
|
+
# irb breaks if you prematurely define IRB::JobMangager
|
38
|
+
# so these methods need to be defined at the latest possible time.
|
39
|
+
unless jobs.respond_to?(:select_session_by_context)
|
40
|
+
def jobs.select_session_by_context(&block)
|
41
|
+
@jobs.select { |job| block.call(job[1].context.main)}
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
unless jobs.respond_to?(:session_select)
|
46
|
+
def jobs.select_shef_session(target_context)
|
47
|
+
session = if target_context.kind_of?(Class)
|
48
|
+
select_session_by_context { |main| main.kind_of?(target_context) }
|
49
|
+
else
|
50
|
+
select_session_by_context { |main| main.equal?(target_context) }
|
51
|
+
end
|
52
|
+
Array(session.first)[1]
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
def find_or_create_session_for(context_obj)
|
58
|
+
ensure_session_select_defined
|
59
|
+
if subsession = jobs.select_shef_session(context_obj)
|
60
|
+
jobs.switch(subsession)
|
61
|
+
else
|
62
|
+
irb(context_obj)
|
63
|
+
end
|
64
|
+
end
|
65
|
+
|
66
|
+
def help_banner
|
67
|
+
banner = []
|
68
|
+
banner << ""
|
69
|
+
banner << "Shef Help"
|
70
|
+
banner << "".ljust(80, "=")
|
71
|
+
banner << "| " + "Command".ljust(25) + "| " + "Description"
|
72
|
+
banner << "".ljust(80, "=")
|
73
|
+
|
74
|
+
self.all_help_descriptions.each do |help_text|
|
75
|
+
banner << "| " + help_text.cmd.ljust(25) + "| " + help_text.desc
|
76
|
+
end
|
77
|
+
banner << "".ljust(80, "=")
|
78
|
+
banner << "\n"
|
79
|
+
banner << "Use help(:command) to get detailed help with individual commands"
|
80
|
+
banner << "\n"
|
81
|
+
banner.join("\n")
|
82
|
+
end
|
83
|
+
|
84
|
+
def explain_command(method_name)
|
85
|
+
help = self.all_help_descriptions.find { |h| h.cmd.to_s == method_name.to_s }
|
86
|
+
if help
|
87
|
+
puts ""
|
88
|
+
puts "Command: #{method_name}"
|
89
|
+
puts "".ljust(80, "=")
|
90
|
+
puts help.explanation || help.desc
|
91
|
+
puts "".ljust(80, "=")
|
92
|
+
puts ""
|
93
|
+
else
|
94
|
+
puts ""
|
95
|
+
puts "command #{method_name} not found or no help available"
|
96
|
+
puts ""
|
97
|
+
end
|
98
|
+
end
|
99
|
+
|
100
|
+
# helpfully returns +:on+ so we can have sugary syntax like `tracing on'
|
101
|
+
def on
|
102
|
+
:on
|
103
|
+
end
|
104
|
+
|
105
|
+
# returns +:off+ so you can just do `tracing off'
|
106
|
+
def off
|
107
|
+
:off
|
108
|
+
end
|
109
|
+
|
110
|
+
def help_descriptions
|
111
|
+
@help_descriptions ||= []
|
112
|
+
end
|
113
|
+
|
114
|
+
def all_help_descriptions
|
115
|
+
help_descriptions
|
116
|
+
end
|
117
|
+
|
118
|
+
def desc(help_text)
|
119
|
+
@desc = help_text
|
120
|
+
end
|
121
|
+
|
122
|
+
def explain(explain_text)
|
123
|
+
@explain = explain_text
|
124
|
+
end
|
125
|
+
|
126
|
+
def subcommands(subcommand_help={})
|
127
|
+
@subcommand_help = subcommand_help
|
128
|
+
end
|
129
|
+
|
130
|
+
def singleton_method_added(mname)
|
131
|
+
if @desc
|
132
|
+
help_descriptions << Help.new(mname.to_s, @desc.to_s, @explain)
|
133
|
+
@desc, @explain = nil, nil
|
134
|
+
end
|
135
|
+
if @subcommand_help
|
136
|
+
@subcommand_help.each do |subcommand, text|
|
137
|
+
help_descriptions << Help.new("#{mname}.#{subcommand}", text.to_s, nil)
|
138
|
+
end
|
139
|
+
end
|
140
|
+
@subcommand_help = {}
|
141
|
+
end
|
142
|
+
|
143
|
+
end
|
144
|
+
|
145
|
+
module String
|
146
|
+
def on_off_to_bool
|
147
|
+
case self
|
148
|
+
when "on"
|
149
|
+
true
|
150
|
+
when "off"
|
151
|
+
false
|
152
|
+
else
|
153
|
+
self
|
154
|
+
end
|
155
|
+
end
|
156
|
+
end
|
157
|
+
|
158
|
+
module Symbol
|
159
|
+
def on_off_to_bool
|
160
|
+
self.to_s.on_off_to_bool
|
161
|
+
end
|
162
|
+
end
|
163
|
+
|
164
|
+
module TrueClass
|
165
|
+
def to_on_off_str
|
166
|
+
"on"
|
167
|
+
end
|
168
|
+
|
169
|
+
def on_off_to_bool
|
170
|
+
self
|
171
|
+
end
|
172
|
+
end
|
173
|
+
|
174
|
+
module FalseClass
|
175
|
+
def to_on_off_str
|
176
|
+
"off"
|
177
|
+
end
|
178
|
+
|
179
|
+
def on_off_to_bool
|
180
|
+
self
|
181
|
+
end
|
182
|
+
end
|
183
|
+
|
184
|
+
# Methods that have associated help text need to be dynamically added
|
185
|
+
# to the main irb objects, so we define them in a proc and later
|
186
|
+
# instance_eval the proc in the object.
|
187
|
+
ObjectUIExtensions = Proc.new do
|
188
|
+
extend Shef::Extensions::ObjectCoreExtensions
|
189
|
+
|
190
|
+
desc "prints this help message"
|
191
|
+
explain(<<-E)
|
192
|
+
## SUMMARY ##
|
193
|
+
When called with no argument, +help+ prints a table of all shef commands. When
|
194
|
+
called with an argument COMMAND, +help+ prints a detailed explanation of the
|
195
|
+
command if available, or the description if no explanation is available.
|
196
|
+
E
|
197
|
+
def help(commmand=nil)
|
198
|
+
if commmand
|
199
|
+
explain_command(commmand)
|
200
|
+
else
|
201
|
+
puts help_banner
|
202
|
+
end
|
203
|
+
:ucanhaz_halp
|
204
|
+
end
|
205
|
+
alias :halp :help
|
206
|
+
|
207
|
+
desc "prints information about chef"
|
208
|
+
def version
|
209
|
+
puts "This is shef, the Chef shell.\n" +
|
210
|
+
" Chef Version: #{::Chef::VERSION}\n" +
|
211
|
+
" http://www.opscode.com/chef\n" +
|
212
|
+
" http://wiki.opscode.com/display/chef/Home"
|
213
|
+
:ucanhaz_automation
|
214
|
+
end
|
215
|
+
alias :shef :version
|
216
|
+
|
217
|
+
desc "switch to recipe mode"
|
218
|
+
def recipe
|
219
|
+
find_or_create_session_for Shef.session.recipe
|
220
|
+
:recipe
|
221
|
+
end
|
222
|
+
|
223
|
+
desc "switch to attributes mode"
|
224
|
+
def attributes
|
225
|
+
find_or_create_session_for Shef.session.node
|
226
|
+
:attributes
|
227
|
+
end
|
228
|
+
|
229
|
+
desc "run chef using the current recipe"
|
230
|
+
def run_chef
|
231
|
+
Chef::Log.level = :debug
|
232
|
+
session = Shef.session
|
233
|
+
runrun = Chef::Runner.new(session.run_context).converge
|
234
|
+
Chef::Log.level = :info
|
235
|
+
runrun
|
236
|
+
end
|
237
|
+
|
238
|
+
desc "returns an object to control a paused chef run"
|
239
|
+
subcommands :resume => "resume the chef run",
|
240
|
+
:step => "run only the next resource",
|
241
|
+
:skip_back => "move back in the run list",
|
242
|
+
:skip_forward => "move forward in the run list"
|
243
|
+
def chef_run
|
244
|
+
Shef.session.resource_collection.iterator
|
245
|
+
end
|
246
|
+
|
247
|
+
desc "resets the current recipe"
|
248
|
+
def reset
|
249
|
+
Shef.session.reset!
|
250
|
+
end
|
251
|
+
|
252
|
+
desc "assume the identity of another node."
|
253
|
+
def become_node(node_name)
|
254
|
+
Shef::DoppelGangerSession.instance.assume_identity(node_name)
|
255
|
+
:doppelganger
|
256
|
+
end
|
257
|
+
alias :doppelganger :become_node
|
258
|
+
|
259
|
+
desc "turns printout of return values on or off"
|
260
|
+
def echo(on_or_off)
|
261
|
+
conf.echo = on_or_off.on_off_to_bool
|
262
|
+
end
|
263
|
+
|
264
|
+
desc "says if echo is on or off"
|
265
|
+
def echo?
|
266
|
+
puts "echo is #{conf.echo.to_on_off_str}"
|
267
|
+
end
|
268
|
+
|
269
|
+
desc "turns on or off tracing of execution. *verbose*"
|
270
|
+
def tracing(on_or_off)
|
271
|
+
conf.use_tracer = on_or_off.on_off_to_bool
|
272
|
+
tracing?
|
273
|
+
end
|
274
|
+
alias :trace :tracing
|
275
|
+
|
276
|
+
desc "says if tracing is on or off"
|
277
|
+
def tracing?
|
278
|
+
puts "tracing is #{conf.use_tracer.to_on_off_str}"
|
279
|
+
end
|
280
|
+
alias :trace? :tracing?
|
281
|
+
|
282
|
+
desc "simple ls style command"
|
283
|
+
def ls(directory)
|
284
|
+
Dir.entries(directory)
|
285
|
+
end
|
286
|
+
end
|
287
|
+
|
288
|
+
MainContextExtensions = Proc.new do
|
289
|
+
desc "returns the current node (i.e., this host)"
|
290
|
+
def node
|
291
|
+
Shef.session.node
|
292
|
+
end
|
293
|
+
|
294
|
+
desc "pretty print the node's attributes"
|
295
|
+
def ohai(key=nil)
|
296
|
+
pp(key ? node.attribute[key] : node.attribute)
|
297
|
+
end
|
298
|
+
end
|
299
|
+
|
300
|
+
RESTApiExtensions = Proc.new do
|
301
|
+
desc "edit an object in your EDITOR"
|
302
|
+
explain(<<-E)
|
303
|
+
## SUMMARY ##
|
304
|
+
+edit(object)+ allows you to edit any object that can be converted to JSON.
|
305
|
+
When finished editing, this method will return the edited object:
|
306
|
+
|
307
|
+
new_node = edit(existing_node)
|
308
|
+
|
309
|
+
## EDITOR SELECTION ##
|
310
|
+
Shef looks for an editor using the following logic
|
311
|
+
1. Looks for an EDITOR set by Shef.editor = "EDITOR"
|
312
|
+
2. Looks for an EDITOR configured in your shef config file
|
313
|
+
3. Uses the value of the EDITOR environment variable
|
314
|
+
E
|
315
|
+
def edit(object)
|
316
|
+
unless Shef.editor
|
317
|
+
puts "Please set your editor with Shef.editor = \"vim|emacs|mate|ed\""
|
318
|
+
return :failburger
|
319
|
+
end
|
320
|
+
|
321
|
+
filename = "shef-edit-#{object.class.name}-"
|
322
|
+
if object.respond_to?(:name)
|
323
|
+
filename += object.name
|
324
|
+
elsif object.respond_to?(:id)
|
325
|
+
filename += object.id
|
326
|
+
end
|
327
|
+
|
328
|
+
edited_data = Tempfile.open([filename, ".js"]) do |tempfile|
|
329
|
+
tempfile.sync = true
|
330
|
+
tempfile.puts object.to_json
|
331
|
+
system("#{Shef.editor.to_s} #{tempfile.path}")
|
332
|
+
tempfile.rewind
|
333
|
+
tempfile.read
|
334
|
+
end
|
335
|
+
|
336
|
+
JSON.parse(edited_data)
|
337
|
+
end
|
338
|
+
|
339
|
+
desc "Find and edit API clients"
|
340
|
+
explain(<<-E)
|
341
|
+
## SUMMARY ##
|
342
|
+
+clients+ allows you to query you chef server for information about your api
|
343
|
+
clients.
|
344
|
+
|
345
|
+
## LIST ALL CLIENTS ##
|
346
|
+
To see all clients on the system, use
|
347
|
+
|
348
|
+
clients.all #=> [<Chef::ApiClient...>, ...]
|
349
|
+
|
350
|
+
If the output from all is too verbose, or you're only interested in a specific
|
351
|
+
value from each of the objects, you can give a code block to +all+:
|
352
|
+
|
353
|
+
clients.all { |client| client.name } #=> [CLIENT1_NAME, CLIENT2_NAME, ...]
|
354
|
+
|
355
|
+
## SHOW ONE CLIENT ##
|
356
|
+
To see a specific client, use
|
357
|
+
|
358
|
+
clients.show(CLIENT_NAME)
|
359
|
+
|
360
|
+
## SEARCH FOR CLIENTS ##
|
361
|
+
You can also search for clients using +find+ or +search+. You can use the
|
362
|
+
familiar string search syntax:
|
363
|
+
|
364
|
+
clients.search("KEY:VALUE")
|
365
|
+
|
366
|
+
Just as the +all+ subcommand, the +search+ subcommand can use a code block to
|
367
|
+
filter or transform the information returned from the search:
|
368
|
+
|
369
|
+
clients.search("KEY:VALUE") { |c| c.name }
|
370
|
+
|
371
|
+
You can also use a Hash based syntax, multiple search conditions will be
|
372
|
+
joined with AND.
|
373
|
+
|
374
|
+
clients.find :KEY => :VALUE, :KEY2 => :VALUE2, ...
|
375
|
+
|
376
|
+
## BULK-EDIT CLIENTS ##
|
377
|
+
**BE CAREFUL, THIS IS DESTRUCTIVE**
|
378
|
+
You can bulk edit API Clients using the +transform+ subcommand, which requires
|
379
|
+
a code block. Each client will be saved after the code block is run. If the
|
380
|
+
code block returns +nil+ or +false+, that client will be skipped:
|
381
|
+
|
382
|
+
clients.transform("*:*") do |client|
|
383
|
+
if client.name =~ /borat/i
|
384
|
+
client.admin(false)
|
385
|
+
true
|
386
|
+
else
|
387
|
+
nil
|
388
|
+
end
|
389
|
+
end
|
390
|
+
|
391
|
+
This will strip the admin privileges from any client named after borat.
|
392
|
+
E
|
393
|
+
subcommands :all => "list all api clients",
|
394
|
+
:show => "load an api client by name",
|
395
|
+
:search => "search for API clients",
|
396
|
+
:transform => "edit all api clients via a code block and save them"
|
397
|
+
def clients
|
398
|
+
@clients ||= Shef::ModelWrapper.new(Chef::ApiClient, :client)
|
399
|
+
end
|
400
|
+
|
401
|
+
desc "Find and edit cookbooks"
|
402
|
+
subcommands :all => "list all cookbooks",
|
403
|
+
:show => "load a cookbook by name",
|
404
|
+
:transform => "edit all cookbooks via a code block and save them"
|
405
|
+
def cookbooks
|
406
|
+
@cookbooks ||= Shef::ModelWrapper.new(Chef::CookbookVersion)
|
407
|
+
end
|
408
|
+
|
409
|
+
desc "Find and edit nodes via the API"
|
410
|
+
explain(<<-E)
|
411
|
+
## SUMMARY ##
|
412
|
+
+nodes+ Allows you to query your chef server for information about your nodes.
|
413
|
+
|
414
|
+
## LIST ALL NODES ##
|
415
|
+
You can list all nodes using +all+ or +list+
|
416
|
+
|
417
|
+
nodes.all #=> [<Chef::Node...>, <Chef::Node...>, ...]
|
418
|
+
|
419
|
+
To limit the information returned for each node, pass a code block to the +all+
|
420
|
+
subcommand:
|
421
|
+
|
422
|
+
nodes.all { |node| node.name } #=> [NODE1_NAME, NODE2_NAME, ...]
|
423
|
+
|
424
|
+
## SHOW ONE NODE ##
|
425
|
+
You can show the data for a single node using the +show+ subcommand:
|
426
|
+
|
427
|
+
nodes.show("NODE_NAME") => <Chef::Node @name="NODE_NAME" ...>
|
428
|
+
|
429
|
+
## SEARCH FOR NODES ##
|
430
|
+
You can search for nodes using the +search+ or +find+ subcommands:
|
431
|
+
|
432
|
+
nodes.find(:name => "app*") #=> [<Chef::Node @name="app1.example.com" ...>, ...]
|
433
|
+
|
434
|
+
Similarly to +all+, you can pass a code block to limit or transform the
|
435
|
+
information returned:
|
436
|
+
|
437
|
+
nodes.find(:name => "app#") { |node| node.ec2 }
|
438
|
+
|
439
|
+
## BULK EDIT NODES ##
|
440
|
+
**BE CAREFUL, THIS OPERATION IS DESTRUCTIVE**
|
441
|
+
|
442
|
+
Bulk edit nodes by passing a code block to the +transform+ or +bulk_edit+
|
443
|
+
subcommand. The block will be applied to each matching node, and then the node
|
444
|
+
will be saved. If the block returns +nil+ or +false+, that node will be
|
445
|
+
skipped.
|
446
|
+
|
447
|
+
nodes.transform do |node|
|
448
|
+
if node.fqdn =~ /.*\\.preprod\\.example\\.com/
|
449
|
+
node.set[:environment] = "preprod"
|
450
|
+
end
|
451
|
+
end
|
452
|
+
|
453
|
+
This will assign the attribute to every node with a FQDN matching the regex.
|
454
|
+
E
|
455
|
+
subcommands :all => "list all nodes",
|
456
|
+
:show => "load a node by name",
|
457
|
+
:search => "search for nodes",
|
458
|
+
:transform => "edit all nodes via a code block and save them"
|
459
|
+
def nodes
|
460
|
+
@nodes ||= Shef::ModelWrapper.new(Chef::Node)
|
461
|
+
end
|
462
|
+
|
463
|
+
desc "Find and edit roles via the API"
|
464
|
+
explain(<<-E)
|
465
|
+
## SUMMARY ##
|
466
|
+
+roles+ allows you to query and edit roles on your Chef server.
|
467
|
+
|
468
|
+
## SUBCOMMANDS ##
|
469
|
+
* all (list)
|
470
|
+
* show (load)
|
471
|
+
* search (find)
|
472
|
+
* transform (bulk_edit)
|
473
|
+
|
474
|
+
## SEE ALSO ##
|
475
|
+
See the help for +nodes+ for more information about the subcommands.
|
476
|
+
E
|
477
|
+
subcommands :all => "list all roles",
|
478
|
+
:show => "load a role by name",
|
479
|
+
:search => "search for roles",
|
480
|
+
:transform => "edit all roles via a code block and save them"
|
481
|
+
def roles
|
482
|
+
@roles ||= Shef::ModelWrapper.new(Chef::Role)
|
483
|
+
end
|
484
|
+
|
485
|
+
desc "Find and edit +databag_name+ via the api"
|
486
|
+
explain(<<-E)
|
487
|
+
## SUMMARY ##
|
488
|
+
+databags(DATABAG_NAME)+ allows you to query and edit data bag items on your
|
489
|
+
Chef server. Unlike other commands for working with data on the server,
|
490
|
+
+databags+ requires the databag name as an argument, for example:
|
491
|
+
databags(:users).all
|
492
|
+
|
493
|
+
## SUBCOMMANDS ##
|
494
|
+
* all (list)
|
495
|
+
* show (load)
|
496
|
+
* search (find)
|
497
|
+
* transform (bulk_edit)
|
498
|
+
|
499
|
+
## SEE ALSO ##
|
500
|
+
See the help for +nodes+ for more information about the subcommands.
|
501
|
+
|
502
|
+
E
|
503
|
+
subcommands :all => "list all items in the data bag",
|
504
|
+
:show => "load a data bag item by id",
|
505
|
+
:search => "search for items in the data bag",
|
506
|
+
:transform => "edit all items via a code block and save them"
|
507
|
+
def databags(databag_name)
|
508
|
+
@named_databags_wrappers ||= {}
|
509
|
+
@named_databags_wrappers[databag_name] ||= Shef::NamedDataBagWrapper.new(databag_name)
|
510
|
+
end
|
511
|
+
|
512
|
+
desc "A REST Client configured to authenticate with the API"
|
513
|
+
def api
|
514
|
+
@rest = Shef::ShefREST.new(Chef::Config[:chef_server_url])
|
515
|
+
end
|
516
|
+
|
517
|
+
end
|
518
|
+
|
519
|
+
RecipeUIExtensions = Proc.new do
|
520
|
+
alias :original_resources :resources
|
521
|
+
|
522
|
+
desc "list all the resources on the current recipe"
|
523
|
+
def resources(*args)
|
524
|
+
if args.empty?
|
525
|
+
pp run_context.resource_collection.instance_variable_get(:@resources_by_name).keys
|
526
|
+
else
|
527
|
+
pp resources = original_resources(*args)
|
528
|
+
resources
|
529
|
+
end
|
530
|
+
end
|
531
|
+
end
|
532
|
+
|
533
|
+
def self.extend_context_object(obj)
|
534
|
+
obj.instance_eval(&ObjectUIExtensions)
|
535
|
+
obj.instance_eval(&MainContextExtensions)
|
536
|
+
obj.instance_eval(&RESTApiExtensions)
|
537
|
+
obj.extend(FileUtils)
|
538
|
+
obj.extend(Chef::Mixin::Language)
|
539
|
+
end
|
540
|
+
|
541
|
+
def self.extend_context_node(node_obj)
|
542
|
+
node_obj.instance_eval(&ObjectUIExtensions)
|
543
|
+
end
|
544
|
+
|
545
|
+
def self.extend_context_recipe(recipe_obj)
|
546
|
+
recipe_obj.instance_eval(&ObjectUIExtensions)
|
547
|
+
recipe_obj.instance_eval(&RecipeUIExtensions)
|
548
|
+
end
|
549
|
+
|
550
|
+
end
|
551
|
+
end
|
552
|
+
|
553
|
+
class String
|
554
|
+
include Shef::Extensions::String
|
555
|
+
end
|
556
|
+
|
557
|
+
class Symbol
|
558
|
+
include Shef::Extensions::Symbol
|
559
|
+
end
|
560
|
+
|
561
|
+
class TrueClass
|
562
|
+
include Shef::Extensions::TrueClass
|
563
|
+
end
|
564
|
+
|
565
|
+
class FalseClass
|
566
|
+
include Shef::Extensions::FalseClass
|
567
|
+
end
|
568
|
+
|