12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- <?php
- declare(strict_types=1);
- namespace OCA\User_LDAP\Migration;
- use Closure;
- use OCP\DB\ISchemaWrapper;
- use OCP\DB\Types;
- use OCP\Migration\IOutput;
- class Version1130Date20220110154718 extends GroupMappingMigration {
- public function getName() {
- return 'Copy ldap_group_mapping data from backup table and if needed';
- }
-
- public function changeSchema(IOutput $output, Closure $schemaClosure, array $options): ?ISchemaWrapper {
-
- $schema = $schemaClosure();
- if (!$schema->hasTable('ldap_group_mapping_backup')) {
-
- return null;
- }
- $table = $schema->createTable('ldap_group_mapping');
- $table->addColumn('ldap_dn', Types::STRING, [
- 'notnull' => true,
- 'length' => 4000,
- 'default' => '',
- ]);
- $table->addColumn('owncloud_name', Types::STRING, [
- 'notnull' => true,
- 'length' => 64,
- 'default' => '',
- ]);
- $table->addColumn('directory_uuid', Types::STRING, [
- 'notnull' => true,
- 'length' => 255,
- 'default' => '',
- ]);
- $table->addColumn('ldap_dn_hash', Types::STRING, [
- 'notnull' => false,
- 'length' => 64,
- ]);
- $table->setPrimaryKey(['owncloud_name']);
- $table->addUniqueIndex(['ldap_dn_hash'], 'ldap_group_dn_hashes');
- $table->addUniqueIndex(['directory_uuid'], 'ldap_group_directory_uuid');
- return $schema;
- }
-
- public function postSchemaChange(IOutput $output, Closure $schemaClosure, array $options) {
-
- $schema = $schemaClosure();
- if (!$schema->hasTable('ldap_group_mapping_backup')) {
-
- return;
- }
- $output->startProgress();
- $this->copyGroupMappingData('ldap_group_mapping_backup', 'ldap_group_mapping');
- $output->finishProgress();
- }
- }
|