]> git.openstreetmap.org Git - rails.git/blob - app/controllers/users/heatmaps_controller.rb
Merge remote-tracking branch 'upstream/pull/5201'
[rails.git] / app / controllers / users / heatmaps_controller.rb
1 module Users
2   class HeatmapsController < ApplicationController
3     layout false
4
5     before_action :authorize_web
6     before_action :set_locale
7     before_action :check_database_readable
8
9     authorize_resource :user
10
11     def show
12       @user = User.find_by(:display_name => params[:user_display_name])
13
14       if @user && (@user.visible? || current_user&.administrator?)
15         @heatmap_data = Rails.cache.fetch("heatmap_data_of_user_#{@user.id}", :expires_at => Time.zone.now.end_of_day) do
16           from = 1.year.ago.beginning_of_day
17           to = Time.zone.now.end_of_day
18
19           mapped = Changeset
20                    .where(:user_id => @user.id)
21                    .where(:created_at => from..to)
22                    .where(:num_changes => 1..)
23                    .group("date_trunc('day', created_at)")
24                    .select("date_trunc('day', created_at) AS date, SUM(num_changes) AS total_changes, MAX(id) AS max_id")
25                    .order("date")
26                    .map do |changeset|
27                      {
28                        :date => changeset.date.to_date,
29                        :total_changes => changeset.total_changes.to_i,
30                        :max_id => changeset.max_id
31                      }
32                    end
33
34           {
35             :count => mapped.sum { |entry| entry[:total_changes] },
36             :data => mapped.index_by { |entry| entry[:date] },
37             :from => from,
38             :to => to
39           }
40         end
41       end
42     end
43   end
44 end