Extension:SplitPrivateWiki

MediaWiki extensions manual
SplitPrivateWiki
Release status: experimental
Implementation User rights
Description Allows to setup 2 wikis a public and private but make them look like only one
Author(s) Brian Wolff (Bawolfftalk)
Latest version 0.2
MediaWiki >= 1.35.3
Database changes Yes
License GNU General Public License 2.0 or later
Download
README
  • $wgExclusiveNamespaces
  • $wgSplitWikiShowInRc
  • $wgBuiltinNamespacesToRename
Quarterly downloads 1 (Ranked 135th)
Translate the SplitPrivateWiki extension if it is available at translatewiki.net

The SplitPrivateWiki extension allows you to make two wikis look like one. Certain namespaces will redirect to the other wiki (and vice versa). Additionally, any edits to the redirected namespace on the public wiki will automatically be transferred to the private wiki. This allows extensions like SemanticMediaWiki to use all the data from the public wiki in the private wiki, but when in the public wiki you can only use the public data. The idea being that one wiki is private and the other is public. This thus allows fine grained read access controls without some of the pitfalls common in other schemes. This extension is experimental. As always use at your own risk.

Installation

edit

We assume you want two wikis run by same copy of mediawiki code, but using different virtual hosts or script paths (using things like alias/rewrite rules)

  • Run the installer twice, once for the public wiki and once for the private wiki. For best security, have the installer create separate db users for each wiki
  • Do not use the "LocalSettings.php" the installer generates, instead use a "LocalSettings.php" like:
<?php
wfLoadExtension( 'SplitPrivateWiki' );
SplitPrivateWiki::setup( [
	'private' => [
		'wgDBname' => 'secretwiki',
		'wgDBuser' => 'secretwikiuser',
		'wgDBpass' => 'secretwikipassword',
		'wgSitename' => 'Secret',
		'wgScriptPath' => '/secret',
		'wgArticlePath' => '/secret/index.php?title=$1',
		'wgExclusiveNamespaces' => [
			NS_MAIN,
			NS_TALK
		],
	],
	'public' => [
		'wgDBname' => 'publicwiki',
		'wgDBuser' => 'publicwikiuser',
		'wgDBpass' => 'publicwikipassword',
		'wgSitename' => 'Public',
		'wgScriptPath' => '/w',
		'wgArticlePath' => '/w/index.php?title=$1',
		'wgExclusiveNamespaces' => [
			NS_HELP,
			NS_HELP_TALK
		],
	],
	'common' => [
		'wgServer' => 'http://localhost:8080',
		'wgShowExceptionDetails' => true,
		'wgShowDBErrorBacktrace' => true,
		'wgDBserver' => '127.0.0.1',
	]
] );

// Extensions for both wikis
wfLoadExtension( 'foo' );
// If you want an extension on only one of the wikis
if ( $wgDBname === 'secretwiki' ) {
  wfLoadExtension( 'Bar' );
}
  • Changing the above of course to your specifics. It is important that either wgServer or wgScriptPath is different between the two wikis or else it won't be able to detect when you are in the secret wiki
  • $wgExclusiveNamespaces should have the namespaces for each wiki that are exclusively handled by that wiki (and auto copied over to the other wiki). Do not include any namespaces here that are in $wgBuiltinNamespacesToRename. If you add custom namespaces you also have to add to wgExtraNamespaces.
  • $wgBuiltinNamespacesToRename - contains a list of builtin namespaces that we want on both wikis, so that get renamed. e.g. MediaWiki becomes MediaWiki_(Public).
  • You would probably want to change the various rights here so that only certain groups have read rights on the private wiki.
  • Run update.php --wiki=secretwiki and update.php --wiki=publicwiki

Things should now just work.

Configuration parameters

edit

Listed here are default values for config vars.

Namespaces handled exclusively on one wiki. Namespaces here will be autoredirected. Any namespaces here in the public wiki will be copied over to the private wiki.

$wgExclusiveNamespaces = [];

Namespaces to be in both and be renamed. Dummy versions of the renamed namespaces will be added on the other wiki to ensure redirects work. The public wiki will also have the renamed namespace copied over to the dummy version on the private wiki:

$wgBuiltinNamespacesToRename = [ 
        NS_SPECIAL,
        NS_USER,
        NS_USER_TALK,
        NS_CATEGORY,
        NS_CATEGORY_TALK,
        NS_MEDIAWIKI,
        NS_MEDIAWIKI_TALK
];

Should sync edits show up in recentchanges (true = yes, false = no, 'bot' = show up but marked as bot). Note, currently this doesn't work with page deletions properly

$wgSplitWikiShowInRc = 'bot';

Notes

edit
  • For best security, the public wiki db user should not have access to the secret wiki db
  • Use of different subdomains is reccomended for better isolation in case of XSS
  • This extension was inspired by a conversation I had at EMWCon with Richard Evans.

Todo

edit
  • Make page deletions be bot edits
  • Should also setup foreignFileRepoViaLB since this only copies page contents not files
  • How user pages should work is kind of iffy, maybe it should be something like Extension:GlobalUserPage Allowing people to override, but copying a fake copy by default(?)
  • Should set up single sign on automatically.
  • page moves are kind of handled hackily

Bug reports and feature requests

edit

Please report bugs and feature requests on the talk page.

See also

edit