В Configurabilty имеется объект конфигурации (раскрытие: я автор), который вы можете использовать как сам по себе, так и в составе набора настроек.Из документации :
Конфигурируемость также включает в себя Configurability::Config
, довольно простой класс объектов конфигурации, который можно использовать для загрузки файла конфигурации YAML, а затем представить как Hash-like, так иСтруктурный интерфейс для чтения разделов конфигурации и значений;он предназначен для использования в тандеме с конфигурацией, но также полезен сам по себе.
Вот краткий пример, демонстрирующий некоторые из его функций.Предположим, у вас есть файл конфигурации, который выглядит следующим образом:
---
database:
development:
adapter: sqlite3
database: db/dev.db
pool: 5
timeout: 5000
testing:
adapter: sqlite3
database: db/testing.db
pool: 2
timeout: 5000
production:
adapter: postgres
database: fixedassets
pool: 25
timeout: 50
ldap:
uri: ldap://ldap.acme.com/dc=acme,dc=com
bind_dn: cn=web,dc=acme,dc=com
bind_pass: Mut@ge.Mix@ge
branding:
header: "#333"
title: "#dedede"
anchor: "#9fc8d4"
Вы можете загрузить эту конфигурацию следующим образом:
require 'configurability/config'
config = Configurability::Config.load( 'examples/config.yml' )
# => #<Configurability::Config:0x1018a7c7016 loaded from
examples/config.yml; 3 sections: database, ldap, branding>
И затем получить к нему доступ, используя методы, подобные структуре:
config.database
# => #<Configurability::Config::Struct:101806fb816
{:development=>{:adapter=>"sqlite3", :database=>"db/dev.db", :pool=>5,
:timeout=>5000}, :testing=>{:adapter=>"sqlite3",
:database=>"db/testing.db", :pool=>2, :timeout=>5000},
:production=>{:adapter=>"postgres", :database=>"fixedassets",
:pool=>25, :timeout=>50}}>
config.database.development.adapter
# => "sqlite3"
config.ldap.uri
# => "ldap://ldap.acme.com/dc=acme,dc=com"
config.branding.title
# => "#dedede"
или используя Hash-подобный интерфейс, используя либо Symbol
s, String
s, либо сочетание обоих:
config[:branding][:title]
# => "#dedede"
config['branding']['header']
# => "#333"
config['branding'][:anchor]
# => "#9fc8d4"
Вы можете установить его через интерфейс Configurability:
config.install
Проверьте, изменился ли файл, из которого он был загружен, с момента его загрузки:
config.changed?
# => false
# Simulate changing the file by manually changing its mtime
File.utime( Time.now, Time.now, config.path )
config.changed?
# => true
Если он изменился (или даже не изменился), вы можетеперезагрузите его, что автоматически переустановит его через интерфейс Configurability:
config.reload
Вы можете вносить изменения через те же интерфейсы в стиле Struct или Hash и записывать измененную конфигурацию обратно в тот же файл:
config.database.testing.adapter = 'mysql'
config[:database]['testing'].database = 't_fixedassets'
затем выведите его в строку YAML:
config.dump
# => "--- \ndatabase: \n development: \n adapter: sqlite3\n
database: db/dev.db\n pool: 5\n timeout: 5000\n testing: \n
adapter: mysql\n database: t_fixedassets\n pool: 2\n timeout:
5000\n production: \n adapter: postgres\n database:
fixedassets\n pool: 25\n timeout: 50\nldap: \n uri:
ldap://ldap.acme.com/dc=acme,dc=com\n bind_dn:
cn=web,dc=acme,dc=com\n bind_pass: Mut@ge.Mix@ge\nbranding: \n
header: \"#333\"\n title: \"#dedede\"\n anchor: \"#9fc8d4\"\n"
или запишите обратно в файл, из которого он был загружен:
config.write