Merge "Use MediaWiki\SuppressWarnings around trigger_error('') instead @"
[lhc/web/wiklou.git] / maintenance / install.php
1 <?php
2 /**
3 * CLI-based MediaWiki installation and configuration.
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 * http://www.gnu.org/copyleft/gpl.html
19 *
20 * @file
21 * @ingroup Maintenance
22 */
23
24 require_once __DIR__ . '/Maintenance.php';
25
26 define( 'MW_CONFIG_CALLBACK', 'Installer::overrideConfig' );
27 define( 'MEDIAWIKI_INSTALL', true );
28
29 /**
30 * Maintenance script to install and configure MediaWiki
31 *
32 * Default values for the options are defined in DefaultSettings.php
33 * (see the mapping in CliInstaller.php)
34 * Default for --dbpath (SQLite-specific) is defined in SqliteInstaller::getGlobalDefaults
35 *
36 * @ingroup Maintenance
37 */
38 class CommandLineInstaller extends Maintenance {
39 function __construct() {
40 parent::__construct();
41 global $IP;
42
43 $this->addDescription( "CLI-based MediaWiki installation and configuration.\n" .
44 "Default options are indicated in parentheses." );
45
46 $this->addArg( 'name', 'The name of the wiki (MediaWiki)', false );
47
48 $this->addArg( 'admin', 'The username of the wiki administrator.' );
49 $this->addOption( 'pass', 'The password for the wiki administrator.', false, true );
50 $this->addOption(
51 'passfile',
52 'An alternative way to provide pass option, as the contents of this file',
53 false,
54 true
55 );
56 /* $this->addOption( 'email', 'The email for the wiki administrator', false, true ); */
57 $this->addOption(
58 'scriptpath',
59 'The relative path of the wiki in the web server (/wiki)',
60 false,
61 true
62 );
63
64 $this->addOption( 'lang', 'The language to use (en)', false, true );
65 /* $this->addOption( 'cont-lang', 'The content language (en)', false, true ); */
66
67 $this->addOption( 'dbtype', 'The type of database (mysql)', false, true );
68 $this->addOption( 'dbserver', 'The database host (localhost)', false, true );
69 $this->addOption( 'dbport', 'The database port; only for PostgreSQL (5432)', false, true );
70 $this->addOption( 'dbname', 'The database name (my_wiki)', false, true );
71 $this->addOption( 'dbpath', 'The path for the SQLite DB ($IP/data)', false, true );
72 $this->addOption( 'dbprefix', 'Optional database table name prefix', false, true );
73 $this->addOption( 'installdbuser', 'The user to use for installing (root)', false, true );
74 $this->addOption( 'installdbpass', 'The password for the DB user to install as.', false, true );
75 $this->addOption( 'dbuser', 'The user to use for normal operations (wikiuser)', false, true );
76 $this->addOption( 'dbpass', 'The password for the DB user for normal operations', false, true );
77 $this->addOption(
78 'dbpassfile',
79 'An alternative way to provide dbpass option, as the contents of this file',
80 false,
81 true
82 );
83 $this->addOption( 'confpath', "Path to write LocalSettings.php to ($IP)", false, true );
84 $this->addOption( 'dbschema', 'The schema for the MediaWiki DB in '
85 . 'PostgreSQL/Microsoft SQL Server (mediawiki)', false, true );
86 /*
87 $this->addOption( 'namespace', 'The project namespace (same as the "name" argument)',
88 false, true );
89 */
90 $this->addOption( 'env-checks', "Run environment checks only, don't change anything" );
91
92 $this->addOption( 'with-extensions', "Detect and include extensions" );
93 $this->addOption( 'extensions', 'Comma-separated list of extensions to install',
94 false, true, false, true );
95 $this->addOption( 'skins', 'Comma-separated list of skins to install (default: all)',
96 false, true, false, true );
97 }
98
99 public function getDbType() {
100 if ( $this->hasOption( 'env-checks' ) ) {
101 return Maintenance::DB_NONE;
102 }
103 return parent::getDbType();
104 }
105
106 function execute() {
107 global $IP;
108
109 $siteName = $this->getArg( 0, 'MediaWiki' ); // Will not be set if used with --env-checks
110 $adminName = $this->getArg( 1 );
111 $envChecksOnly = $this->hasOption( 'env-checks' );
112
113 $this->setDbPassOption();
114 if ( !$envChecksOnly ) {
115 $this->setPassOption();
116 }
117
118 $installer = InstallerOverrides::getCliInstaller( $siteName, $adminName, $this->mOptions );
119
120 $status = $installer->doEnvironmentChecks();
121 if ( $status->isGood() ) {
122 $installer->showMessage( 'config-env-good' );
123 } else {
124 $installer->showStatusMessage( $status );
125
126 return;
127 }
128 if ( !$envChecksOnly ) {
129 $installer->execute();
130 $installer->writeConfigurationFile( $this->getOption( 'confpath', $IP ) );
131 }
132 }
133
134 private function setDbPassOption() {
135 $dbpassfile = $this->getOption( 'dbpassfile' );
136 if ( $dbpassfile !== null ) {
137 if ( $this->getOption( 'dbpass' ) !== null ) {
138 $this->error( 'WARNING: You have provided the options "dbpass" and "dbpassfile". '
139 . 'The content of "dbpassfile" overrides "dbpass".' );
140 }
141 Wikimedia\suppressWarnings();
142 $dbpass = file_get_contents( $dbpassfile ); // returns false on failure
143 Wikimedia\restoreWarnings();
144 if ( $dbpass === false ) {
145 $this->fatalError( "Couldn't open $dbpassfile" );
146 }
147 $this->mOptions['dbpass'] = trim( $dbpass, "\r\n" );
148 }
149 }
150
151 private function setPassOption() {
152 $passfile = $this->getOption( 'passfile' );
153 if ( $passfile !== null ) {
154 if ( $this->getOption( 'pass' ) !== null ) {
155 $this->error( 'WARNING: You have provided the options "pass" and "passfile". '
156 . 'The content of "passfile" overrides "pass".' );
157 }
158 Wikimedia\suppressWarnings();
159 $pass = file_get_contents( $passfile ); // returns false on failure
160 Wikimedia\restoreWarnings();
161 if ( $pass === false ) {
162 $this->fatalError( "Couldn't open $passfile" );
163 }
164 $this->mOptions['pass'] = trim( $pass, "\r\n" );
165 } elseif ( $this->getOption( 'pass' ) === null ) {
166 $this->fatalError( 'You need to provide the option "pass" or "passfile"' );
167 }
168 }
169
170 function validateParamsAndArgs() {
171 if ( !$this->hasOption( 'env-checks' ) ) {
172 parent::validateParamsAndArgs();
173 }
174 }
175 }
176
177 $maintClass = CommandLineInstaller::class;
178
179 require_once RUN_MAINTENANCE_IF_MAIN;