X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Finstaller.php;h=ff7677dc7d86ba03ef06499d1946c7c5adddd5c0;hb=3326b7b850f538f0e3c2c7969c5e566e2a374ffb;hp=9a167618f7db42e8b4069ee759f32e39859833c2;hpb=c909f351d07c50c433cd59fef00f41a67767ce9e;p=quix0rs-gnu-social.git diff --git a/lib/installer.php b/lib/installer.php index 9a167618f7..ff7677dc7d 100644 --- a/lib/installer.php +++ b/lib/installer.php @@ -96,12 +96,12 @@ abstract class Installer } } - if (version_compare(PHP_VERSION, '5.3.2', '<')) { - $this->warning('Require PHP version 5.3.2 or greater.'); + if (version_compare(PHP_VERSION, '5.5.0', '<')) { + $this->warning('Require PHP version 5.5.0 or greater.'); $pass = false; } - $reqs = array('gd', 'curl', 'json', + $reqs = array('gd', 'curl', 'intl', 'json', 'xmlwriter', 'mbstring', 'xml', 'dom', 'simplexml'); foreach ($reqs as $req) { @@ -133,10 +133,16 @@ abstract class Installer } // Check the subdirs used for file uploads - $fileSubdirs = array('avatar', 'background', 'file'); + $fileSubdirs = array('avatar', 'file'); foreach ($fileSubdirs as $fileSubdir) { - $fileFullPath = INSTALLDIR."/$fileSubdir/"; - if (!is_writable($fileFullPath)) { + $fileFullPath = INSTALLDIR."/$fileSubdir"; + if (!file_exists($fileFullPath)) { + $pass = $pass && mkdir($fileFullPath); + } elseif (!is_dir($fileFullPath)) { + $this->warning(sprintf('GNU social expected a directory but found something else on this path: %s', $fileFullPath), + 'Either make sure it goes to a directory or remove it and a directory will be created.'); + $pass = false; + } elseif (!is_writable($fileFullPath)) { $this->warning(sprintf('Cannot write to %s directory: %s', $fileSubdir, $fileFullPath), sprintf('On your server, try this command: chmod a+w %s', $fileFullPath)); $pass = false; @@ -224,7 +230,7 @@ abstract class Installer } // @fixme hardcoded list; should use Nickname::isValid() // if/when it's safe to have loaded the infrastructure here - $blacklist = array('main', 'panel', 'twitter', 'settings', 'rsd.xml', 'favorited', 'featured', 'favoritedrss', 'featuredrss', 'rss', 'getfile', 'api', 'groups', 'group', 'peopletag', 'tag', 'user', 'message', 'conversation', 'notice', 'attachment', 'search', 'index.php', 'doc', 'opensearch', 'robots.txt', 'xd_receiver.html', 'facebook'); + $blacklist = array('main', 'panel', 'twitter', 'settings', 'rsd.xml', 'favorited', 'featured', 'favoritedrss', 'featuredrss', 'rss', 'getfile', 'api', 'groups', 'group', 'peopletag', 'tag', 'user', 'message', 'conversation', 'notice', 'attachment', 'search', 'index.php', 'doc', 'opensearch', 'robots.txt', 'xd_receiver.html', 'facebook', 'activity'); if (in_array($this->adminNick, $blacklist)) { $this->updateStatus('The user nickname "' . htmlspecialchars($this->adminNick) . '" is reserved.', true); @@ -427,7 +433,11 @@ abstract class Installer // database "\$config['db']['database'] = {$vals['db_database']};\n\n". ($this->db['type'] == 'pgsql' ? "\$config['db']['quote_identifiers'] = true;\n\n":''). - "\$config['db']['type'] = {$vals['db_type']};\n\n"; + "\$config['db']['type'] = {$vals['db_type']};\n\n". + + "// Uncomment below for better performance. Just remember you must run\n". + "// php scripts/checkschema.php whenever your enabled plugins change!\n". + "//\$config['db']['schemacheck'] = 'script';\n\n"; // Normalize line endings for Windows servers $cfg = str_replace("\n", PHP_EOL, $cfg); @@ -516,9 +526,9 @@ abstract class Installer if ($this->adminEmail) { $data['email'] = $this->adminEmail; } - $user = User::register($data); - - if (empty($user)) { + try { + $user = User::register($data, true); // true to skip email sending verification + } catch (Exception $e) { return false; } @@ -554,7 +564,7 @@ abstract class Installer } require_once INSTALLDIR . '/lib/framework.php'; - StatusNet::initDefaults($this->server, $this->path); + GNUsocial::initDefaults($this->server, $this->path); if ($this->siteProfile == "singleuser") { // Until we use ['site']['profile']==='singleuser' everywhere @@ -621,7 +631,7 @@ abstract class Installer $this->updateStatus("GNU social has been installed at $link"); $this->updateStatus( - 'DONE! You can visit your new GNU social site (log in as "'.htmlspecialchars($this->adminNick).'"). If this is your first GNU social install, make your experience the best possible by visiting our resource site to join the mailing list and good documentation.' + 'DONE! You can visit your new GNU social site (log in as "'.htmlspecialchars($this->adminNick).'"). If this is your first GNU social install, make your experience the best possible by visiting our resource site to join the mailing list or IRC. FAQ is found here.' ); return true;