annotate .svn/pristine/6a/6a4fdd885d26844cca5f9f69058f8424de0ff4e2.svn-base @ 1519:afce8026aaeb redmine-2.4-integration

Merge from branch "live"
author Chris Cannam
date Tue, 09 Sep 2014 09:34:53 +0100
parents cbb26bc654de
children
rev   line source
Chris@909 1 # Redmine - project management software
Chris@909 2 # Copyright (C) 2006-2011 Jean-Philippe Lang
Chris@909 3 #
Chris@909 4 # This program is free software; you can redistribute it and/or
Chris@909 5 # modify it under the terms of the GNU General Public License
Chris@909 6 # as published by the Free Software Foundation; either version 2
Chris@909 7 # of the License, or (at your option) any later version.
Chris@909 8 #
Chris@909 9 # This program is distributed in the hope that it will be useful,
Chris@909 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
Chris@909 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Chris@909 12 # GNU General Public License for more details.
Chris@909 13 #
Chris@909 14 # You should have received a copy of the GNU General Public License
Chris@909 15 # along with this program; if not, write to the Free Software
Chris@909 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Chris@909 17
Chris@909 18 module Redmine
Chris@909 19 module Activity
Chris@909 20 # Class used to retrieve activity events
Chris@909 21 class Fetcher
Chris@909 22 attr_reader :user, :project, :scope
Chris@909 23
Chris@909 24 # Needs to be unloaded in development mode
Chris@909 25 @@constantized_providers = Hash.new {|h,k| h[k] = Redmine::Activity.providers[k].collect {|t| t.constantize } }
Chris@909 26
Chris@909 27 def initialize(user, options={})
Chris@909 28 options.assert_valid_keys(:project, :with_subprojects, :author)
Chris@909 29 @user = user
Chris@909 30 @project = options[:project]
Chris@909 31 @options = options
Chris@909 32
Chris@909 33 @scope = event_types
Chris@909 34 end
Chris@909 35
Chris@909 36 # Returns an array of available event types
Chris@909 37 def event_types
Chris@909 38 return @event_types unless @event_types.nil?
Chris@909 39
Chris@909 40 @event_types = Redmine::Activity.available_event_types
Chris@909 41 @event_types = @event_types.select {|o| @project.self_and_descendants.detect {|p| @user.allowed_to?("view_#{o}".to_sym, p)}} if @project
Chris@909 42 @event_types
Chris@909 43 end
Chris@909 44
Chris@909 45 # Yields to filter the activity scope
Chris@909 46 def scope_select(&block)
Chris@909 47 @scope = @scope.select {|t| yield t }
Chris@909 48 end
Chris@909 49
Chris@909 50 # Sets the scope
Chris@909 51 # Argument can be :all, :default or an array of event types
Chris@909 52 def scope=(s)
Chris@909 53 case s
Chris@909 54 when :all
Chris@909 55 @scope = event_types
Chris@909 56 when :default
Chris@909 57 default_scope!
Chris@909 58 else
Chris@909 59 @scope = s & event_types
Chris@909 60 end
Chris@909 61 end
Chris@909 62
Chris@909 63 # Resets the scope to the default scope
Chris@909 64 def default_scope!
Chris@909 65 @scope = Redmine::Activity.default_event_types
Chris@909 66 end
Chris@909 67
Chris@909 68 # Returns an array of events for the given date range
Chris@909 69 # sorted in reverse chronological order
Chris@909 70 def events(from = nil, to = nil, options={})
Chris@909 71 e = []
Chris@909 72 @options[:limit] = options[:limit]
Chris@909 73
Chris@909 74 @scope.each do |event_type|
Chris@909 75 constantized_providers(event_type).each do |provider|
Chris@909 76 e += provider.find_events(event_type, @user, from, to, @options)
Chris@909 77 end
Chris@909 78 end
Chris@909 79
Chris@909 80 e.sort! {|a,b| b.event_datetime <=> a.event_datetime}
Chris@909 81
Chris@909 82 if options[:limit]
Chris@909 83 e = e.slice(0, options[:limit])
Chris@909 84 end
Chris@909 85 e
Chris@909 86 end
Chris@909 87
Chris@909 88 private
Chris@909 89
Chris@909 90 def constantized_providers(event_type)
Chris@909 91 @@constantized_providers[event_type]
Chris@909 92 end
Chris@909 93 end
Chris@909 94 end
Chris@909 95 end