]> sipb.mit.edu Git - ikiwiki.git/blobdiff - IkiWiki/Plugin/meta.pm
* meta: Add redir support, based on a patch by Thomas Schwinge.
[ikiwiki.git] / IkiWiki / Plugin / meta.pm
index cfa4b84b1d9d92382a28e60ae54501683c5dff31..134c0ce5d1065f5520407c2d671c52073c569040 100644 (file)
@@ -13,6 +13,7 @@ my %author;
 my %authorurl;
 my %license;
 my %copyright;
+my %redirected;
 
 sub import { #{{{
        hook(type => "preprocess", id => "meta", call => \&preprocess, scan => 1);
@@ -59,7 +60,9 @@ sub preprocess (@) { #{{{
        if ($key eq 'link') {
                if (%params) {
                        $meta{$page}.=scrub("<link href=\"".encode_entities($value)."\" ".
-                               join(" ", map { encode_entities($_)."=\"".encode_entities(decode_entities($params{$_}))."\"" } keys %params).
+                               join(" ", map {
+                                       encode_entities($_)."=\"".encode_entities(decode_entities($params{$_}))."\""
+                               } keys %params).
                                " />\n");
                }
                else {
@@ -67,6 +70,32 @@ sub preprocess (@) { #{{{
                        push @{$links{$page}}, $value;
                }
        }
+       elsif ($key eq 'redir') {
+               $redirected{$page}=1;
+               my $safe=0;
+               if ($value =~ /^$config{wiki_link_regexp}$/) {
+                       my $link=bestlink($page, $value);
+                       if (! length $link) {
+                               return "[[meta ".gettext("redir page not found")."]]";
+                       }
+                       if ($redirected{$link}) {
+                               # TODO this is a cheap way of avoiding
+                               # redir cycles, but it is really too strict.
+                               return "[[meta ".gettext("redir to page that itself redirs is not allowed")."]]";
+                       }
+                       $value=urlto($link, $destpage);
+                       $safe=1;
+               }
+               else {
+                       $value=encode_entities($value);
+               }
+               my $delay=int(exists $params{delay} ? $params{delay} : 0);
+               my $redir="<meta http-equiv=\"refresh\" content=\"$delay; URL=$value\">";
+               if (! $safe) {
+                       $redir=scrub($redir);
+               }
+               $meta{$page}.=$redir;
+       }
        elsif ($key eq 'title') {
                $title{$page}=HTML::Entities::encode_numeric($value);
        }
@@ -111,25 +140,6 @@ sub preprocess (@) { #{{{
                $meta{$page}.="<link rel=\"copyright\" href=\"#page_copyright\" />\n";
                $copyright{$page}=$value;
        }
-       elsif ($key eq 'forward') {
-               my $delay=0;
-               my $dest_url;
-               my $text;
-               if (exists $params{delay}) {
-                       $delay=$params{delay};
-               }
-               # Is this a wikilink?
-               if ($value =~ /^\[\[(.*)\]\]$/) {
-                       $text=htmllink($page, $destpage, $1);
-                       $dest_url=urlto(bestlink($page, $1), $destpage);
-               } else {
-                       $text="<a href=\"$dest_url\">$dest_url</a>";
-                       $dest_url=$value;
-               }
-# TODO.                $meta{$page}.=scrub("<meta http-equiv=\"refresh\" content=\"$delay; URL=$dest_url\">");
-               $meta{$page}.="<meta http-equiv=\"refresh\" content=\"$delay; URL=$dest_url\">";
-               return "You are being forwarded to $text.";
-       }
        else {
                $meta{$page}.=scrub("<meta name=\"".encode_entities($key).
                        "\" content=\"".encode_entities($value)."\" />\n");