Skip to content

Commit

Permalink
primaryKey on circles_membership
Browse files Browse the repository at this point in the history
Signed-off-by: Maxence Lange <maxence@artificial-owl.com>
  • Loading branch information
ArtificialOwl committed Mar 18, 2022
1 parent b1b6b3c commit 0d6fc18
Show file tree
Hide file tree
Showing 4 changed files with 100 additions and 33 deletions.
1 change: 0 additions & 1 deletion lib/Migration/Version0023Date20211216113101.php
Original file line number Diff line number Diff line change
Expand Up @@ -47,5 +47,4 @@ class Version0023Date20211216113101 extends SimpleMigrationStep {
*/
public function __construct(IDBConnection $connection) {
}

}
5 changes: 2 additions & 3 deletions lib/Migration/Version0024Date20220203123901.php
Original file line number Diff line number Diff line change
Expand Up @@ -69,8 +69,8 @@ public function changeSchema(IOutput $output, Closure $schemaClosure, array $opt
$table = $schema->getTable('circles_token');
$table->changeColumn(
'password', [
'length' => 127
]
'length' => 127
]
);
}

Expand Down Expand Up @@ -105,5 +105,4 @@ public function changeSchema(IOutput $output, Closure $schemaClosure, array $opt

return $schema;
}

}
57 changes: 28 additions & 29 deletions lib/Migration/Version0024Date20220203123902.php
Original file line number Diff line number Diff line change
Expand Up @@ -64,67 +64,66 @@ public function changeSchema(IOutput $output, Closure $schemaClosure, array $opt
$table = $schema->createTable('circles_event');
$table->addColumn(
'token', 'string', [
'notnull' => false,
'length' => 63,
]
'notnull' => false,
'length' => 63,
]
);
$table->addColumn(
'event', 'text', [
'notnull' => false
]
'notnull' => false
]
);
$table->addColumn(
'result', 'text', [
'notnull' => false
]
'notnull' => false
]
);
$table->addColumn(
'instance', 'string', [
'length' => 255,
'notnull' => false
]
'length' => 255,
'notnull' => false
]
);
$table->addColumn(
'interface', 'integer', [
'notnull' => true,
'length' => 1,
'default' => 0
]
'notnull' => true,
'length' => 1,
'default' => 0
]
);
$table->addColumn(
'severity', 'integer', [
'length' => 3,
'notnull' => false
]
'length' => 3,
'notnull' => false
]
);
$table->addColumn(
'retry', 'integer', [
'length' => 3,
'notnull' => false
]
'length' => 3,
'notnull' => false
]
);
$table->addColumn(
'status', 'integer', [
'length' => 3,
'notnull' => false
]
'length' => 3,
'notnull' => false
]
);
$table->addColumn(
'updated', 'datetime', [
'notnull' => false,
]
'notnull' => false,
]
);
$table->addColumn(
'creation', 'bigint', [
'length' => 14,
'notnull' => false
]
'length' => 14,
'notnull' => false
]
);

$table->setPrimaryKey(['token', 'instance']);
}

return $schema;
}

}
70 changes: 70 additions & 0 deletions lib/Migration/Version0024Date20220317190331.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
<?php

declare(strict_types=1);


/**
* Circles - Bring cloud-users closer together.
*
* This file is licensed under the Affero General Public License version 3 or
* later. See the COPYING file.
*
* @author Maxence Lange <maxence@artificial-owl.com>
* @copyright 2022
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/


namespace OCA\Circles\Migration;

use Closure;
use Doctrine\DBAL\Schema\SchemaException;
use OCP\DB\ISchemaWrapper;
use OCP\Migration\IOutput;
use OCP\Migration\SimpleMigrationStep;

class Version0024Date20220317190331 extends SimpleMigrationStep {

/**
* @param IOutput $output
* @param Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper`
* @param array $options
*
* @return null|ISchemaWrapper
* @throws SchemaException
*/
public function changeSchema(IOutput $output, Closure $schemaClosure, array $options): ?ISchemaWrapper {
/** @var ISchemaWrapper $schema */
$schema = $schemaClosure();

if ($schema->hasTable('circles_membership')) {
$table = $schema->getTable('circles_membership');
if (!$table->hasPrimaryKey()) {
$indexes = $table->getIndexes();
// conflict in Oracle with existing unique index, duplicate of primaryKey.
foreach ($indexes as $index) {
if ($index->isUnique()) {
$table->dropIndex($index->getName());
}
}
$table->setPrimaryKey(['single_id', 'circle_id']);
}
}

return $schema;
}
}

0 comments on commit 0d6fc18

Please sign in to comment.