master
parent
e7e11e6570
commit
e4f241ac2f
|
@ -0,0 +1,60 @@
|
||||||
|
The idea behind this would be to have one ikiwiki behave as a dynamic private wiki in a specified area
|
||||||
|
and a more static publiczone wiki. Actually private wiki page can be addressed via a *pagespec*.
|
||||||
|
|
||||||
|
What is ready /can be done:
|
||||||
|
|
||||||
|
* We already can more or less do this for example with [[httpauth|/plugins/httpauth/]], *.htaccess* files and a proper *httpauth_pagespec*
|
||||||
|
yet at the cost of maintaining two different user/pass logbase (native ikiwiki signin)
|
||||||
|
* Furthermore we can [[lockedit|plugins/lockedit/]] some pagespecs, ie in the public zone.
|
||||||
|
|
||||||
|
What is problematic is when you link a public page in a private page :
|
||||||
|
a backlink will be generated from the public page to the private page.
|
||||||
|
|
||||||
|
As I noticed in [[per_page_ACLs]] in the end users through backlink
|
||||||
|
navigation will frequently hit HTTP/401 deterring browsing as well as for the admin at false-positive logwatching.
|
||||||
|
|
||||||
|
One can radically [[disable backlinks feature|todo/allow_disabling_backlinks]] but then no more neat backlink navigation that
|
||||||
|
is really good to have in both area.
|
||||||
|
|
||||||
|
I think of just preventing this backlink leak in that case would be sufficient via i.e a *privatebacklinks* config and
|
||||||
|
a below patch.
|
||||||
|
|
||||||
|
Comments are welcome.
|
||||||
|
|
||||||
|
[[mathdesc]]
|
||||||
|
|
||||||
|
|
||||||
|
<pre>
|
||||||
|
diff --git a/IkiWiki.pm b/IkiWiki.pm
|
||||||
|
--- a/IkiWiki.pm
|
||||||
|
+++ b/IkiWiki.pm
|
||||||
|
@@ -294,6 +294,14 @@ sub getsetup () {
|
||||||
|
safe => 1,
|
||||||
|
rebuild => 1,
|
||||||
|
},
|
||||||
|
+ privatebacklinks => {
|
||||||
|
+ type => "pagespec",
|
||||||
|
+ example => "",
|
||||||
|
+ description => "PageSpec controlling which backlinks are private (ie users/*)",
|
||||||
|
+ link => "ikiwiki/PageSpec",
|
||||||
|
+ safe => 1,
|
||||||
|
+ rebuild => 1,
|
||||||
|
+ },
|
||||||
|
hardlink => {
|
||||||
|
type => "boolean",
|
||||||
|
default => 0,
|
||||||
|
diff --git a/IkiWiki/Render.pm b/IkiWiki/Render.pm
|
||||||
|
--- a/IkiWiki/Render.pm
|
||||||
|
+++ b/IkiWiki/Render.pm
|
||||||
|
@@ -52,7 +52,8 @@ sub backlinks ($) {
|
||||||
|
$p_trimmed=~s/^\Q$dir\E// &&
|
||||||
|
$page_trimmed=~s/^\Q$dir\E//;
|
||||||
|
|
||||||
|
- push @links, { url => $href, page => pagetitle($p_trimmed) };
|
||||||
|
+ push @links, { url => $href, page => pagetitle($p_trimmed) }
|
||||||
|
+ unless defined $config{privatebacklinks} && length $config{privatebacklinks} && pagespec_match($p, $config{privatebacklinks}) && !pagespec_match($page, $config{privatebacklinks}) ;
|
||||||
|
}
|
||||||
|
return @links;
|
||||||
|
}
|
||||||
|
|
||||||
|
</pre>
|
Loading…
Reference in New Issue