sub problem_list {
my ($self, %args) = @_;
- my $rs = $self->problems->search(undef, {order_by => 'me.name', columns => PROBLEM_PUBLIC_COLUMNS, prefetch => 'owner'});
+ my @columns = @{PROBLEM_PUBLIC_COLUMNS()};
+ push @columns, 'solution' if $args{solution} && $args{contest} && !$self->contest($args{contest})->is_running;
+ my $rs = $self->problems->search(undef, {order_by => 'me.name', columns => \@columns, prefetch => 'owner'});
$rs = $rs->search({-or => ['contest_problems.contest' => undef, 'contest.stop' => {'<=', time}], 'me.private' => 0}, {join => {'contest_problems' => 'contest'}, distinct => 1}) unless $args{contest} || $args{private};
$rs = $rs->search({'contest_problems.contest' => $args{contest}}, {join => 'contest_problems'}) if $args{contest};
$rs = $rs->search({'me.owner' => $args{owner}}) if $args{owner};
sub problem_entry {
my ($self, $id, $contest, $user) = @_;
my $running = $contest && $self->contest($contest)->is_running;
- my $columns = PROBLEM_PUBLIC_COLUMNS;
- push @$columns, 'statement';
- push @$columns, 'solution' unless $running;
- my $pb = $self->problems->find($id, {columns => $columns, prefetch => 'owner'});
+ my @columns = @{PROBLEM_PUBLIC_COLUMNS()};
+ push @columns, 'statement';
+ push @columns, 'solution' unless $running;
+ my $pb = $self->problems->find($id, {columns => \@columns, prefetch => 'owner'});
my $open;
$open = $self->opens->find_or_create({
contest => $contest,