#-- copyright # OpenProject is an open source project management software. # Copyright (C) 2012-2020 the OpenProject GmbH # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License version 3. # # OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows: # Copyright (C) 2006-2017 Jean-Philippe Lang # Copyright (C) 2010-2013 the ChiliProject Team # # 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. # # See docs/COPYRIGHT.rdoc for more details. #++ class CostQuery < Report def_delegators :result, :real_costs User.before_destroy do |user| CostQuery.where(user_id: user.id, is_public: false).delete_all CostQuery.where(['user_id = ?', user.id]).update_all ['user_id = ?', DeletedUser.first.id] max_query_id = 0 while((current_queries = CostQuery.limit(1000) .where(["id > ?", max_query_id]) .order("id ASC")).size > 0) do current_queries.each do |query| serialized = query.serialized serialized[:filters] = serialized[:filters].map do |name, options| options[:values].delete(user.id.to_s) if ["UserId", "AuthorId", "AssignedToId"].include?(name) options[:values].nil? || options[:values].size > 0 ? [name, options] : nil end.compact CostQuery.where(["id = ?", query.id]).update_all ["serialized = ?", YAML::dump(serialized)] max_query_id = query.id end end end end