Class: Ridley::Client
- Inherits:
-
Object
- Object
- Ridley::Client
- Extended by:
- Forwardable
- Includes:
- Celluloid, Logging
- Defined in:
- lib/ridley/client.rb
Defined Under Namespace
Classes: ConnectionSupervisor, ResourcesSupervisor
Constant Summary collapse
- REQUIRED_OPTIONS =
[ :server_url, :client_name, :client_key ].freeze
Instance Attribute Summary collapse
-
#chef_version ⇒ Object
Returns the value of attribute chef_version.
-
#encrypted_data_bag_secret_path ⇒ Object
Returns the value of attribute encrypted_data_bag_secret_path.
-
#options ⇒ Object
readonly
Returns the value of attribute options.
-
#validator_client ⇒ Object
Returns the value of attribute validator_client.
-
#validator_path ⇒ Object
Returns the value of attribute validator_path.
Class Method Summary collapse
Instance Method Summary collapse
- #client ⇒ Ridley::ClientResource
- #cookbook ⇒ Ridley::CookbookResource
- #data_bag ⇒ Ridley::DataBagResource
-
#encrypted_data_bag_secret ⇒ String?
The encrypted data bag secret for this connection.
- #environment ⇒ Ridley::EnvironmentResource
-
#initialize(options = {}) ⇒ Client
constructor
A new instance of Client.
- #node ⇒ Ridley::NodeResource
-
#partial_search(index, query = nil, attributes = [], options = {}) ⇒ Array<ChefObject>, Hash
Perform a partial search on the Chef Server.
- #role ⇒ Ridley::RoleResource
- #sandbox ⇒ Ridley::SandboxResource
-
#search(index, query = nil, options = {}) ⇒ Array<ChefObject>, Hash
Perform a search the Chef Server.
-
#search_indexes ⇒ Array<Symbol, String>
Return an array of all possible search indexes for the including connection.
- #server_url ⇒ Object
- #user ⇒ Ridley::UserResource
Methods included from Logging
Constructor Details
#initialize(options = {}) ⇒ Client
Returns a new instance of Client.
120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 |
# File 'lib/ridley/client.rb', line 120 def initialize( = {}) @options = .reverse_merge( pool_size: 4 ).deep_symbolize_keys self.class.(@options) @chef_version = @options[:chef_version] @validator_client = @options[:validator_client] if @options[:validator_path] @validator_path = File.(@options[:validator_path]) end @options[:encrypted_data_bag_secret] ||= begin if @options[:encrypted_data_bag_secret_path] @encrypted_data_bag_secret_path = File.(@options[:encrypted_data_bag_secret_path]) end encrypted_data_bag_secret end unless verify_client_key(@options[:client_key]) @options[:client_key] = File.(@options[:client_key]) raise Errors::ClientKeyFileNotFoundOrInvalid, "client key is invalid or not found at: '#{@options[:client_key]}'" unless File.exist?(@options[:client_key]) && verify_client_key(::IO.read(@options[:client_key])) end @connection_registry = Celluloid::Registry.new @resources_registry = Celluloid::Registry.new @connection_supervisor = ConnectionSupervisor.new(@connection_registry, @options) @resources_supervisor = ResourcesSupervisor.new(@resources_registry, @connection_registry, @options) end |
Instance Attribute Details
#chef_version ⇒ Object
Returns the value of attribute chef_version.
92 93 94 |
# File 'lib/ridley/client.rb', line 92 def chef_version @chef_version end |
#encrypted_data_bag_secret_path ⇒ Object
Returns the value of attribute encrypted_data_bag_secret_path.
91 92 93 |
# File 'lib/ridley/client.rb', line 91 def encrypted_data_bag_secret_path @encrypted_data_bag_secret_path end |
#options ⇒ Object (readonly)
Returns the value of attribute options.
87 88 89 |
# File 'lib/ridley/client.rb', line 87 def @options end |
#validator_client ⇒ Object
Returns the value of attribute validator_client.
89 90 91 |
# File 'lib/ridley/client.rb', line 89 def validator_client @validator_client end |
#validator_path ⇒ Object
Returns the value of attribute validator_path.
90 91 92 |
# File 'lib/ridley/client.rb', line 90 def validator_path @validator_path end |
Class Method Details
.open(options = {}, &block) ⇒ Object
36 37 38 39 40 41 |
# File 'lib/ridley/client.rb', line 36 def open( = {}, &block) client = new() yield client ensure client.terminate if client && client.alive? end |
.validate_options(options) ⇒ Boolean
46 47 48 49 50 51 52 53 54 55 56 57 58 59 |
# File 'lib/ridley/client.rb', line 46 def () missing = (REQUIRED_OPTIONS - .keys) if missing.any? missing.collect! { |opt| "'#{opt}'" } raise ArgumentError, "Missing required option(s): #{missing.join(', ')}" end missing_values = .slice(*REQUIRED_OPTIONS).select { |key, value| !value.present? } if missing_values.any? values = missing_values.keys.collect { |opt| "'#{opt}'" } raise ArgumentError, "Missing value for required option(s): '#{values.join(', ')}'" end end |
Instance Method Details
#client ⇒ Ridley::ClientResource
153 154 155 |
# File 'lib/ridley/client.rb', line 153 def client @resources_registry[:client_resource] end |
#cookbook ⇒ Ridley::CookbookResource
158 159 160 |
# File 'lib/ridley/client.rb', line 158 def cookbook @resources_registry[:cookbook_resource] end |
#data_bag ⇒ Ridley::DataBagResource
163 164 165 |
# File 'lib/ridley/client.rb', line 163 def data_bag @resources_registry[:data_bag_resource] end |
#encrypted_data_bag_secret ⇒ String?
The encrypted data bag secret for this connection.
255 256 257 258 259 260 261 |
# File 'lib/ridley/client.rb', line 255 def encrypted_data_bag_secret return nil if encrypted_data_bag_secret_path.nil? ::IO.read(encrypted_data_bag_secret_path).chomp rescue Errno::ENOENT => e raise Errors::EncryptedDataBagSecretNotFound, "Encrypted data bag secret provided but not found at '#{encrypted_data_bag_secret_path}'" end |
#environment ⇒ Ridley::EnvironmentResource
168 169 170 |
# File 'lib/ridley/client.rb', line 168 def environment @resources_registry[:environment_resource] end |
#node ⇒ Ridley::NodeResource
173 174 175 |
# File 'lib/ridley/client.rb', line 173 def node @resources_registry[:node_resource] end |
#partial_search(index, query = nil, attributes = [], options = {}) ⇒ Array<ChefObject>, Hash
Perform a partial search on the Chef Server. Partial objects or a smaller hash will be returned resulting in a faster response for larger response sets. Specify the attributes you want returned with the attributes parameter.
246 247 248 |
# File 'lib/ridley/client.rb', line 246 def partial_search(index, query = nil, attributes = [], = {}) @resources_registry[:search_resource].partial(index, query, Array(attributes), @resources_registry, ) end |
#role ⇒ Ridley::RoleResource
178 179 180 |
# File 'lib/ridley/client.rb', line 178 def role @resources_registry[:role_resource] end |
#sandbox ⇒ Ridley::SandboxResource
183 184 185 |
# File 'lib/ridley/client.rb', line 183 def sandbox @resources_registry[:sandbox_resource] end |
#search(index, query = nil, options = {}) ⇒ Array<ChefObject>, Hash
Perform a search the Chef Server
205 206 207 |
# File 'lib/ridley/client.rb', line 205 def search(index, query = nil, = {}) @resources_registry[:search_resource].run(index, query, @resources_registry, ) end |
#search_indexes ⇒ Array<Symbol, String>
Return an array of all possible search indexes for the including connection
217 218 219 |
# File 'lib/ridley/client.rb', line 217 def search_indexes @resources_registry[:search_resource].indexes end |
#server_url ⇒ Object
263 264 265 |
# File 'lib/ridley/client.rb', line 263 def server_url self.url_prefix.to_s end |
#user ⇒ Ridley::UserResource
188 189 190 |
# File 'lib/ridley/client.rb', line 188 def user @resources_registry[:user_resource] end |