| @@ -35,107 +35,107 @@ | ||
| 35 | 35 | */ | 
| 36 | 36 |  class RemoveRootShares implements IRepairStep { | 
| 37 | 37 | |
| 38 | - /** @var IDBConnection */ | |
| 39 | - protected $connection; | |
| 40 | - | |
| 41 | - /** @var IUserManager */ | |
| 42 | - protected $userManager; | |
| 43 | - | |
| 44 | - /** @var IRootFolder */ | |
| 45 | - protected $rootFolder; | |
| 46 | - | |
| 47 | - /** | |
| 48 | - * RemoveRootShares constructor. | |
| 49 | - * | |
| 50 | - * @param IDBConnection $connection | |
| 51 | - * @param IUserManager $userManager | |
| 52 | - * @param IRootFolder $rootFolder | |
| 53 | - */ | |
| 54 | - public function __construct(IDBConnection $connection, | |
| 55 | - IUserManager $userManager, | |
| 56 | -								IRootFolder $rootFolder) { | |
| 57 | - $this->connection = $connection; | |
| 58 | - $this->userManager = $userManager; | |
| 59 | - $this->rootFolder = $rootFolder; | |
| 60 | - } | |
| 61 | - | |
| 62 | - /** | |
| 63 | - * @return string | |
| 64 | - */ | |
| 65 | -	public function getName() { | |
| 66 | - return 'Remove shares of a users root folder'; | |
| 67 | - } | |
| 68 | - | |
| 69 | - /** | |
| 70 | - * @param IOutput $output | |
| 71 | - */ | |
| 72 | -	public function run(IOutput $output) { | |
| 73 | -		if ($this->rootSharesExist()) { | |
| 74 | - $this->removeRootShares($output); | |
| 75 | - } | |
| 76 | - } | |
| 77 | - | |
| 78 | - /** | |
| 79 | - * @param IOutput $output | |
| 80 | - */ | |
| 81 | -	private function removeRootShares(IOutput $output) { | |
| 82 | -		$function = function(IUser $user) use ($output) { | |
| 83 | - $userFolder = $this->rootFolder->getUserFolder($user->getUID()); | |
| 84 | - $fileId = $userFolder->getId(); | |
| 85 | - | |
| 86 | - $qb = $this->connection->getQueryBuilder(); | |
| 87 | -			$qb->delete('share') | |
| 88 | -				->where($qb->expr()->eq('file_source', $qb->createNamedParameter($fileId))) | |
| 89 | - ->andWhere($qb->expr()->orX( | |
| 90 | -					$qb->expr()->eq('item_type', $qb->expr()->literal('file')), | |
| 91 | -					$qb->expr()->eq('item_type', $qb->expr()->literal('folder')) | |
| 92 | - )); | |
| 93 | - | |
| 94 | - $qb->execute(); | |
| 95 | - | |
| 96 | - $output->advance(); | |
| 97 | - }; | |
| 98 | - | |
| 99 | - $output->startProgress($this->userManager->countSeenUsers()); | |
| 100 | - | |
| 101 | - $this->userManager->callForSeenUsers($function); | |
| 102 | - | |
| 103 | - $output->finishProgress(); | |
| 104 | - } | |
| 105 | - | |
| 106 | - /** | |
| 107 | - * Verify if this repair steps is required | |
| 108 | - * It *should* not be necessary in most cases and it can be very | |
| 109 | - * costly. | |
| 110 | - * | |
| 111 | - * @return bool | |
| 112 | - */ | |
| 113 | -	private function rootSharesExist() { | |
| 114 | - $qb = $this->connection->getQueryBuilder(); | |
| 115 | - $qb2 = $this->connection->getQueryBuilder(); | |
| 116 | - | |
| 117 | -		$qb->select('fileid') | |
| 118 | -			->from('filecache') | |
| 119 | -			->where($qb->expr()->eq('path', $qb->expr()->literal('files'))); | |
| 120 | - | |
| 121 | -		$qb2->select('id') | |
| 122 | -			->from('share') | |
| 123 | -			->where($qb2->expr()->in('file_source', $qb2->createFunction($qb->getSQL()))) | |
| 124 | - ->andWhere($qb2->expr()->orX( | |
| 125 | -				$qb2->expr()->eq('item_type', $qb->expr()->literal('file')), | |
| 126 | -				$qb2->expr()->eq('item_type', $qb->expr()->literal('folder')) | |
| 127 | - )) | |
| 128 | - ->setMaxResults(1); | |
| 129 | - | |
| 130 | - $cursor = $qb2->execute(); | |
| 131 | - $data = $cursor->fetch(); | |
| 132 | - $cursor->closeCursor(); | |
| 133 | - | |
| 134 | -		if ($data === false) { | |
| 135 | - return false; | |
| 136 | - } | |
| 137 | - | |
| 138 | - return true; | |
| 139 | - } | |
| 38 | + /** @var IDBConnection */ | |
| 39 | + protected $connection; | |
| 40 | + | |
| 41 | + /** @var IUserManager */ | |
| 42 | + protected $userManager; | |
| 43 | + | |
| 44 | + /** @var IRootFolder */ | |
| 45 | + protected $rootFolder; | |
| 46 | + | |
| 47 | + /** | |
| 48 | + * RemoveRootShares constructor. | |
| 49 | + * | |
| 50 | + * @param IDBConnection $connection | |
| 51 | + * @param IUserManager $userManager | |
| 52 | + * @param IRootFolder $rootFolder | |
| 53 | + */ | |
| 54 | + public function __construct(IDBConnection $connection, | |
| 55 | + IUserManager $userManager, | |
| 56 | +                                IRootFolder $rootFolder) { | |
| 57 | + $this->connection = $connection; | |
| 58 | + $this->userManager = $userManager; | |
| 59 | + $this->rootFolder = $rootFolder; | |
| 60 | + } | |
| 61 | + | |
| 62 | + /** | |
| 63 | + * @return string | |
| 64 | + */ | |
| 65 | +    public function getName() { | |
| 66 | + return 'Remove shares of a users root folder'; | |
| 67 | + } | |
| 68 | + | |
| 69 | + /** | |
| 70 | + * @param IOutput $output | |
| 71 | + */ | |
| 72 | +    public function run(IOutput $output) { | |
| 73 | +        if ($this->rootSharesExist()) { | |
| 74 | + $this->removeRootShares($output); | |
| 75 | + } | |
| 76 | + } | |
| 77 | + | |
| 78 | + /** | |
| 79 | + * @param IOutput $output | |
| 80 | + */ | |
| 81 | +    private function removeRootShares(IOutput $output) { | |
| 82 | +        $function = function(IUser $user) use ($output) { | |
| 83 | + $userFolder = $this->rootFolder->getUserFolder($user->getUID()); | |
| 84 | + $fileId = $userFolder->getId(); | |
| 85 | + | |
| 86 | + $qb = $this->connection->getQueryBuilder(); | |
| 87 | +            $qb->delete('share') | |
| 88 | +                ->where($qb->expr()->eq('file_source', $qb->createNamedParameter($fileId))) | |
| 89 | + ->andWhere($qb->expr()->orX( | |
| 90 | +                    $qb->expr()->eq('item_type', $qb->expr()->literal('file')), | |
| 91 | +                    $qb->expr()->eq('item_type', $qb->expr()->literal('folder')) | |
| 92 | + )); | |
| 93 | + | |
| 94 | + $qb->execute(); | |
| 95 | + | |
| 96 | + $output->advance(); | |
| 97 | + }; | |
| 98 | + | |
| 99 | + $output->startProgress($this->userManager->countSeenUsers()); | |
| 100 | + | |
| 101 | + $this->userManager->callForSeenUsers($function); | |
| 102 | + | |
| 103 | + $output->finishProgress(); | |
| 104 | + } | |
| 105 | + | |
| 106 | + /** | |
| 107 | + * Verify if this repair steps is required | |
| 108 | + * It *should* not be necessary in most cases and it can be very | |
| 109 | + * costly. | |
| 110 | + * | |
| 111 | + * @return bool | |
| 112 | + */ | |
| 113 | +    private function rootSharesExist() { | |
| 114 | + $qb = $this->connection->getQueryBuilder(); | |
| 115 | + $qb2 = $this->connection->getQueryBuilder(); | |
| 116 | + | |
| 117 | +        $qb->select('fileid') | |
| 118 | +            ->from('filecache') | |
| 119 | +            ->where($qb->expr()->eq('path', $qb->expr()->literal('files'))); | |
| 120 | + | |
| 121 | +        $qb2->select('id') | |
| 122 | +            ->from('share') | |
| 123 | +            ->where($qb2->expr()->in('file_source', $qb2->createFunction($qb->getSQL()))) | |
| 124 | + ->andWhere($qb2->expr()->orX( | |
| 125 | +                $qb2->expr()->eq('item_type', $qb->expr()->literal('file')), | |
| 126 | +                $qb2->expr()->eq('item_type', $qb->expr()->literal('folder')) | |
| 127 | + )) | |
| 128 | + ->setMaxResults(1); | |
| 129 | + | |
| 130 | + $cursor = $qb2->execute(); | |
| 131 | + $data = $cursor->fetch(); | |
| 132 | + $cursor->closeCursor(); | |
| 133 | + | |
| 134 | +        if ($data === false) { | |
| 135 | + return false; | |
| 136 | + } | |
| 137 | + | |
| 138 | + return true; | |
| 139 | + } | |
| 140 | 140 | } | 
| 141 | 141 | |
| @@ -28,53 +28,53 @@ | ||
| 28 | 28 | |
| 29 | 29 |  class MoveUpdaterStepFile implements IRepairStep { | 
| 30 | 30 | |
| 31 | - /** @var \OCP\IConfig */ | |
| 32 | - protected $config; | |
| 31 | + /** @var \OCP\IConfig */ | |
| 32 | + protected $config; | |
| 33 | 33 | |
| 34 | - /** | |
| 35 | - * @param \OCP\IConfig $config | |
| 36 | - */ | |
| 37 | -	public function __construct($config) { | |
| 38 | - $this->config = $config; | |
| 39 | - } | |
| 34 | + /** | |
| 35 | + * @param \OCP\IConfig $config | |
| 36 | + */ | |
| 37 | +    public function __construct($config) { | |
| 38 | + $this->config = $config; | |
| 39 | + } | |
| 40 | 40 | |
| 41 | -	public function getName() { | |
| 42 | - return 'Move .step file of updater to backup location'; | |
| 43 | - } | |
| 41 | +    public function getName() { | |
| 42 | + return 'Move .step file of updater to backup location'; | |
| 43 | + } | |
| 44 | 44 | |
| 45 | -	public function run(IOutput $output) { | |
| 45 | +    public function run(IOutput $output) { | |
| 46 | 46 | |
| 47 | -		$dataDir = $this->config->getSystemValue('datadirectory', \OC::$SERVERROOT . '/data'); | |
| 48 | -		$instanceId = $this->config->getSystemValue('instanceid', null); | |
| 47 | +        $dataDir = $this->config->getSystemValue('datadirectory', \OC::$SERVERROOT . '/data'); | |
| 48 | +        $instanceId = $this->config->getSystemValue('instanceid', null); | |
| 49 | 49 | |
| 50 | -		if(!is_string($instanceId) || empty($instanceId)) { | |
| 51 | - return; | |
| 52 | - } | |
| 50 | +        if(!is_string($instanceId) || empty($instanceId)) { | |
| 51 | + return; | |
| 52 | + } | |
| 53 | 53 | |
| 54 | - $updaterFolderPath = $dataDir . '/updater-' . $instanceId; | |
| 55 | - $stepFile = $updaterFolderPath . '/.step'; | |
| 56 | -		if(file_exists($stepFile)) { | |
| 57 | -			$output->info('.step file exists'); | |
| 54 | + $updaterFolderPath = $dataDir . '/updater-' . $instanceId; | |
| 55 | + $stepFile = $updaterFolderPath . '/.step'; | |
| 56 | +        if(file_exists($stepFile)) { | |
| 57 | +            $output->info('.step file exists'); | |
| 58 | 58 | |
| 59 | - $previousStepFile = $updaterFolderPath . '/.step-previous-update'; | |
| 59 | + $previousStepFile = $updaterFolderPath . '/.step-previous-update'; | |
| 60 | 60 | |
| 61 | - // cleanup | |
| 62 | -			if(file_exists($previousStepFile)) { | |
| 63 | -				if(\OC_Helper::rmdirr($previousStepFile)) { | |
| 64 | -					$output->info('.step-previous-update removed'); | |
| 65 | -				} else { | |
| 66 | -					$output->info('.step-previous-update can\'t be removed - abort move of .step file'); | |
| 67 | - return; | |
| 68 | - } | |
| 69 | - } | |
| 61 | + // cleanup | |
| 62 | +            if(file_exists($previousStepFile)) { | |
| 63 | +                if(\OC_Helper::rmdirr($previousStepFile)) { | |
| 64 | +                    $output->info('.step-previous-update removed'); | |
| 65 | +                } else { | |
| 66 | +                    $output->info('.step-previous-update can\'t be removed - abort move of .step file'); | |
| 67 | + return; | |
| 68 | + } | |
| 69 | + } | |
| 70 | 70 | |
| 71 | - // move step file | |
| 72 | -			if(rename($stepFile, $previousStepFile)) { | |
| 73 | -				$output->info('.step file moved to .step-previous-update'); | |
| 74 | -			} else { | |
| 75 | -				$output->warning('.step file can\'t be moved'); | |
| 76 | - } | |
| 77 | - } | |
| 78 | - } | |
| 71 | + // move step file | |
| 72 | +            if(rename($stepFile, $previousStepFile)) { | |
| 73 | +                $output->info('.step file moved to .step-previous-update'); | |
| 74 | +            } else { | |
| 75 | +                $output->warning('.step file can\'t be moved'); | |
| 76 | + } | |
| 77 | + } | |
| 78 | + } | |
| 79 | 79 | } | 
| 80 | 80 | |
| @@ -29,50 +29,50 @@ | ||
| 29 | 29 | |
| 30 | 30 |  class FixMountStorages implements IRepairStep { | 
| 31 | 31 | |
| 32 | - /** @var IDBConnection */ | |
| 33 | - private $db; | |
| 32 | + /** @var IDBConnection */ | |
| 33 | + private $db; | |
| 34 | 34 | |
| 35 | - /** | |
| 36 | - * @param IDBConnection $db | |
| 37 | - */ | |
| 38 | -	public function __construct(IDBConnection $db) { | |
| 39 | - $this->db = $db; | |
| 40 | - } | |
| 35 | + /** | |
| 36 | + * @param IDBConnection $db | |
| 37 | + */ | |
| 38 | +    public function __construct(IDBConnection $db) { | |
| 39 | + $this->db = $db; | |
| 40 | + } | |
| 41 | 41 | |
| 42 | - /** | |
| 43 | - * @return string | |
| 44 | - */ | |
| 45 | -	public function getName() { | |
| 46 | - return 'Fix potential broken mount points'; | |
| 47 | - } | |
| 42 | + /** | |
| 43 | + * @return string | |
| 44 | + */ | |
| 45 | +    public function getName() { | |
| 46 | + return 'Fix potential broken mount points'; | |
| 47 | + } | |
| 48 | 48 | |
| 49 | -	public function run(IOutput $output) { | |
| 50 | - $query = $this->db->getQueryBuilder(); | |
| 51 | -		$query->select('m.id', 'f.storage') | |
| 52 | -			->from('mounts', 'm') | |
| 53 | -			->leftJoin('m', 'filecache', 'f', $query->expr()->eq('m.root_id', 'f.fileid')) | |
| 54 | -			->where($query->expr()->neq('m.storage_id', 'f.storage')); | |
| 49 | +    public function run(IOutput $output) { | |
| 50 | + $query = $this->db->getQueryBuilder(); | |
| 51 | +        $query->select('m.id', 'f.storage') | |
| 52 | +            ->from('mounts', 'm') | |
| 53 | +            ->leftJoin('m', 'filecache', 'f', $query->expr()->eq('m.root_id', 'f.fileid')) | |
| 54 | +            ->where($query->expr()->neq('m.storage_id', 'f.storage')); | |
| 55 | 55 | |
| 56 | - $update = $this->db->getQueryBuilder(); | |
| 57 | -		$update->update('mounts') | |
| 58 | -			->set('storage_id', $update->createParameter('storage')) | |
| 59 | -			->where($query->expr()->eq('id', $update->createParameter('mount'))); | |
| 56 | + $update = $this->db->getQueryBuilder(); | |
| 57 | +        $update->update('mounts') | |
| 58 | +            ->set('storage_id', $update->createParameter('storage')) | |
| 59 | +            ->where($query->expr()->eq('id', $update->createParameter('mount'))); | |
| 60 | 60 | |
| 61 | - $result = $query->execute(); | |
| 62 | - $entriesUpdated = 0; | |
| 63 | -		while ($row = $result->fetch()) { | |
| 64 | -			$update->setParameter('storage', $row['storage'], IQueryBuilder::PARAM_INT) | |
| 65 | -				->setParameter('mount', $row['id'], IQueryBuilder::PARAM_INT); | |
| 66 | - $update->execute(); | |
| 67 | - $entriesUpdated++; | |
| 68 | - } | |
| 69 | - $result->closeCursor(); | |
| 61 | + $result = $query->execute(); | |
| 62 | + $entriesUpdated = 0; | |
| 63 | +        while ($row = $result->fetch()) { | |
| 64 | +            $update->setParameter('storage', $row['storage'], IQueryBuilder::PARAM_INT) | |
| 65 | +                ->setParameter('mount', $row['id'], IQueryBuilder::PARAM_INT); | |
| 66 | + $update->execute(); | |
| 67 | + $entriesUpdated++; | |
| 68 | + } | |
| 69 | + $result->closeCursor(); | |
| 70 | 70 | |
| 71 | -		if ($entriesUpdated > 0) { | |
| 72 | - $output->info($entriesUpdated . ' mounts updated'); | |
| 73 | - return; | |
| 74 | - } | |
| 71 | +        if ($entriesUpdated > 0) { | |
| 72 | + $output->info($entriesUpdated . ' mounts updated'); | |
| 73 | + return; | |
| 74 | + } | |
| 75 | 75 | |
| 76 | -		$output->info('No mounts updated'); | |
| 77 | - } | |
| 76 | +        $output->info('No mounts updated'); | |
| 77 | + } | |
| 78 | 78 | } | 
| @@ -36,66 +36,66 @@ | ||
| 36 | 36 | * altered in order to retrigger SQL schema generation through OCSqlitePlatform. | 
| 37 | 37 | */ | 
| 38 | 38 |  class SqliteAutoincrement implements IRepairStep { | 
| 39 | - /** | |
| 40 | - * @var \OC\DB\Connection | |
| 41 | - */ | |
| 42 | - protected $connection; | |
| 39 | + /** | |
| 40 | + * @var \OC\DB\Connection | |
| 41 | + */ | |
| 42 | + protected $connection; | |
| 43 | 43 | |
| 44 | - /** | |
| 45 | - * @param \OC\DB\Connection $connection | |
| 46 | - */ | |
| 47 | -	public function __construct($connection) { | |
| 48 | - $this->connection = $connection; | |
| 49 | - } | |
| 44 | + /** | |
| 45 | + * @param \OC\DB\Connection $connection | |
| 46 | + */ | |
| 47 | +    public function __construct($connection) { | |
| 48 | + $this->connection = $connection; | |
| 49 | + } | |
| 50 | 50 | |
| 51 | -	public function getName() { | |
| 52 | - return 'Repair SQLite autoincrement'; | |
| 53 | - } | |
| 51 | +    public function getName() { | |
| 52 | + return 'Repair SQLite autoincrement'; | |
| 53 | + } | |
| 54 | 54 | |
| 55 | - /** | |
| 56 | - * Fix mime types | |
| 57 | - */ | |
| 58 | -	public function run(IOutput $out) { | |
| 59 | -		if (!$this->connection->getDatabasePlatform() instanceof SqlitePlatform) { | |
| 60 | - return; | |
| 61 | - } | |
| 55 | + /** | |
| 56 | + * Fix mime types | |
| 57 | + */ | |
| 58 | +    public function run(IOutput $out) { | |
| 59 | +        if (!$this->connection->getDatabasePlatform() instanceof SqlitePlatform) { | |
| 60 | + return; | |
| 61 | + } | |
| 62 | 62 | |
| 63 | - $sourceSchema = $this->connection->getSchemaManager()->createSchema(); | |
| 63 | + $sourceSchema = $this->connection->getSchemaManager()->createSchema(); | |
| 64 | 64 | |
| 65 | - $schemaDiff = new SchemaDiff(); | |
| 65 | + $schemaDiff = new SchemaDiff(); | |
| 66 | 66 | |
| 67 | -		foreach ($sourceSchema->getTables() as $tableSchema) { | |
| 68 | - $primaryKey = $tableSchema->getPrimaryKey(); | |
| 69 | -			if (!$primaryKey) { | |
| 70 | - continue; | |
| 71 | - } | |
| 67 | +        foreach ($sourceSchema->getTables() as $tableSchema) { | |
| 68 | + $primaryKey = $tableSchema->getPrimaryKey(); | |
| 69 | +            if (!$primaryKey) { | |
| 70 | + continue; | |
| 71 | + } | |
| 72 | 72 | |
| 73 | - $columnNames = $primaryKey->getColumns(); | |
| 73 | + $columnNames = $primaryKey->getColumns(); | |
| 74 | 74 | |
| 75 | - // add a column diff for every primary key column, | |
| 76 | - // but do not actually change anything, this will | |
| 77 | - // force the generation of SQL statements to alter | |
| 78 | - // those tables, which will then trigger the | |
| 79 | - // specific SQL code from OCSqlitePlatform | |
| 80 | -			try { | |
| 81 | - $tableDiff = new TableDiff($tableSchema->getName()); | |
| 82 | - $tableDiff->fromTable = $tableSchema; | |
| 83 | -				foreach ($columnNames as $columnName) { | |
| 84 | - $columnSchema = $tableSchema->getColumn($columnName); | |
| 85 | - $columnDiff = new ColumnDiff($columnSchema->getName(), $columnSchema); | |
| 86 | - $tableDiff->changedColumns[] = $columnDiff; | |
| 87 | - $schemaDiff->changedTables[] = $tableDiff; | |
| 88 | - } | |
| 89 | -			} catch (SchemaException $e) { | |
| 90 | - // ignore | |
| 91 | - } | |
| 92 | - } | |
| 75 | + // add a column diff for every primary key column, | |
| 76 | + // but do not actually change anything, this will | |
| 77 | + // force the generation of SQL statements to alter | |
| 78 | + // those tables, which will then trigger the | |
| 79 | + // specific SQL code from OCSqlitePlatform | |
| 80 | +            try { | |
| 81 | + $tableDiff = new TableDiff($tableSchema->getName()); | |
| 82 | + $tableDiff->fromTable = $tableSchema; | |
| 83 | +                foreach ($columnNames as $columnName) { | |
| 84 | + $columnSchema = $tableSchema->getColumn($columnName); | |
| 85 | + $columnDiff = new ColumnDiff($columnSchema->getName(), $columnSchema); | |
| 86 | + $tableDiff->changedColumns[] = $columnDiff; | |
| 87 | + $schemaDiff->changedTables[] = $tableDiff; | |
| 88 | + } | |
| 89 | +            } catch (SchemaException $e) { | |
| 90 | + // ignore | |
| 91 | + } | |
| 92 | + } | |
| 93 | 93 | |
| 94 | - $this->connection->beginTransaction(); | |
| 95 | -		foreach ($schemaDiff->toSql($this->connection->getDatabasePlatform()) as $sql) { | |
| 96 | - $this->connection->query($sql); | |
| 97 | - } | |
| 98 | - $this->connection->commit(); | |
| 99 | - } | |
| 94 | + $this->connection->beginTransaction(); | |
| 95 | +        foreach ($schemaDiff->toSql($this->connection->getDatabasePlatform()) as $sql) { | |
| 96 | + $this->connection->query($sql); | |
| 97 | + } | |
| 98 | + $this->connection->commit(); | |
| 99 | + } | |
| 100 | 100 | } | 
| 101 | 101 | |
| @@ -29,28 +29,28 @@ | ||
| 29 | 29 | use Doctrine\DBAL\Schema\Table; | 
| 30 | 30 | |
| 31 | 31 |  class MySQLMigrator extends Migrator { | 
| 32 | - /** | |
| 33 | - * @param Schema $targetSchema | |
| 34 | - * @param \Doctrine\DBAL\Connection $connection | |
| 35 | - * @return \Doctrine\DBAL\Schema\SchemaDiff | |
| 36 | - */ | |
| 37 | -	protected function getDiff(Schema $targetSchema, \Doctrine\DBAL\Connection $connection) { | |
| 38 | - $platform = $connection->getDatabasePlatform(); | |
| 39 | -		$platform->registerDoctrineTypeMapping('enum', 'string'); | |
| 40 | -		$platform->registerDoctrineTypeMapping('bit', 'string'); | |
| 32 | + /** | |
| 33 | + * @param Schema $targetSchema | |
| 34 | + * @param \Doctrine\DBAL\Connection $connection | |
| 35 | + * @return \Doctrine\DBAL\Schema\SchemaDiff | |
| 36 | + */ | |
| 37 | +    protected function getDiff(Schema $targetSchema, \Doctrine\DBAL\Connection $connection) { | |
| 38 | + $platform = $connection->getDatabasePlatform(); | |
| 39 | +        $platform->registerDoctrineTypeMapping('enum', 'string'); | |
| 40 | +        $platform->registerDoctrineTypeMapping('bit', 'string'); | |
| 41 | 41 | |
| 42 | - $schemaDiff = parent::getDiff($targetSchema, $connection); | |
| 42 | + $schemaDiff = parent::getDiff($targetSchema, $connection); | |
| 43 | 43 | |
| 44 | - // identifiers need to be quoted for mysql | |
| 45 | -		foreach ($schemaDiff->changedTables as $tableDiff) { | |
| 46 | - $tableDiff->name = $this->connection->quoteIdentifier($tableDiff->name); | |
| 47 | -			foreach ($tableDiff->changedColumns as $column) { | |
| 48 | - $column->oldColumnName = $this->connection->quoteIdentifier($column->oldColumnName); | |
| 49 | - } | |
| 50 | - } | |
| 44 | + // identifiers need to be quoted for mysql | |
| 45 | +        foreach ($schemaDiff->changedTables as $tableDiff) { | |
| 46 | + $tableDiff->name = $this->connection->quoteIdentifier($tableDiff->name); | |
| 47 | +            foreach ($tableDiff->changedColumns as $column) { | |
| 48 | + $column->oldColumnName = $this->connection->quoteIdentifier($column->oldColumnName); | |
| 49 | + } | |
| 50 | + } | |
| 51 | 51 | |
| 52 | - return $schemaDiff; | |
| 53 | - } | |
| 52 | + return $schemaDiff; | |
| 53 | + } | |
| 54 | 54 | |
| 55 | 55 | /** | 
| 56 | 56 | * Speed up migration test by disabling autocommit and unique indexes check | 
| @@ -23,27 +23,27 @@ | ||
| 23 | 23 | namespace OC\DB; | 
| 24 | 24 | |
| 25 | 25 |  class OCSqlitePlatform extends \Doctrine\DBAL\Platforms\SqlitePlatform { | 
| 26 | - /** | |
| 27 | -	 * {@inheritDoc} | |
| 28 | - */ | |
| 29 | -	public function getColumnDeclarationSQL($name, array $field) { | |
| 30 | - $def = parent::getColumnDeclarationSQL($name, $field); | |
| 31 | -		if (!empty($field['autoincrement'])) { | |
| 32 | - $def .= ' PRIMARY KEY AUTOINCREMENT'; | |
| 33 | - } | |
| 34 | - return $def; | |
| 35 | - } | |
| 26 | + /** | |
| 27 | +     * {@inheritDoc} | |
| 28 | + */ | |
| 29 | +    public function getColumnDeclarationSQL($name, array $field) { | |
| 30 | + $def = parent::getColumnDeclarationSQL($name, $field); | |
| 31 | +        if (!empty($field['autoincrement'])) { | |
| 32 | + $def .= ' PRIMARY KEY AUTOINCREMENT'; | |
| 33 | + } | |
| 34 | + return $def; | |
| 35 | + } | |
| 36 | 36 | |
| 37 | - /** | |
| 38 | -	 * {@inheritDoc} | |
| 39 | - */ | |
| 40 | -	protected function _getCreateTableSQL($name, array $columns, array $options = array()){ | |
| 41 | - // if auto increment is set the column is already defined as primary key | |
| 42 | -		foreach ($columns as $column) { | |
| 43 | -			if (!empty($column['autoincrement'])) { | |
| 44 | - $options['primary'] = null; | |
| 45 | - } | |
| 46 | - } | |
| 47 | - return parent::_getCreateTableSQL($name, $columns, $options); | |
| 48 | - } | |
| 37 | + /** | |
| 38 | +     * {@inheritDoc} | |
| 39 | + */ | |
| 40 | +    protected function _getCreateTableSQL($name, array $columns, array $options = array()){ | |
| 41 | + // if auto increment is set the column is already defined as primary key | |
| 42 | +        foreach ($columns as $column) { | |
| 43 | +            if (!empty($column['autoincrement'])) { | |
| 44 | + $options['primary'] = null; | |
| 45 | + } | |
| 46 | + } | |
| 47 | + return parent::_getCreateTableSQL($name, $columns, $options); | |
| 48 | + } | |
| 49 | 49 | } | 
| @@ -25,17 +25,17 @@ | ||
| 25 | 25 | use OCP\DB\QueryBuilder\IQueryFunction; | 
| 26 | 26 | |
| 27 | 27 |  class QueryFunction implements IQueryFunction { | 
| 28 | - /** @var string */ | |
| 29 | - protected $function; | |
| 28 | + /** @var string */ | |
| 29 | + protected $function; | |
| 30 | 30 | |
| 31 | -	public function __construct($function) { | |
| 32 | - $this->function = $function; | |
| 33 | - } | |
| 31 | +    public function __construct($function) { | |
| 32 | + $this->function = $function; | |
| 33 | + } | |
| 34 | 34 | |
| 35 | - /** | |
| 36 | - * @return string | |
| 37 | - */ | |
| 38 | -	public function __toString() { | |
| 39 | - return (string) $this->function; | |
| 40 | - } | |
| 35 | + /** | |
| 36 | + * @return string | |
| 37 | + */ | |
| 38 | +    public function __toString() { | |
| 39 | + return (string) $this->function; | |
| 40 | + } | |
| 41 | 41 | } | 
| @@ -25,69 +25,69 @@ | ||
| 25 | 25 | use OCP\DB\QueryBuilder\ICompositeExpression; | 
| 26 | 26 | |
| 27 | 27 |  class CompositeExpression implements ICompositeExpression, \Countable { | 
| 28 | - /** @var \Doctrine\DBAL\Query\Expression\CompositeExpression */ | |
| 29 | - protected $compositeExpression; | |
| 28 | + /** @var \Doctrine\DBAL\Query\Expression\CompositeExpression */ | |
| 29 | + protected $compositeExpression; | |
| 30 | 30 | |
| 31 | - /** | |
| 32 | - * Constructor. | |
| 33 | - * | |
| 34 | - * @param \Doctrine\DBAL\Query\Expression\CompositeExpression $compositeExpression | |
| 35 | - */ | |
| 36 | -	public function __construct(\Doctrine\DBAL\Query\Expression\CompositeExpression $compositeExpression) { | |
| 37 | - $this->compositeExpression = $compositeExpression; | |
| 38 | - } | |
| 31 | + /** | |
| 32 | + * Constructor. | |
| 33 | + * | |
| 34 | + * @param \Doctrine\DBAL\Query\Expression\CompositeExpression $compositeExpression | |
| 35 | + */ | |
| 36 | +    public function __construct(\Doctrine\DBAL\Query\Expression\CompositeExpression $compositeExpression) { | |
| 37 | + $this->compositeExpression = $compositeExpression; | |
| 38 | + } | |
| 39 | 39 | |
| 40 | - /** | |
| 41 | - * Adds multiple parts to composite expression. | |
| 42 | - * | |
| 43 | - * @param array $parts | |
| 44 | - * | |
| 45 | - * @return \OCP\DB\QueryBuilder\ICompositeExpression | |
| 46 | - */ | |
| 47 | -	public function addMultiple(array $parts = array()) { | |
| 48 | - $this->compositeExpression->addMultiple($parts); | |
| 40 | + /** | |
| 41 | + * Adds multiple parts to composite expression. | |
| 42 | + * | |
| 43 | + * @param array $parts | |
| 44 | + * | |
| 45 | + * @return \OCP\DB\QueryBuilder\ICompositeExpression | |
| 46 | + */ | |
| 47 | +    public function addMultiple(array $parts = array()) { | |
| 48 | + $this->compositeExpression->addMultiple($parts); | |
| 49 | 49 | |
| 50 | - return $this; | |
| 51 | - } | |
| 50 | + return $this; | |
| 51 | + } | |
| 52 | 52 | |
| 53 | - /** | |
| 54 | - * Adds an expression to composite expression. | |
| 55 | - * | |
| 56 | - * @param mixed $part | |
| 57 | - * | |
| 58 | - * @return \OCP\DB\QueryBuilder\ICompositeExpression | |
| 59 | - */ | |
| 60 | -	public function add($part) { | |
| 61 | - $this->compositeExpression->add($part); | |
| 53 | + /** | |
| 54 | + * Adds an expression to composite expression. | |
| 55 | + * | |
| 56 | + * @param mixed $part | |
| 57 | + * | |
| 58 | + * @return \OCP\DB\QueryBuilder\ICompositeExpression | |
| 59 | + */ | |
| 60 | +    public function add($part) { | |
| 61 | + $this->compositeExpression->add($part); | |
| 62 | 62 | |
| 63 | - return $this; | |
| 64 | - } | |
| 63 | + return $this; | |
| 64 | + } | |
| 65 | 65 | |
| 66 | - /** | |
| 67 | - * Retrieves the amount of expressions on composite expression. | |
| 68 | - * | |
| 69 | - * @return integer | |
| 70 | - */ | |
| 71 | -	public function count() { | |
| 72 | - return $this->compositeExpression->count(); | |
| 73 | - } | |
| 66 | + /** | |
| 67 | + * Retrieves the amount of expressions on composite expression. | |
| 68 | + * | |
| 69 | + * @return integer | |
| 70 | + */ | |
| 71 | +    public function count() { | |
| 72 | + return $this->compositeExpression->count(); | |
| 73 | + } | |
| 74 | 74 | |
| 75 | - /** | |
| 76 | - * Returns the type of this composite expression (AND/OR). | |
| 77 | - * | |
| 78 | - * @return string | |
| 79 | - */ | |
| 80 | -	public function getType() { | |
| 81 | - return $this->compositeExpression->getType(); | |
| 82 | - } | |
| 75 | + /** | |
| 76 | + * Returns the type of this composite expression (AND/OR). | |
| 77 | + * | |
| 78 | + * @return string | |
| 79 | + */ | |
| 80 | +    public function getType() { | |
| 81 | + return $this->compositeExpression->getType(); | |
| 82 | + } | |
| 83 | 83 | |
| 84 | - /** | |
| 85 | - * Retrieves the string representation of this composite expression. | |
| 86 | - * | |
| 87 | - * @return string | |
| 88 | - */ | |
| 89 | - public function __toString() | |
| 90 | -	{ | |
| 91 | - return (string) $this->compositeExpression; | |
| 92 | - } | |
| 84 | + /** | |
| 85 | + * Retrieves the string representation of this composite expression. | |
| 86 | + * | |
| 87 | + * @return string | |
| 88 | + */ | |
| 89 | + public function __toString() | |
| 90 | +    { | |
| 91 | + return (string) $this->compositeExpression; | |
| 92 | + } | |
| 93 | 93 | } | 
| @@ -25,17 +25,17 @@ | ||
| 25 | 25 | use OCP\DB\QueryBuilder\ILiteral; | 
| 26 | 26 | |
| 27 | 27 |  class Literal implements ILiteral{ | 
| 28 | - /** @var mixed */ | |
| 29 | - protected $literal; | |
| 28 | + /** @var mixed */ | |
| 29 | + protected $literal; | |
| 30 | 30 | |
| 31 | -	public function __construct($literal) { | |
| 32 | - $this->literal = $literal; | |
| 33 | - } | |
| 31 | +    public function __construct($literal) { | |
| 32 | + $this->literal = $literal; | |
| 33 | + } | |
| 34 | 34 | |
| 35 | - /** | |
| 36 | - * @return string | |
| 37 | - */ | |
| 38 | -	public function __toString() { | |
| 39 | - return (string) $this->literal; | |
| 40 | - } | |
| 35 | + /** | |
| 36 | + * @return string | |
| 37 | + */ | |
| 38 | +    public function __toString() { | |
| 39 | + return (string) $this->literal; | |
| 40 | + } | |
| 41 | 41 | } |