- if ($r->uri =~ /^\/\+tags\/?/) {
- # Tag cloud
- my $q = $dbh->prepare('SELECT tag,COUNT(*) AS frequency FROM tags t JOIN images i ON t.image=i.id WHERE vhost=? GROUP BY tag ORDER BY COUNT(*) DESC LIMIT 75')
- or dberror($r, "Couldn't list events");
- $q->execute($r->get_server_name)
- or dberror($r, "Couldn't get events");
-
- Sesse::pr0n::Common::header($r, Sesse::pr0n::Templates::fetch_template($r, 'tag-listing'));
- Sesse::pr0n::Templates::print_template($r, 'mainmenu-tags');
-
- my $cloud = HTML::TagCloud->new;
-
- while (my $ref = $q->fetchrow_hashref()) {
- my $tag = Encode::decode_utf8($ref->{'tag'});
- my $html = HTML::Entities::encode_entities($tag); # is this right?
- my $uri = Sesse::pr0n::Common::pretty_escape($tag); # and this?
-
- $cloud->add($html, "/+tags/$uri/", $ref->{'frequency'});
- }
-
- $r->print($cloud->html_and_css());
- Sesse::pr0n::Common::footer($r);
-
- $q->finish();
- } else {
- # main listing