fun_with_configurations : Your objects must be configurized!¶ ↑
Configuration and settings are the beating heart and dark, twisted soul of your operation.
Let’s look at some example code:
class Computer; end; Computer.install_fwc_config do servers do hopeful_host do ip "192.168.0.25" services :mysql, :memcached, :email, :backup uptime `uptime`.strip config_script "/var/configurations/hopeful.conf" end squishy_host do ip "192.168.0.27" services :postresql, :couchdb uptime `uptime`.strip config_script "/var/configurations/squishy.conf" end end workstations do betty do ip "192.168.0.14" os "Ubuntu Linux 13.04" end veronica do ip "192.168.0.15" os "Solaris 10" end end end Computers.config.servers.hopeful_host.ip # "192.168.0.25" Computers.config.workstations.betty.ip # "192.168.0.14" Computers.config.try.servers.grumpy_host.ip.success? # false (doesn't have that configuration setting)
You can also load from a hash:
@obj.install_fwc_config_from_hash({ servers: { hopeful_host: { ip: "192.168.0.25", services :mysql, :memcached, :email, :backup # stores args as an array ... (and so on) } } }) @obj.config.servers.hopeful_host.services # [:mysql, :memcached, :email, :backup]
Or from a yaml string:
@obj.install_fwc_config_from_file( "~/data/configs/circumstantial.yml" ) # looks for .yml or .yaml as the file extension
The file should represent hashes of hashes. Anything not a hash will be treated as a leaf setting (arrays, etc.).
Last and best, you can load a pure Ruby configuration:
@obj.install_fwc_config_from_file( "~/data/configs/rubicon.rb" )
Contents of rubicon.rb would be similar to what appears in the install_fwc_config block:
server do thor do ip "212.36.64.10" role "mysql" end loki do ip "212.36.64.11" role "web" end odin do ip "212.36.64.12" role "bitcoin_mining" end fenrir do ip "212.36.64.13" role "igniting_ragnarok" end end
Other features¶ ↑
There are a couple of affordances for assigning variables to an object from a config. The first is fwc_assign!(), which takes an object and assigns its instance_vars. More code!
require "fun_with_configurations" class Person attr_accessor :ssn, :birthdate, :password end p = Person.new p.install_fwc_config do age 51 data do personal do ssn "555-555-5555" birthdate "2001-03-01" password "mice" end end end p.config.data.personal.fwc_assign! p.ssn # => "555-555-5555" p.birthdate # => "2001-03-01" (and so on)
By default, fwc_assign!() assigns the instance variables of the config’s object (the object you call object.config on). But you can also pass fwc_assign a different object to config instead.
class Computer; end Computer.install_fwc_config_from_file( file ) betty = Computer.config.betty.fwc_assign!( Computer.new ) veronica = Computer.config.veronica.fwc_assign!( Computer.new ) odin = Computer.config.odin.fwc_assign!( Computer.new ) computers = {} # Alternately Computer.config.fwc do |c| # You'll meet .fwc() soon c.each do |k, config| computers[k] = config.fwc_assign!( Computer.new ) end end odin.ip # "192.168.0.15"
Another convenience method lets
MyRails.config.constant_contact.fwc do |config| @key = config.oauth.key @secret = config.oauth.secret @redir = config.oauth.redirect_url @user = config.user @password = config.password end
Basically, this is meant to spare you from typing the longhand form:
@key = MyRails.config.constant_contact.oauth.key @secret = MyRails.config.constant_contact.oauth.secret @redir = MyRails.config.constant_contact.oauth.redirect_url @user = MyRails.config.constant_contact.user @password = MyRails.config.constant_contact.password
FunWith::Patterns::Loader integration¶ ↑
To use configurations with the Loader pattern:
require 'fun_with_configurations' require 'fun_with_patterns' class Computer attr_accessor :label # Look up individual configurations via Computer[:bob_system] loader_pattern_configure( :bracketwise_lookup, :warn_on_key_change, # Warn if an existing lookup key is overwritten { :key => :label, # Key is found by calling method label() :style => FunWith::Configurations::LoadingStyle } ) # Interprets the file as a FWC::Config end Computer.loader_pattern_load_from_dir( "~/.config/computers" ) # loads all the configurations in the directory puts Computer[:bob_system].memory # ==> "4GB"
Internally, the LoadingStyle simply offloads the loading work to Config.from_file(), so any valid configuration format will do (.rb, .yaml).
Contributing to fun_with_configurations¶ ↑
- Boilerplate from Jeweler. Seems reasonable.
-
Check out the latest master to make sure the feature hasn’t been implemented or the bug hasn’t been fixed yet.
-
Check out the issue tracker to make sure someone already hasn’t requested it and/or contributed it.
-
Fork the project.
-
Start a feature/bugfix branch.
-
Commit and push until you are happy with your contribution.
-
Make sure to add tests for it. This is important so I don’t break it in a future version unintentionally.
-
Please try not to mess with the Rakefile, version, or history. If you want to have your own version, or is otherwise necessary, that is fine, but please isolate to its own commit so I can cherry-pick around it.
Copyright¶ ↑
Copyright © 2013 Bryce Anderson. See LICENSE.txt for further details.