| 
									
										
										
										
											2009-01-04 17:09:25 +00:00
										 |  |  | # Redmine - project management software | 
					
						
							| 
									
										
										
										
											2015-01-11 09:09:50 +00:00
										 |  |  | # Copyright (C) 2006-2015  Jean-Philippe Lang | 
					
						
							| 
									
										
										
										
											2009-01-04 17:09:25 +00:00
										 |  |  | # | 
					
						
							|  |  |  | # This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  | # modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  | # as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  | # of the License, or (at your option) any later version. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | # but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | # GNU General Public License for more details. | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | # You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  | # along with this program; if not, write to the Free Software | 
					
						
							|  |  |  | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module Redmine | 
					
						
							|  |  |  |   module Utils | 
					
						
							|  |  |  |     class << self | 
					
						
							|  |  |  |       # Returns the relative root url of the application | 
					
						
							|  |  |  |       def relative_url_root | 
					
						
							|  |  |  |         ActionController::Base.respond_to?('relative_url_root') ? | 
					
						
							|  |  |  |           ActionController::Base.relative_url_root.to_s : | 
					
						
							| 
									
										
										
										
											2012-04-25 17:17:49 +00:00
										 |  |  |           ActionController::Base.config.relative_url_root.to_s | 
					
						
							| 
									
										
										
										
											2009-01-04 17:09:25 +00:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2011-09-20 02:46:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-04 17:09:25 +00:00
										 |  |  |       # Sets the relative root url of the application | 
					
						
							|  |  |  |       def relative_url_root=(arg) | 
					
						
							|  |  |  |         if ActionController::Base.respond_to?('relative_url_root=') | 
					
						
							|  |  |  |           ActionController::Base.relative_url_root=arg | 
					
						
							|  |  |  |         else | 
					
						
							| 
									
										
										
										
											2012-04-25 17:17:49 +00:00
										 |  |  |           ActionController::Base.config.relative_url_root = arg | 
					
						
							| 
									
										
										
										
											2009-01-04 17:09:25 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2012-03-04 11:05:02 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |       # Generates a n bytes random hex string | 
					
						
							|  |  |  |       # Example: | 
					
						
							|  |  |  |       #   random_hex(4) # => "89b8c729" | 
					
						
							|  |  |  |       def random_hex(n) | 
					
						
							| 
									
										
										
										
											2012-04-25 17:17:49 +00:00
										 |  |  |         SecureRandom.hex(n) | 
					
						
							| 
									
										
										
										
											2012-03-04 11:05:02 +00:00
										 |  |  |       end | 
					
						
							| 
									
										
										
										
											2009-01-04 17:09:25 +00:00
										 |  |  |     end | 
					
						
							| 
									
										
										
										
											2012-07-07 13:48:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     module Shell | 
					
						
							|  |  |  |       def shell_quote(str) | 
					
						
							|  |  |  |         if Redmine::Platform.mswin? | 
					
						
							|  |  |  |           '"' + str.gsub(/"/, '\\"') + '"' | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |           "'" + str.gsub(/'/, "'\"'\"'") + "'" | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2012-10-29 10:06:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     module DateCalculation | 
					
						
							|  |  |  |       # Returns the number of working days between from and to | 
					
						
							|  |  |  |       def working_days(from, to) | 
					
						
							|  |  |  |         days = (to - from).to_i | 
					
						
							|  |  |  |         if days > 0
 | 
					
						
							|  |  |  |           weeks = days / 7
 | 
					
						
							|  |  |  |           result = weeks * (7 - non_working_week_days.size) | 
					
						
							|  |  |  |           days_left = days - weeks * 7
 | 
					
						
							|  |  |  |           start_cwday = from.cwday | 
					
						
							|  |  |  |           days_left.times do |i| | 
					
						
							|  |  |  |             unless non_working_week_days.include?(((start_cwday + i - 1) % 7) + 1) | 
					
						
							|  |  |  |               result += 1
 | 
					
						
							|  |  |  |             end | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |           result | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |           0
 | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       # Adds working days to the given date | 
					
						
							|  |  |  |       def add_working_days(date, working_days) | 
					
						
							|  |  |  |         if working_days > 0
 | 
					
						
							|  |  |  |           weeks = working_days / (7 - non_working_week_days.size) | 
					
						
							|  |  |  |           result = weeks * 7
 | 
					
						
							|  |  |  |           days_left = working_days - weeks * (7 - non_working_week_days.size) | 
					
						
							|  |  |  |           cwday = date.cwday | 
					
						
							|  |  |  |           while days_left > 0
 | 
					
						
							|  |  |  |             cwday += 1
 | 
					
						
							|  |  |  |             unless non_working_week_days.include?(((cwday - 1) % 7) + 1) | 
					
						
							|  |  |  |               days_left -= 1
 | 
					
						
							|  |  |  |             end | 
					
						
							|  |  |  |             result += 1
 | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |           next_working_date(date + result) | 
					
						
							|  |  |  |         else | 
					
						
							|  |  |  |           date | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       # Returns the date of the first day on or after the given date that is a working day | 
					
						
							|  |  |  |       def next_working_date(date) | 
					
						
							|  |  |  |         cwday = date.cwday | 
					
						
							|  |  |  |         days = 0
 | 
					
						
							|  |  |  |         while non_working_week_days.include?(((cwday + days - 1) % 7) + 1) | 
					
						
							|  |  |  |           days += 1
 | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |         date + days | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       # Returns the index of non working week days (1=monday, 7=sunday) | 
					
						
							|  |  |  |       def non_working_week_days | 
					
						
							|  |  |  |         @non_working_week_days ||= begin | 
					
						
							|  |  |  |           days = Setting.non_working_week_days | 
					
						
							|  |  |  |           if days.is_a?(Array) && days.size < 7
 | 
					
						
							|  |  |  |             days.map(&:to_i) | 
					
						
							|  |  |  |           else | 
					
						
							|  |  |  |             [] | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2009-01-04 17:09:25 +00:00
										 |  |  |   end | 
					
						
							|  |  |  | end |