Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/matomo-org/matomo.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'core/Updates/3.0.0-b4.php')
-rw-r--r--core/Updates/3.0.0-b4.php99
1 files changed, 99 insertions, 0 deletions
diff --git a/core/Updates/3.0.0-b4.php b/core/Updates/3.0.0-b4.php
new file mode 100644
index 0000000000..cb6568e28f
--- /dev/null
+++ b/core/Updates/3.0.0-b4.php
@@ -0,0 +1,99 @@
+<?php
+/**
+ * Piwik - free/libre analytics platform
+ *
+ * @link http://piwik.org
+ * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
+ *
+ */
+
+namespace Piwik\Updates;
+
+use Piwik\Common;
+use Piwik\Db;
+use Piwik\Plugins\Installation\ServerFilesGenerator;
+use Piwik\Updater;
+use Piwik\Updater\Migration;
+use Piwik\Updater\Migration\Factory as MigrationFactory;
+use Piwik\Updates;
+
+class Updates_3_0_0_b4 extends Updates
+{
+ /**
+ * @var MigrationFactory
+ */
+ private $migration;
+
+ /**
+ * @var string
+ */
+ private $userTable = 'user';
+
+ public function __construct(MigrationFactory $factory)
+ {
+ $this->migration = $factory;
+ }
+
+ /**
+ * Here you can define one or multiple SQL statements that should be executed during the update.
+ * @param Updater $updater
+ * @return Migration[]
+ */
+ public function getMigrations(Updater $updater)
+ {
+ $migrations = [];
+ $migrations = $this->getUserDatabaseMigrations($migrations);
+
+ return $migrations;
+ }
+
+
+ public function doUpdate(Updater $updater)
+ {
+ $updater->executeMigrations(__FILE__, $this->getMigrations($updater));
+ $updater->executeMigrations(__FILE__, $this->getUserPasswordMigrations([]));
+
+ ServerFilesGenerator::createFilesForSecurity();
+ }
+
+ /**
+ * Returns database migrations for this update.
+ * @param Migration[] $queries
+ * @return Migration[]
+ */
+ private function getUserDatabaseMigrations($queries)
+ {
+ $queries[] = $this->migration->db->changeColumn($this->userTable, 'password', 'password', 'VARCHAR(255) NOT NULL');
+
+ return $queries;
+ }
+
+ /**
+ * Returns migrations to hash existing password with bcrypt.
+ * @param Migration[] $queries
+ * @return Migration[]
+ */
+ private function getUserPasswordMigrations($queries)
+ {
+ $db = Db::get();
+ $userTable = Common::prefixTable($this->userTable);
+
+ $users = $db->fetchAll(
+ 'SELECT `login`, `password` FROM `' . $userTable . '` WHERE LENGTH(`password`) = 32'
+ );
+
+ foreach ($users as $user) {
+ $queries[] = $this->migration->db->boundSql(
+ 'UPDATE `' . $userTable . '`'
+ . ' SET `password` = ?'
+ . ' WHERE `login` = ?',
+ [
+ password_hash($user['password'], PASSWORD_BCRYPT),
+ $user['login'],
+ ]
+ );
+ }
+
+ return $queries;
+ }
+}