6 sub vars
{ return $_[0]->{cgi
}->Vars(); }
7 sub upload_dirs
{ return @
{ $_[0]->{upload_dirs
} }; }
13 foreach my $k (keys(%headers)) {
14 $self->{http_headers
}->{$k} = $headers{$k};
17 return $self->{http_headers
};
24 $self->http_headers( 'Set-Cookie', shift );
27 return $ENV{HTTP_COOKIE
};
30 sub redirect
{ $_[0]->http_headers( 'Location', $_[1] ); }
37 $self->{data
} = $data;
49 my $file = $self->{cgi
}->param($field);
50 my ($basename) = ($file =~ /([^\/\\]+)$/);
52 if (! grep(/^$dir$/, $self->upload_dirs())) {
53 croak
"Unauthorized upload directory $dir";
56 my $filename = $dir . '/' . $basename;
58 open F
, '>' . $filename or croak
"Can't write $filename";
70 my $obj = bless( { @_ }, $class );
72 $obj->{http_headers
} = {
73 'Content-Type' => 'text/html; charset=ISO-8859-1',
74 'X-Gateway-Interface' => $ENV{'GATEWAY_INTERFACE'},
75 'X-Server-Name' => $ENV{'SERVER_NAME'}
78 $obj->{upload_dirs
} ||= [];
80 $obj->{cgi
} = CGI
->new();
89 my $data = $self->data();
90 my $vars = $self->vars();
92 $data->template->cgi_vars($vars);
94 if ($ENV{REMOTE_USER
} and my $u = $data->user($ENV{REMOTE_USER
})) {
97 elsif (my $cookie = $self->cookie()) {
98 if (my ($sid) = ($cookie =~ /^sid\s*=\s*(\d+)$/)) {
99 $data->auth_from_sid( $sid );
106 $st = uc($vars->{t
});
109 $st = 'INDEX' unless $st =~ /^[-\w0-9_]+$/;
113 eval { $body = $data->template->process( $st ) };
117 # $self->redirect('?t=INDEX');
118 $body = "<pre>$@</pre>";
121 $self->http_headers('X-Powered-By' => 'Gruta ' . $self->data->version());
123 if (!$data->auth()) {
126 my $md5 = Digest
::MD5
->new();
128 my $etag = $md5->hexdigest();
130 my $inm = $ENV{HTTP_IF_NONE_MATCH
} || '';
133 $self->http_headers('Status' => '304');
137 $self->http_headers('ETag' => $etag);
141 my $h = $self->http_headers();
142 foreach my $k (keys(%{ $h })) {
143 print $k, ': ', $h->{$k}, "\n";