X-Git-Url: http://gitweb.michael.orlitzky.com/?p=mailshears.git;a=blobdiff_plain;f=lib%2Fcommon%2Fconfiguration.rb;h=02c30d252b796073587ee961011a02ccbebb1936;hp=b2a37d01177551cb51c56752e601c7a66f43a976;hb=5bf27259563a3dda6425dc794722273cc29b69f7;hpb=61c80543fa4fa57c89c5acc17f6842dc937206a4 diff --git a/lib/common/configuration.rb b/lib/common/configuration.rb index b2a37d0..02c30d2 100644 --- a/lib/common/configuration.rb +++ b/lib/common/configuration.rb @@ -1,17 +1,39 @@ require 'yaml' +# A configuration object that knows how to read options out of a file +# in ~/.mailshears.conf.yml. The configuration options can be +# accessed via methods even though the internal representation is a +# hash. +# +# === Examples +# +# >> cfg = Configuration.new() +# >> cfg.i_mean_business() +# => true +# class Configuration + # The default path to the user's configuration file. USERCONF_PATH = ENV['HOME'] + '/.mailshears.conf.yml' + + # The hash structure in which we store our configuration options + # internally. @dict = {} - def initialize() + + # Initialize a {Configuration} object with the config file at *path*. + # + # @param path [String] the path to the configuration file to + # load. We check for a file named ".mailshears.conf.yml" in the + # user's home directory by default. + # + def initialize(path = USERCONF_PATH) cfg = default_configuration() # Now, load the user configuration which will override the # variables defined above. begin - user_config = YAML.load(File.open(USERCONF_PATH)) + user_config = YAML.load(File.open(path)) # Write our own update() method for Ruby 1.8. user_config.each do |key, value| @@ -28,38 +50,31 @@ class Configuration end + # Replace all missing method calls with hash lookups. This lets us + # retrieve the values in our option hash by using methods named + # after the associated keys. + # + # @param sym [Symbol] the method that was called. + # + # @return [Object] the config file value associated with *sym*. + # def method_missing(sym, *args) - # Replace all missing method calls with dictionary lookups. return @dict[sym] end private; + + # A default config hash. + # + # @return [Hash] sensible default configuration values. + # def default_configuration() d = {} d['i_mean_business'] = false - - d['dbhost'] = 'localhost' - d['dbport'] = 5432 - d['dbopts'] = '' - d['dbtty'] = '' - d['dbuser'] = 'postgres' - d['dbpass'] = '' - d['dbname'] = 'postfix' - - d['plugins'] = ['dovecot_mailstore', 'roundcube_db'] - - d['mail_root'] = '/var/spool/mail/vhosts' - - d['roundcube_dbhost'] = 'localhost' - d['roundcube_dbport'] = 5432 - d['roundcube_dbopts'] = '' - d['roundcube_dbtty'] = '' - d['roundcube_dbuser'] = 'postgres' - d['roundcube_dbpass'] = '' - d['roundcube_dbname'] = 'roundcube' + d['plugins'] = ['postfixadmin'] d['agendav_dbhost'] = 'localhost' d['agendav_dbport'] = 5432 @@ -77,6 +92,24 @@ class Configuration d['davical_dbpass'] = '' d['davical_dbname'] = 'davical' + d['dovecot_mail_root'] = '/tmp/mailshears-test' + + d['postfixadmin_dbhost'] = 'localhost' + d['postfixadmin_dbport'] = 5432 + d['postfixadmin_dbopts'] = '' + d['postfixadmin_dbtty'] = '' + d['postfixadmin_dbuser'] = 'postgres' + d['postfixadmin_dbpass'] = '' + d['postfixadmin_dbname'] = 'postfixadmin' + + d['roundcube_dbhost'] = 'localhost' + d['roundcube_dbport'] = 5432 + d['roundcube_dbopts'] = '' + d['roundcube_dbtty'] = '' + d['roundcube_dbuser'] = 'postgres' + d['roundcube_dbpass'] = '' + d['roundcube_dbname'] = 'roundcube' + return d end