source: trunk/wiki.cgi @ 711

Last change on this file since 711 was 711, checked in by Earle Martin, 16 years ago

remove use lib line that had been placed in for testing purposes

  • Property svn:eol-style set to native
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 12.9 KB
Line 
1#!/usr/local/bin/perl
2
3use strict;
4use warnings;
5
6use vars qw( $VERSION );
7$VERSION = '0.51';
8
9use CGI qw/:standard/;
10use CGI::Carp qw(croak);
11use CGI::Wiki;
12use Geography::NationalGrid;
13use Geography::NationalGrid::GB;
14use OpenGuides;
15use OpenGuides::CGI;
16use OpenGuides::Config;
17use OpenGuides::RDF;
18use OpenGuides::Utils;
19use OpenGuides::Template;
20use Time::Piece;
21use URI::Escape;
22
23my $config_file = $ENV{OPENGUIDES_CONFIG_FILE} || "wiki.conf";
24my $config = OpenGuides::Config->new( file => $config_file );
25
26my $script_name = $config->script_name;
27my $script_url  = $config->script_url;
28
29my ($guide, $wiki, $formatter, $q);
30eval {
31    $guide = OpenGuides->new( config => $config );
32    $wiki = $guide->wiki;
33    $formatter = $wiki->formatter;
34
35    # Get CGI object, find out what to do.
36    $q = CGI->new;
37
38    # Note $q->param('keywords') gives you the entire param string.
39    # We need this to do URLs like foo.com/wiki.cgi?This_Page
40    my $node = $q->param('id') || $q->param('title') || $q->param('keywords') || "";
41    $node = $formatter->node_param_to_node_name( $node );
42
43    my $action       = $q->param('action')  || 'display';
44    my $commit       = $q->param('Save')    || 0;
45    my $preview      = $q->param('preview') || 0;
46    my $search_terms = $q->param('terms')   || $q->param('search') || '';
47    my $format       = $q->param('format')  || '';
48    my $oldid        = $q->param('oldid')   || '';
49
50    # Alternative method of calling search, supported by usemod.
51    $action = 'search' if $q->param("search");
52
53    if ($commit) {
54        $guide->commit_node(
55                             id      => $node,
56                             cgi_obj => $q,
57                           );
58    } elsif ($preview) {
59        preview_node($node);
60    } elsif ($action eq 'edit') {
61        edit_node($node);
62    } elsif ($action eq 'search') {
63        do_search($search_terms);
64    } elsif ($action eq 'show_backlinks') {
65        $guide->show_backlinks( id => $node );
66    } elsif ($action eq 'show_wanted_pages') {
67        show_wanted_pages();
68    } elsif ($action eq 'index') {
69        $guide->show_index(
70                            type   => $q->param("index_type") || "Full",
71                            value  => $q->param("index_value") || "",
72                            format => $format,
73                          );
74    } elsif ($action eq 'random') {
75        my @nodes = $wiki->list_all_nodes();
76        $node = $nodes[int(rand(scalar(@nodes) + 1)) + 1];
77        print $guide->redirect_to_node($node);
78        exit 0;
79    } elsif ($action eq 'find_within_distance') {
80        $guide->find_within_distance(
81                                      id => $node,
82                                      metres => $q->param("distance_in_metres")
83                                    );
84    } elsif ( $action eq 'delete'
85              and ( lc($config->enable_page_deletion) eq "y"
86                    or $config->enable_page_deletion eq "1" )
87            ) {
88        $guide->delete_node(
89                             id       => $node,
90                             version  => $q->param("version") || "",
91                             password => $q->param("password") || "",
92                           );
93    } elsif ($action eq 'userstats') {
94        show_userstats(
95                        username => $q->param("username") || "",
96                        host     => $q->param("host") || "",
97                      );
98    } elsif ($action eq 'list_all_versions') {
99        $guide->list_all_versions( id => $node );
100    } elsif ($action eq 'rc') {
101        if ($format && $format eq 'rss') {
102            my $feed = $q->param("feed");
103            if ( !defined $feed or $feed eq "recent_changes" ) {
104                my %args = map { $_ => ( $q->param($_) || "" ) }
105                           qw( feed items days ignore_minor_edits username
106                               category locale );
107                $guide->display_rss( %args );
108            } elsif ( $feed eq "chef_dan" ) {
109                display_node_rdf( node => $node );
110            } else {
111                croak "Unknown RSS feed type '$feed'";
112            }
113        } else {
114            $guide->display_node( id => 'RecentChanges' );
115        }
116    } elsif ($action eq 'rss') {
117        print $q->redirect( $script_url . '?action=rc;format=rss' );
118    } else { # Default is to display a node.
119        if ( $format and $format eq "rdf" ) {
120            display_node_rdf( node => $node );
121        } elsif ( $format and $format eq 'raw' ) {
122            $guide->display_node(
123                                  id       => $node,
124                                  format   => 'raw',
125                                );
126        } else {
127            my $version = $q->param("version");
128            my $other_ver = $q->param("diffversion");
129            if ( $other_ver ) {
130                $guide->display_diffs(
131                                       id            => $node,
132                                       version       => $version,
133                                       other_version => $other_ver,
134                                     );
135            } else {
136                my $redirect;
137               
138                if ((defined $q->param("redirect")) && ($q->param("redirect") == 0)) {
139                  $redirect = 0;
140                } else {
141                  $redirect = 1;               
142                }
143               
144                $guide->display_node(
145                                      id       => $node,
146                                      version  => $version,
147                                      oldid    => $oldid,
148                                      redirect => $redirect,
149                                    );
150            }
151        }
152    }
153};
154
155if ($@) {
156    my $error = $@;
157    warn $error;
158    print $q->header;
159    my $contact_email = $config->contact_email;
160    print qq(<html><head><title>ERROR</title></head><body>
161             <p>Sorry!  Something went wrong.  Please contact the
162             Wiki administrator at
163             <a href="mailto:$contact_email">$contact_email</a> and quote
164             the following error message:</p><blockquote>)
165      . $q->escapeHTML($error)
166      . qq(</blockquote><p><a href="$script_name">Return to the Wiki home page</a>
167           </body></html>);
168}
169exit 0;
170
171############################ subroutines ###################################
172
173sub show_userstats {
174    my %args = @_;
175    my ($username, $host) = @args{ qw( username host ) };
176    croak "No username or host supplied to show_userstats"
177        unless $username or $host;
178    my %criteria = ( last_n_changes => 5 );
179    $criteria{metadata_was} = $username ? { username => $username }
180                                        : { host     => $host };
181    my @nodes = $wiki->list_recent_changes( %criteria );
182    @nodes = map { {name          => $q->escapeHTML($_->{name}),
183            last_modified => $q->escapeHTML($_->{last_modified}),
184            comment       => $q->escapeHTML($_->{metadata}{comment}[0]),
185            url           => "$script_name?"
186          . $q->escape($formatter->node_name_to_node_param($_->{name})) }
187                       } @nodes;
188    my %tt_vars = ( last_five_nodes => \@nodes,
189            username        => $username,
190            username_param  => $wiki->formatter->node_name_to_node_param($username),
191                    host            => $host,
192                  );
193    process_template("userstats.tt", "", \%tt_vars);
194}
195
196sub preview_node {
197    my $node = shift;
198    my $content  = $q->param('content');
199    $content     =~ s/\r\n/\n/gs;
200    my $checksum = $q->param('checksum');
201
202    my %tt_metadata_vars = OpenGuides::Template->extract_metadata_vars(
203                                               wiki                 => $wiki,
204                           config               => $config,
205                           cgi_obj              => $q,
206                                               set_coord_field_vars => 1,
207    );
208    foreach my $var ( qw( username comment edit_type ) ) {
209        $tt_metadata_vars{$var} = $q->escapeHTML($q->param($var));
210    }
211
212    if ($wiki->verify_checksum($node, $checksum)) {
213        my %tt_vars = (
214            %tt_metadata_vars,
215            content                => $q->escapeHTML($content),
216            preview_html           => $wiki->format($content),
217            preview_above_edit_box => get_cookie( "preview_above_edit_box" ),
218            checksum               => $q->escapeHTML($checksum)
219    );
220        process_template("edit_form.tt", $node, \%tt_vars);
221    } else {
222        my %node_data = $wiki->retrieve_node($node);
223        my %tt_vars = ( checksum       => $node_data{checksum},
224                        new_content    => $content,
225                        stored_content => $node_data{content} );
226        foreach my $mdvar ( keys %tt_metadata_vars ) {
227            if ($mdvar eq "locales") {
228                $tt_vars{"stored_$mdvar"} = $node_data{metadata}{locale};
229                $tt_vars{"new_$mdvar"}    = $tt_metadata_vars{locale};
230            } elsif ($mdvar eq "categories") {
231                $tt_vars{"stored_$mdvar"} = $node_data{metadata}{category};
232                $tt_vars{"new_$mdvar"}    = $tt_metadata_vars{category};
233            } elsif ($mdvar eq "username" or $mdvar eq "comment"
234                      or $mdvar eq "edit_type" ) {
235                $tt_vars{$mdvar} = $tt_metadata_vars{$mdvar};
236            } else {
237                $tt_vars{"stored_$mdvar"} = $node_data{metadata}{$mdvar}[0];
238                $tt_vars{"new_$mdvar"}    = $tt_metadata_vars{$mdvar};
239            }
240        }
241        process_template("edit_conflict.tt", $node, \%tt_vars);
242    }
243}
244
245sub edit_node {
246    my $node = shift;
247    my %node_data = $wiki->retrieve_node($node);
248    my ($content, $checksum) = @node_data{ qw( content checksum ) };
249    my $username = get_cookie( "username" );
250    my $edit_type = get_cookie( "default_edit_type" ) eq "normal" ?
251                        "Normal edit" : "Minor tidying";
252
253    my %metadata_vars = OpenGuides::Template->extract_metadata_vars(
254                             wiki     => $wiki,
255                             config   => $config,
256                 metadata => $node_data{metadata} );
257
258    my %tt_vars = ( content         => $q->escapeHTML($content),
259                    checksum        => $q->escapeHTML($checksum),
260                    %metadata_vars,
261            username        => $username,
262                    edit_type       => $edit_type,
263                    deter_robots    => 1,
264    );
265
266    process_template("edit_form.tt", $node, \%tt_vars);
267}
268
269sub get_cookie {
270    my $pref_name = shift or return "";
271    my %cookie_data = OpenGuides::CGI->get_prefs_from_cookie(config=>$config);
272    return $cookie_data{$pref_name};
273}
274
275sub display_node_rdf {
276    my %args = @_;
277    my $rdf_writer = OpenGuides::RDF->new( wiki      => $wiki,
278                       config => $config );
279    print "Content-type: text/plain\n\n";
280    print $rdf_writer->emit_rdfxml( node => $args{node} );
281    exit 0;
282}
283
284sub process_template {
285    my ($template, $node, $vars, $conf, $omit_header) = @_;
286
287    my %output_conf = ( wiki     => $wiki,
288            config   => $config,
289                        node     => $node,
290            template => $template,
291            vars     => $vars
292    );
293    $output_conf{content_type} = "" if $omit_header; # defaults otherwise
294    print OpenGuides::Template->output( %output_conf );
295}
296
297
298sub do_search {
299    my $terms = shift;
300    my %finds = $wiki->search_nodes($terms);
301#    my @sorted = sort { $finds{$a} cmp $finds{$b} } keys %finds;
302    my @sorted = sort keys %finds;
303    my @results = map {
304        { url   => $q->escape($formatter->node_name_to_node_param($_)),
305      title => $q->escapeHTML($_)
306        }             } @sorted;
307    my %tt_vars = ( results      => \@results,
308                    num_results  => scalar @results,
309                    not_editable => 1,
310                    search_terms => $q->escapeHTML($terms) );
311    process_template("search_results.tt", "", \%tt_vars);
312}
313
314sub show_wanted_pages {
315    my @dangling = $wiki->list_dangling_links;
316    my @wanted;
317    my %backlinks_count;
318    foreach my $node_name (@dangling) {
319        $backlinks_count{$node_name} = scalar($wiki->list_backlinks( node => $node_name ));
320    }
321    foreach my $node_name (sort { $backlinks_count{$b} <=> $backlinks_count{$a} } @dangling) {
322        my $node_param =
323         uri_escape($formatter->node_name_to_node_param($node_name));
324        push @wanted, {
325            name          => $q->escapeHTML($node_name),
326            edit_link     => $script_url . uri_escape($script_name)
327                           . "?action=edit;id=$node_param",
328            backlink_link => $script_url . uri_escape($script_name)
329                    . "?action=show_backlinks;id=$node_param",
330            backlinks_count => $backlinks_count{$node_name}
331        };
332    }
333    process_template( "wanted_pages.tt",
334                      "",
335                      { not_editable  => 1,
336                        not_deletable => 1,
337                        deter_robots  => 1,
338                        wanted        => \@wanted } );
339}
340
Note: See TracBrowser for help on using the repository browser.