2 package IkiWiki
::Plugin
::getsource
;
7 use open qw{:utf8
:std
};
10 hook
(type
=> "getsetup", id
=> "getsource", call
=> \
&getsetup
);
11 hook
(type
=> "pagetemplate", id
=> "getsource", call
=> \
&pagetemplate
);
12 hook
(type
=> "cgi", id
=> "getsource", call
=> \
&cgi_getsource
);
22 getsource_mimetype
=> {
24 example
=> "text/plain; charset=utf-8",
25 description
=> "Mime type for returned source.",
31 sub pagetemplate
(@
) {
34 my $page=$params{page
};
35 my $template=$params{template
};
37 if (length $config{cgiurl
}) {
38 $template->param(getsourceurl
=> IkiWiki
::cgiurl
(do => "getsource", page
=> $page));
39 $template->param(have_actions
=> 1);
43 sub cgi_getsource
($) {
46 return unless defined $cgi->param('do') &&
47 $cgi->param("do") eq "getsource";
49 IkiWiki
::decode_cgi_utf8
($cgi);
51 my $page=$cgi->param('page');
53 if (! defined $page || $page !~ /$config{wiki_file_regexp}/) {
54 error
("invalid page parameter");
60 if (! exists $pagesources{$page}) {
61 IkiWiki
::cgi_custom_failure
(
64 IkiWiki
::cgitemplate
($cgi, gettext
("missing page"),
66 sprintf(gettext
("The page %s does not exist."),
67 htmllink
("", "", $page)).
72 if (! defined pagetype
($pagesources{$page})) {
73 IkiWiki
::cgi_custom_failure
(
74 $cgi->header(-status
=> "403 Forbidden"),
75 IkiWiki
::cgitemplate
($cgi, gettext
("not a page"),
77 sprintf(gettext
("%s is an attachment, not a page."),
78 htmllink
("", "", $page)).
83 if (! $config{getsource_mimetype
}) {
84 $config{getsource_mimetype
} = "text/plain; charset=utf-8";
87 print "Content-Type: $config{getsource_mimetype}\r\n";
89 print readfile
(srcfile
($pagesources{$page}));