* Make it configurable.

svn path=/nixos/trunk/; revision=18778
This commit is contained in:
Eelco Dolstra 2009-12-03 08:44:54 +00:00
parent 81c3454cdb
commit c7e0a7b31c
1 changed files with 76 additions and 69 deletions

View File

@ -37,13 +37,19 @@ let
$wgDebugLogFile = "/tmp/mediawiki_debug_log.txt";
# Database configuration.
$wgDBtype = "postgres";
$wgDBserver = "";
$wgDBuser = "wwwrun";
$wgDBname = "mediawiki";
$wgDBtype = "${config.dbType}";
$wgDBserver = "${config.dbServer}";
$wgDBuser = "${config.dbUser}";
$wgDBpassword = "${config.dbPassword}";
$wgDBname = "${config.dbName}";
$wgEmergencyContact = "${serverInfo.serverConfig.adminAddr}";
$wgPasswordSender = $wgEmergencyContact;
# E-mail.
$wgEmergencyContact = "${config.emergencyContact}";
$wgPasswordSender = "${config.passwordSender}";
$wgSitename = "${config.siteName}";
${config.extraConfig}
?>
'';
@ -83,79 +89,65 @@ in
options = {
/*
dbName = mkOption {
example = "wikidb";
default = "wikidb";
description = "
Name of the wiki database that holds MediaWiki data.
";
};
dbEmergencyContact = mkOption {
example = "admin@example.com";
default = "e.dolstra@tudelft.nl";
description = "
In case of emergency, contact this e-mail.
";
};
dbPasswordSender = mkOption {
example = "passwordrecovery@example.com";
default = "e.dolstra@tudelft.nl";
description = "
From which e-mail the recovery password for database users will be sent
";
};
dbType = mkOption {
default = "postgres";
example = "mysql";
default = "mysql";
description = "
Which type of database should be used
";
description = "Database type.";
};
dbName = mkOption {
default = "mediawiki";
description = "Name of the database that holds the MediaWiki data.";
};
dbServer = mkOption {
default = ""; # use a Unix domain socket
example = "10.0.2.2";
default = "10.0.2.2";
description = "
The location of the database server, e.g. localhost or remote ip address.
";
};
dbPortNumber = mkOption {
example = "3306";
default = "3306";
description = "
Portnumber used to connect to the database server. Default: 3306.
";
description = ''
The location of the database server. Leave empty to use a
database server running on the same machine through a Unix
domain socket.
'';
};
dbUser = mkOption {
example = "root";
default = "root";
description = "
The username for accessing the database.
";
default = "wwwrun";
example = "mediawiki";
description = "The user name for accessing the database.";
};
dbPassword = mkOption {
example = "foobar";
default = "";
description = "
The dbUser's password.
";
example = "foobar";
description = ''
The password of the database user. Warning: this is stored in
cleartext in the Nix store!
'';
};
dbSiteName = mkOption {
example = "wikipedia";
default = "wiki";
description = "
Name of the wiki site.
";
emergencyContact = mkOption {
default = serverInfo.serverConfig.adminAddr;
example = "admin@example.com";
description = ''
Emergency contact e-mail address. Defaults to the Apache
admin address.
'';
};
passwordSender = mkOption {
default = serverInfo.serverConfig.adminAddr;
example = "password@example.com";
description = ''
E-mail address from which password confirmations originate.
Defaults to the Apache admin address.
'';
};
siteName = mkOption {
default = "MediaWiki";
example = "Foobar Wiki";
description = "Name of the wiki";
};
*/
urlPrefix = mkOption {
example = "/wiki";
@ -165,14 +157,29 @@ in
'';
};
extraConfig = mkOption {
default = "";
example =
''
$wgEnableEmail = false;
'';
description = ''
Any additional text to be appended to MediaWiki's
configuration file. This is a PHP script. For configuration
settings, see <link xlink:href='http://www.mediawiki.org/wiki/Manual:Configuration_settings'/>.
'';
};
};
startupScript = pkgs.writeScript "mediawiki_startup.sh"
''
if ! ${pkgs.postgresql}/bin/psql -l | grep -q ' mediawiki ' ; then
${pkgs.postgresql}/bin/createuser --no-superuser --no-createdb --no-createrole wwwrun || true
${pkgs.postgresql}/bin/createdb mediawiki -O wwwrun
${pkgs.su}/bin/su -s ${pkgs.stdenv.shell} wwwrun -c "(echo 'CREATE LANGUAGE plpgsql;'; cat /nix/store/q9gdf3f4362yhsdi8inlhpk26d9b8af6-mediawiki-1.15.1/maintenance/postgres/tables.sql; echo 'CREATE TEXT SEARCH CONFIGURATION public.default ( COPY = pg_catalog.english );'; echo COMMIT) | ${pkgs.postgresql}/bin/psql mediawiki"
# Initialise the database automagically if we're using a Postgres
# server on localhost.
(optionalString (config.dbType == "postgres" && config.dbServer == "") ''
if ! ${pkgs.postgresql}/bin/psql -l | grep -q ' ${config.dbName} ' ; then
${pkgs.postgresql}/bin/createuser --no-superuser --no-createdb --no-createrole "${config.dbUser}" || true
${pkgs.postgresql}/bin/createdb "${config.dbName}" -O "${config.dbUser}"
${pkgs.su}/bin/su -s ${pkgs.stdenv.shell} "${config.dbUser}" -c "(echo 'CREATE LANGUAGE plpgsql;'; cat ${mediawikiRoot}/maintenance/postgres/tables.sql; echo 'CREATE TEXT SEARCH CONFIGURATION public.default ( COPY = pg_catalog.english );'; echo COMMIT) | ${pkgs.postgresql}/bin/psql ${config.dbName}"
fi
'';
'');
}