To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.

Statistics Download as Zip
| Branch: | Tag: | Revision:

root / app / models / setting.rb @ 1566:ac2e4a54a6a6

History | View | Annotate | Download (7.68 KB)

1 441:cbce1fd3b1b7 Chris
# Redmine - project management software
2 1494:e248c7af89ec Chris
# Copyright (C) 2006-2014  Jean-Philippe Lang
3 0:513646585e45 Chris
#
4
# This program is free software; you can redistribute it and/or
5
# modify it under the terms of the GNU General Public License
6
# as published by the Free Software Foundation; either version 2
7
# of the License, or (at your option) any later version.
8 441:cbce1fd3b1b7 Chris
#
9 0:513646585e45 Chris
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13 441:cbce1fd3b1b7 Chris
#
14 0:513646585e45 Chris
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17
18
class Setting < ActiveRecord::Base
19
20
  DATE_FORMATS = [
21 1464:261b3d9a4903 Chris
        '%Y-%m-%d',
22
        '%d/%m/%Y',
23
        '%d.%m.%Y',
24
        '%d-%m-%Y',
25
        '%m/%d/%Y',
26
        '%d %b %Y',
27
        '%d %B %Y',
28
        '%b %d, %Y',
29
        '%B %d, %Y'
30 0:513646585e45 Chris
    ]
31 441:cbce1fd3b1b7 Chris
32 0:513646585e45 Chris
  TIME_FORMATS = [
33
    '%H:%M',
34
    '%I:%M %p'
35
    ]
36 441:cbce1fd3b1b7 Chris
37 0:513646585e45 Chris
  ENCODINGS = %w(US-ASCII
38
                  windows-1250
39
                  windows-1251
40
                  windows-1252
41
                  windows-1253
42
                  windows-1254
43
                  windows-1255
44
                  windows-1256
45
                  windows-1257
46
                  windows-1258
47
                  windows-31j
48
                  ISO-2022-JP
49
                  ISO-2022-KR
50
                  ISO-8859-1
51
                  ISO-8859-2
52
                  ISO-8859-3
53
                  ISO-8859-4
54
                  ISO-8859-5
55
                  ISO-8859-6
56
                  ISO-8859-7
57
                  ISO-8859-8
58
                  ISO-8859-9
59
                  ISO-8859-13
60
                  ISO-8859-15
61
                  KOI8-R
62
                  UTF-8
63
                  UTF-16
64
                  UTF-16BE
65
                  UTF-16LE
66
                  EUC-JP
67
                  Shift_JIS
68 245:051f544170fe Chris
                  CP932
69 0:513646585e45 Chris
                  GB18030
70
                  GBK
71
                  ISCII91
72
                  EUC-KR
73
                  Big5
74
                  Big5-HKSCS
75
                  TIS-620)
76 441:cbce1fd3b1b7 Chris
77 0:513646585e45 Chris
  cattr_accessor :available_settings
78 909:cbb26bc654de Chris
  @@available_settings = YAML::load(File.open("#{Rails.root}/config/settings.yml"))
79 0:513646585e45 Chris
  Redmine::Plugin.all.each do |plugin|
80
    next unless plugin.settings
81 441:cbce1fd3b1b7 Chris
    @@available_settings["plugin_#{plugin.id}"] = {'default' => plugin.settings[:default], 'serialized' => true}
82 0:513646585e45 Chris
  end
83 441:cbce1fd3b1b7 Chris
84 0:513646585e45 Chris
  validates_uniqueness_of :name
85
  validates_inclusion_of :name, :in => @@available_settings.keys
86 1517:dffacf8a6908 Chris
  validates_numericality_of :value, :only_integer => true, :if => Proc.new { |setting|
87
    (s = @@available_settings[setting.name]) && s['format'] == 'int'
88
  }
89 0:513646585e45 Chris
90
  # Hash used to cache setting values
91
  @cached_settings = {}
92
  @cached_cleared_on = Time.now
93 441:cbce1fd3b1b7 Chris
94 0:513646585e45 Chris
  def value
95
    v = read_attribute(:value)
96
    # Unserialize serialized settings
97
    v = YAML::load(v) if @@available_settings[name]['serialized'] && v.is_a?(String)
98
    v = v.to_sym if @@available_settings[name]['format'] == 'symbol' && !v.blank?
99
    v
100
  end
101 441:cbce1fd3b1b7 Chris
102 0:513646585e45 Chris
  def value=(v)
103
    v = v.to_yaml if v && @@available_settings[name] && @@available_settings[name]['serialized']
104
    write_attribute(:value, v.to_s)
105
  end
106 441:cbce1fd3b1b7 Chris
107 0:513646585e45 Chris
  # Returns the value of the setting named name
108
  def self.[](name)
109
    v = @cached_settings[name]
110
    v ? v : (@cached_settings[name] = find_or_default(name).value)
111
  end
112 441:cbce1fd3b1b7 Chris
113 0:513646585e45 Chris
  def self.[]=(name, v)
114
    setting = find_or_default(name)
115
    setting.value = (v ? v : "")
116
    @cached_settings[name] = nil
117
    setting.save
118
    setting.value
119
  end
120 441:cbce1fd3b1b7 Chris
121 0:513646585e45 Chris
  # Defines getter and setter for each setting
122
  # Then setting values can be read using: Setting.some_setting_name
123
  # or set using Setting.some_setting_name = "some value"
124
  @@available_settings.each do |name, params|
125
    src = <<-END_SRC
126
    def self.#{name}
127
      self[:#{name}]
128
    end
129

130
    def self.#{name}?
131
      self[:#{name}].to_i > 0
132
    end
133

134
    def self.#{name}=(value)
135
      self[:#{name}] = value
136
    end
137 1464:261b3d9a4903 Chris
END_SRC
138 0:513646585e45 Chris
    class_eval src, __FILE__, __LINE__
139
  end
140 441:cbce1fd3b1b7 Chris
141 1464:261b3d9a4903 Chris
  # Sets a setting value from params
142
  def self.set_from_params(name, params)
143
    params = params.dup
144
    params.delete_if {|v| v.blank? } if params.is_a?(Array)
145
146
    m = "#{name}_from_params"
147
    if respond_to? m
148
      self[name.to_sym] = send m, params
149
    else
150
      self[name.to_sym] = params
151
    end
152
  end
153
154
  # Returns a hash suitable for commit_update_keywords setting
155
  #
156
  # Example:
157
  # params = {:keywords => ['fixes', 'closes'], :status_id => ["3", "5"], :done_ratio => ["", "100"]}
158
  # Setting.commit_update_keywords_from_params(params)
159
  # # => [{'keywords => 'fixes', 'status_id' => "3"}, {'keywords => 'closes', 'status_id' => "5", 'done_ratio' => "100"}]
160
  def self.commit_update_keywords_from_params(params)
161
    s = []
162
    if params.is_a?(Hash) && params.key?(:keywords) && params.values.all? {|v| v.is_a? Array}
163
      attributes = params.except(:keywords).keys
164
      params[:keywords].each_with_index do |keywords, i|
165
        next if keywords.blank?
166
        s << attributes.inject({}) {|h, a|
167
          value = params[a][i].to_s
168
          h[a.to_s] = value if value.present?
169
          h
170
        }.merge('keywords' => keywords)
171
      end
172
    end
173
    s
174
  end
175
176 0:513646585e45 Chris
  # Helper that returns an array based on per_page_options setting
177
  def self.per_page_options_array
178
    per_page_options.split(%r{[\s,]}).collect(&:to_i).select {|n| n > 0}.sort
179
  end
180 441:cbce1fd3b1b7 Chris
181 1464:261b3d9a4903 Chris
  # Helper that returns a Hash with single update keywords as keys
182
  def self.commit_update_keywords_array
183
    a = []
184
    if commit_update_keywords.is_a?(Array)
185
      commit_update_keywords.each do |rule|
186
        next unless rule.is_a?(Hash)
187
        rule = rule.dup
188
        rule.delete_if {|k, v| v.blank?}
189
        keywords = rule['keywords'].to_s.downcase.split(",").map(&:strip).reject(&:blank?)
190
        next if keywords.empty?
191
        a << rule.merge('keywords' => keywords)
192
      end
193
    end
194
    a
195
  end
196
197
  def self.commit_fix_keywords
198
    ActiveSupport::Deprecation.warn "Setting.commit_fix_keywords is deprecated and will be removed in Redmine 3"
199
    if commit_update_keywords.is_a?(Array)
200
      commit_update_keywords.first && commit_update_keywords.first['keywords']
201
    end
202
  end
203
204
  def self.commit_fix_status_id
205
    ActiveSupport::Deprecation.warn "Setting.commit_fix_status_id is deprecated and will be removed in Redmine 3"
206
    if commit_update_keywords.is_a?(Array)
207
      commit_update_keywords.first && commit_update_keywords.first['status_id']
208
    end
209
  end
210
211
  def self.commit_fix_done_ratio
212
    ActiveSupport::Deprecation.warn "Setting.commit_fix_done_ratio is deprecated and will be removed in Redmine 3"
213
    if commit_update_keywords.is_a?(Array)
214
      commit_update_keywords.first && commit_update_keywords.first['done_ratio']
215
    end
216
  end
217
218 0:513646585e45 Chris
  def self.openid?
219
    Object.const_defined?(:OpenID) && self[:openid].to_i > 0
220
  end
221 441:cbce1fd3b1b7 Chris
222 0:513646585e45 Chris
  # Checks if settings have changed since the values were read
223
  # and clears the cache hash if it's the case
224
  # Called once per request
225
  def self.check_cache
226
    settings_updated_on = Setting.maximum(:updated_on)
227
    if settings_updated_on && @cached_cleared_on <= settings_updated_on
228 909:cbb26bc654de Chris
      clear_cache
229 0:513646585e45 Chris
    end
230
  end
231 1464:261b3d9a4903 Chris
232 909:cbb26bc654de Chris
  # Clears the settings cache
233
  def self.clear_cache
234
    @cached_settings.clear
235
    @cached_cleared_on = Time.now
236
    logger.info "Settings cache cleared." if logger
237
  end
238 441:cbce1fd3b1b7 Chris
239 0:513646585e45 Chris
private
240
  # Returns the Setting instance for the setting named name
241
  # (record found in database or new record with default value)
242
  def self.find_or_default(name)
243
    name = name.to_s
244 441:cbce1fd3b1b7 Chris
    raise "There's no setting named #{name}" unless @@available_settings.has_key?(name)
245 1517:dffacf8a6908 Chris
    setting = where(:name => name).first
246 909:cbb26bc654de Chris
    unless setting
247 1517:dffacf8a6908 Chris
      setting = new
248
      setting.name = name
249 909:cbb26bc654de Chris
      setting.value = @@available_settings[name]['default']
250
    end
251
    setting
252 0:513646585e45 Chris
  end
253
end