#
# class Configuration
# configuration class
#
module TDiary
class Configuration
attr_reader :database_url
def initialize( cgi = nil, request = nil )
@request = request
configure_attrs
configure_bot_pattern
setup_attr_accessor_to_all_ivars
load_logger
end
def save
result = ERB.new(File.read("#{File.dirname(__FILE__)}/../../views/tdiary.rconf")).result(binding)
eval( result, binding, "(TDiary::Configuration#save)", 1 )
@io_class.save_cgi_conf(self, result)
end
#
# get/set/delete plugin options
#
def []( key )
@options[key]
end
def []=( key, val )
@options2[key] = @options[key] = val
end
def delete( key )
@options.delete( key )
@options2.delete( key )
end
# backward compatibility, returns NOT mobile phone always
def mobile_agent?
false
end
# backward compatibility, returns NOT smartphone always
def smartphone?
false
end
alias iphone? smartphone?
# backward compatibility, you can use bot? or @conf.bot =~ @cgi.user_agent
def bot?
@bot =~ @request.user_agent
end
# backward compatibility, you can use TDiary::ViewHelper#base_url
def base_url
if @options['base_url'] && @options['base_url'].length > 0
@options['base_url']
elsif @request
@request.base_url
else
''
end
end
def to_native( str, charset = nil )
str = str.dup
if str.encoding == Encoding::ASCII_8BIT
str.force_encoding(charset || 'utf-8')
end
unless str.valid_encoding?
str.encode!('utf-16be', invalid: :replace, undef: :replace)
end
unless str.encoding == Encoding::UTF_8
str.encode!('utf-8', invalid: :replace, undef: :replace)
end
str
end
private
# loading tdiary.conf in @data_path.
def load_cgi_conf
def_vars1 = ''
def_vars2 = ''
[
:tdiary_version,
:html_title, :author_name, :author_mail, :index_page, :hour_offset,
:description, :icon, :banner, :x_frame_options,
:header, :footer,
:section_anchor, :comment_anchor, :date_format, :latest_limit, :show_nyear,
:theme, :css,
:show_comment, :comment_limit, :comment_limit_per_day,
:mail_on_comment, :mail_header,
:show_referer, :no_referer2, :only_volatile2, :referer_table2,
:options2,
].each do |var|
def_vars1 << "#{var} = nil\n"
def_vars2 << "@#{var} = #{var} unless #{var} == nil\n"
end
unless defined?(::TDiary::Cache) && ::TDiary::Cache.method_defined?(:store_cache)
require 'tdiary/cache/file'
end
unless @io_class
require 'tdiary/io/default'
@io_class = IO::Default
attr_reader :io_class
end
cgi_conf = @io_class.load_cgi_conf(self)
b = binding
eval( def_vars1, b )
begin
eval( cgi_conf, b, "(TDiary::Configuration#load_cgi_conf)", 1 )
rescue SyntaxError
enc = case @lang
when 'en'
'UTF-8'
else
'EUC-JP'
end
cgi_conf.force_encoding( enc )
retry
end if cgi_conf
eval( def_vars2, b )
end
# loading tdiary.conf in current directory
def configure_attrs
@options = {}
eval( File::open( 'tdiary.conf' ) {|f| f.read }, nil, "(tdiary.conf)", 1 )
# language setup
@lang = 'ja' unless @lang
begin
instance_eval( File::open( "#{TDiary::PATH}/tdiary/lang/#{@lang}.rb" ){|f| f.read }, "(tdiary/lang/#{@lang}.rb)", 1 )
rescue Errno::ENOENT
@lang = 'ja'
retry
end
@data_path += '/' if @data_path && /\/$/ !~ @data_path
@style = 'tDiary' unless @style
@index = './' unless @index
@update = 'update.rb' unless @update
@hide_comment_form = false unless defined?( @hide_comment_form )
@author_name = '' unless @author_name
@index_page = '' unless @index_page
@hour_offset = 0 unless @hour_offset
@html_title = '' unless @html_title
@x_frame_options = nil unless @x_frame_options
@header = '' unless @header
@footer = '' unless @footer
@section_anchor = '_' unless @section_anchor
@comment_anchor = '_' unless @comment_anchor
@date_format = '%Y-%m-%d' unless @date_format
@latest_limit = 10 unless @latest_limit
@show_nyear = false unless @show_nyear
@theme = 'default' if not @theme and not @css
@theme = "local/#{@theme}" unless @theme.index('/')
@css = '' unless @css
@show_comment = true unless defined?( @show_comment )
@comment_limit = 3 unless @comment_limit
@comment_limit_per_day = 100 unless @comment_limit_per_day
@show_referer = true unless defined?( @show_referer )
@referer_limit = 10 unless @referer_limit
@referer_day_only = true unless defined?( @referer_day_only )
@no_referer = [] unless @no_referer
@no_referer2 = [] unless @no_referer2
@no_referer = @no_referer2 + @no_referer
@only_volatile = [] unless @only_volatile
@only_volatile2 = [] unless @only_volatile2
@only_volatile = @only_volatile2 + @only_volatile
@referer_table = [] unless @referer_table
@referer_table2 = [] unless @referer_table2
@referer_table = @referer_table2 + @referer_table
@options = {} unless @options.class == Hash
if @options2 then
@options.update( @options2 )
else
@options2 = {}
end
# for 1.4 compatibility
@section_anchor = @paragraph_anchor unless @section_anchor
end
def setup_attr_accessor_to_all_ivars
names = instance_variables().collect {|ivar| ivar.to_s.sub(/@/, '') }
(class << self; self; end).class_eval { attr_accessor *names }
end
def configure_bot_pattern
bot = ["bot", "spider", "antenna", "crawler", "moget", "slurp"]
bot += @options['bot'] || []
@bot = Regexp::new( "(#{bot.uniq.join( '|' )})", true )
end
def load_logger
if @logger
TDiary.logger = @logger
else
require 'logger'
log_path = (@log_path || "#{@data_path}/log")
FileUtils.mkdir_p(log_path)
TDiary.logger = Logger.new(File.join(log_path, "debug.log"), 'daily')
TDiary.logger.level = Logger.const_get(@log_level || 'DEBUG')
end
end
def method_missing( *m )
(class << self; self; end).class_eval { attr_accessor m[0] } if m.length == 1
nil
end
end
# backward compatibility
Config = Configuration
end
# Local Variables:
# mode: ruby
# indent-tabs-mode: t
# tab-width: 3
# ruby-indent-level: 3
# End:
# vim: ts=3