diff options
| author | Gareth Rees <gareth@mysociety.org> | 2014-04-24 18:00:42 +0100 | 
|---|---|---|
| committer | Gareth Rees <gareth@mysociety.org> | 2014-05-01 14:15:05 +0100 | 
| commit | 48c60549daf4ba5b94bb164ae27c7d1cbf9110bf (patch) | |
| tree | 6ecda98a8e934602a398ce5480d2ea21e04747f2 /lib | |
| parent | 57e614fe0fc4de08a9225855f41c861a7a270dce (diff) | |
Add rake tasks for James Cheshire stats
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/tasks/stats.rake | 55 | 
1 files changed, 55 insertions, 0 deletions
| diff --git a/lib/tasks/stats.rake b/lib/tasks/stats.rake index 38eb15996..d32dfa94d 100644 --- a/lib/tasks/stats.rake +++ b/lib/tasks/stats.rake @@ -97,6 +97,61 @@ namespace :stats do      end    end +  desc <<-DESC +Prints the total and per-quarter number of created FOI Requests made to each Public Body found by the query. +Specify the search query as QUERY='london school' +DESC +  task :number_of_requests_created => :environment do +    query = ENV['QUERY'] +    start_at = PublicBody.minimum(:created_at) +    finish_at = PublicBody.maximum(:created_at) +    public_bodies = PublicBody.search(query) +    quarters = DateQuarter.quarters_between(start_at, finish_at) + +    # Headers +    headers = ['Body', 'Total Requests'] + quarters.map { |date_tuple| date_tuple.join('~') } +    puts headers.join(",") + +    public_bodies.each do |body| +        stats = quarters.map do |quarter| +                    conditions = ['created_at >= ? AND created_at < ?', quarter[0], quarter[1]] +                    count = body.info_requests.count(:conditions => conditions) +                    count ? count : 0 +                end + +      row = [body.name, body.info_requests_count] + stats +      puts row.join(",") +    end +  end + +  desc <<-DESC +Prints the total and per-quarter number of successful FOI Requests made to each Public Body found by the query. +Specify the search query as QUERY='london school' +DESC +  task :number_of_requests_successful => :environment do +    query = ENV['QUERY'] +    start_at = PublicBody.minimum(:created_at) +    finish_at = PublicBody.maximum(:created_at) +    public_bodies = PublicBody.search(query) +    quarters = DateQuarter.quarters_between(start_at, finish_at) + +    # Headers +    headers = ['Body', 'Total Requests'] + quarters.map { |date_tuple| date_tuple.join('~') } +    puts headers.join(",") + +    public_bodies.each do |body| +      stats = quarters.map do |quarter| +                  conditions = ['created_at >= ? AND created_at < ? AND described_state = ?', +                                quarter[0], quarter[1], 'successful'] +                  count = body.info_requests.count(:conditions => conditions) +                  count ? count : 0 +              end + +      row = [body.name, body.info_requests_count] + stats +      puts row.join(",") +    end +  end +    desc 'Update statistics in the public_bodies table'    task :update_public_bodies_stats => :environment do      verbose = ENV['VERBOSE'] == '1' | 
