# redMine - project management software # Copyright (C) 2006-2008 Jean-Philippe Lang # # 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 Acts module ActivityProvider def self.included(base) base.extend ClassMethods end module ClassMethods def acts_as_activity_provider(options = {}) unless self.included_modules.include?(Redmine::Acts::ActivityProvider::InstanceMethods) cattr_accessor :activity_provider_options send :include, Redmine::Acts::ActivityProvider::InstanceMethods end options.assert_valid_keys(:type, :permission, :timestamp, :find_options) self.activity_provider_options ||= {} # One model can provide different event types # We store these options in activity_provider_options hash event_type = options.delete(:type) || self.name.underscore.pluralize options[:permission] = "view_#{self.name.underscore.pluralize}".to_sym unless options.has_key?(:permission) options[:timestamp] ||= "#{table_name}.created_on" options[:find_options] ||= {} self.activity_provider_options[event_type] = options end end module InstanceMethods def self.included(base) base.extend ClassMethods end module ClassMethods # Returns events of type event_type visible by user that occured between from and to def find_events(event_type, user, from, to, options) provider_options = activity_provider_options[event_type] raise "#{self.name} can not provide #{event_type} events." if provider_options.nil? cond = ARCondition.new(["#{provider_options[:timestamp]} BETWEEN ? AND ?", from, to]) cond.add(Project.allowed_to_condition(user, provider_options[:permission], options)) if provider_options[:permission] with_scope(:find => { :conditions => cond.conditions }) do find(:all, provider_options[:find_options]) end end end end end end end