]> git.sesse.net Git - ccbs/blobdiff - html/ccbs.pm
Shape text using Pango and HarfBuzz; gives us nice ligatures and exotic scripts.
[ccbs] / html / ccbs.pm
index 7d5f90dd0a4abf827367ca7d164ed232f0be6060..1807e0953de82cfdbb066373c8c4af7ed4ba58a4 100755 (executable)
@@ -1,12 +1,43 @@
 package ccbs;
 use Template;
 use CGI;
+use CGI::Cookie;
 use DBI;
+use HTML::Entities;
+use Time::HiRes;
+use Locale::gettext;
+use POSIX;
 use strict;
 use warnings;
+require '../intl/Sesse::GettextizeTemplates.pm';
+
+require '../config.pm';
+-r '../config.local.pm' and require '../config.local.pm';
+
+# Check for language settings
+my %cookies = fetch CGI::Cookie;
+my $lang = defined($cookies{'language'}) ? $cookies{'language'}->value : undef;
+if (defined($lang) && ($lang eq 'nb_NO' || $lang eq 'nn_NO' || $lang eq 'en_US')) {
+       POSIX::setlocale( &POSIX::LC_CTYPE , $lang . ".UTF-8" );
+       POSIX::setlocale( &POSIX::LC_MESSAGES , $lang . ".UTF-8" );
+} else {
+       POSIX::setlocale( &POSIX::LC_CTYPE , $ccbs::config::lang );
+       POSIX::setlocale( &POSIX::LC_MESSAGES , $ccbs::config::lang );
+}
+Locale::gettext::bindtextdomain("ccbs", "po");
+Locale::gettext::textdomain("ccbs");
+
+our $start_time;
+
+BEGIN {
+       $start_time = [Time::HiRes::gettimeofday()];
+}
+
+# Hack to get the non-templatized gettext stuff working
+*_ = sub {
+       return Locale::gettext::gettext(@_);
+};
 
-our $ccbs_dbdebug = 0;
-       
 sub print_header {
        print CGI::header(-type=>'text/html; charset=utf-8');
 }
@@ -14,14 +45,12 @@ sub print_see_other {
        my $location = shift;
 
        print CGI::header(-status=>'303 See other',
-                         -location=>'http://ccbs.sesse.net/' . $location,
+                         -location=>$ccbs::config::webroot . $location,
                          -type=>'text/html; charset=utf-8');
 }
 
 sub db_connect {
-       $ccbs_dbdebug = defined(shift) ? 1 : 0;
-
-       my $dbh = DBI->connect("dbi:Pg:dbname=ccbs;host=sql.samfundet.no", "ccbs", "GeT|>>B_")
+       my $dbh = DBI->connect("dbi:Pg:dbname=$ccbs::config::dbname;host=$ccbs::config::dbhost", $ccbs::config::dbuser, $ccbs::config::dbpass)
                or die "Couldn't connect to database";
        $dbh->{RaiseError} = 1;
        return $dbh;
@@ -34,14 +63,14 @@ sub db_fetch_all {
        $q->execute(@parms)
                or die "Could not execute query: " . $dbh->errstr;
 
-       if ($ccbs_dbdebug) {
+       if ($config::ccbs::dbdebug) {
                warn $sql;
                warn "params=" . join(', ', @parms);
        }
        
        my @ret = ();
        while (my $ref = $q->fetchrow_hashref()) {
-               if ($ccbs_dbdebug) {
+               if ($config::ccbs::dbdebug) {
                        my $dbstr = "";
                        for my $k (sort keys %$ref) {
                                $dbstr .= " " . $k . "=" . $ref->{$k};
@@ -59,17 +88,20 @@ sub process_template {
        my ($page, $title, $vars) = @_;
        $vars->{'page'} = $page;
        $vars->{'title'} = $title;
+       $vars->{'public'} = $ccbs::config::noadmin;
+       $vars->{'timetogenerate'} = sprintf "%.3f", Time::HiRes::tv_interval($start_time);
        
        my $config = {
                INCLUDE_PATH => 'templates/',
                INTERPOLATE  => 1,
                POST_CHOMP   => 1,
                EVAL_PERL    => 1,
+               FACTORY      => 'Sesse::GettextizeTemplates'
        };
        my $template = Template->new($config);
 
        my $output = '';
-       $template->process('main.tmpl', $vars, \$output)
+       $template->process($ccbs::config::main_template, $vars, \$output)
                or die $template->error();
 
        print $output;
@@ -79,11 +111,14 @@ sub user_error {
        my $msg = shift;
 
        ccbs::print_header();
-       ccbs::process_template('user-error.tmpl', 'Feil',
+       ccbs::process_template('user-error.tmpl', _('Error'),
                { message => $msg });
 
        exit;
 }
+sub admin_only {
+       user_error(_("Sorry, the database is in no-admin-mode.")) if ($config::ccbs::noadmin);
+}
 
 $SIG{__DIE__} = sub {
        # Gosh! Net::Resolver::DNS is brain-damaged.
@@ -91,8 +126,8 @@ $SIG{__DIE__} = sub {
        return if $msg =~ m#Win32/Registry.pm#;
 
        ccbs::print_header();
-       ccbs::process_template('error.tmpl', 'Internal Server Error',
-               { message => $msg });
+       ccbs::process_template('error.tmpl', _('Internal Server Error'),
+               { message => HTML::Entities::encode_entities($msg) });
 };
 
 1;