1 |
296 |
ahitrov |
#!/usr/bin/perl |
2 |
|
|
|
3 |
|
|
use strict; |
4 |
|
|
use warnings "all"; |
5 |
|
|
use locale; |
6 |
|
|
|
7 |
|
|
use FindBin; |
8 |
|
|
BEGIN { |
9 |
|
|
require "$FindBin::RealBin/../lib/Modules.pm"; |
10 |
|
|
} |
11 |
|
|
|
12 |
|
|
use Contenido::Globals; |
13 |
|
|
use Contenido::Init; |
14 |
|
|
use ErrorTee; |
15 |
|
|
use PidFile; |
16 |
|
|
use JSON::XS; |
17 |
|
|
use Data::Dumper; |
18 |
|
|
|
19 |
|
|
# begin |
20 |
|
|
Contenido::Init->init(); |
21 |
|
|
|
22 |
|
|
#PidFile->new($state); # db-based locking (run only on one host) |
23 |
|
|
#PidFile->new($state, per_host=>1); # db-based locking (run on whole cluster) |
24 |
|
|
#PidFile->new($state->{run_dir}); # file-based locking (run on whole cluster) |
25 |
|
|
|
26 |
|
|
my $keeper_module = $state->project.'::Keeper'; |
27 |
|
|
$keeper = $keeper_module->new($state); |
28 |
|
|
|
29 |
|
|
############################################ |
30 |
|
|
# please use: |
31 |
|
|
# $state->{log_dir} for logging |
32 |
|
|
# $state->{tmp_dir} for temporary files |
33 |
|
|
########################################### |
34 |
|
|
my @votings = $keeper->get_documents ( |
35 |
|
|
class => 'promosuite::Voting', |
36 |
|
|
status => [1,2], |
37 |
|
|
); |
38 |
|
|
my $SIZE = 400; |
39 |
|
|
foreach my $voting ( @votings ) { |
40 |
|
|
my @voices; my $p = 0; |
41 |
|
|
my $voting_data = $voting->get_image('voting'); |
42 |
|
|
while ( my @vs = $keeper->get_documents ( |
43 |
|
|
class => 'promosuite::Voice', object_id => $voting->id, |
44 |
|
|
order_by => 'id', limit => $SIZE, offset => $SIZE * $p++ ) ) { |
45 |
|
|
push @voices, @vs; |
46 |
|
|
} |
47 |
|
|
|
48 |
|
|
if ( @voices ) { |
49 |
|
|
my %voting_data; |
50 |
|
|
foreach my $voice ( @voices ) { |
51 |
|
|
my $json = JSON::XS->new; |
52 |
|
|
my $voice_data = $json->decode($voice->voting); |
53 |
|
|
next unless ref $voice_data eq 'HASH'; |
54 |
|
|
while ( my ($qnum, $answer) = each %$voice_data ) { |
55 |
|
|
next unless ref $answer eq 'HASH'; |
56 |
|
|
while ( my ($anum, $value) = each %$answer ) { |
57 |
|
|
$voting_data{$qnum}{$anum}{total} = 0 unless defined $voting_data{$qnum}{$anum}{total}; |
58 |
|
|
$voting_data{$qnum}{$anum}{total} += $value; |
59 |
|
|
$voting_data{$qnum}{$anum}{count} = 0 unless defined $voting_data{$qnum}{$anum}{count}; |
60 |
|
|
$voting_data{$qnum}{$anum}{count}++; |
61 |
|
|
} |
62 |
|
|
} |
63 |
|
|
|
64 |
|
|
} |
65 |
|
|
for ( 1..$voting_data->{'question_amount'} ) { |
66 |
|
|
my $qnum = $_; |
67 |
|
|
if ( $voting_data->{questions}->[$qnum-1]->{amount} ) { |
68 |
|
|
for ( 1..$voting_data->{questions}->[$qnum-1]->{amount} ) { |
69 |
|
|
my $anum = $_ - 1; |
70 |
|
|
if ( exists $voting_data{$qnum} && exists $voting_data{$qnum}{$anum} ) { |
71 |
|
|
if ( $voting_data->{questions}->[$qnum-1]->{range} ) { |
72 |
|
|
$voting_data->{questions}->[$qnum-1]->{choices}->[$anum]->{votes} = $voting_data{$qnum}{$anum}{total}/$voting_data{$qnum}{$anum}{count}; |
73 |
|
|
} else { |
74 |
|
|
$voting_data->{questions}->[$qnum-1]->{choices}->[$anum]->{votes} = $voting_data{$qnum}{$anum}{total}; |
75 |
|
|
} |
76 |
|
|
} |
77 |
|
|
} |
78 |
|
|
} |
79 |
|
|
} |
80 |
|
|
$voting_data->{total} = scalar @voices; |
81 |
|
|
{ |
82 |
|
|
local $Data::Dumper::Indent = 0; |
83 |
|
|
$voting->voting( Dumper($voting_data) ); |
84 |
|
|
} |
85 |
|
|
} |
86 |
|
|
$voting->status(3) if $voting->status == 2; |
87 |
|
|
$voting->store; |
88 |
|
|
|
89 |
|
|
} |