owncloud/core

View on GitHub
apps/files_sharing/appinfo/Migrations/Version20170804201125.php

Summary

Maintainability
A
2 hrs
Test Coverage
<?php

namespace OCA\Files_Sharing\Migrations;
use Doctrine\DBAL\Schema\Schema;
use OCP\Migration\ISchemaMigration;

/** Creates initial schema */
class Version20170804201125 implements ISchemaMigration {
    public function changeSchema(Schema $schema, array $options) {
        $prefix = $options['tablePrefix'];
        if (!$schema->hasTable("{$prefix}share_external")) {
            $table = $schema->createTable("{$prefix}share_external");
            $table->addColumn('id', 'bigint', [
                'autoincrement' => true,
                'unsigned' => false,
                'notnull' => true,
                'length' => 11,
            ]);

            $table->addColumn('remote', 'string', [
                'notnull' => true,
                'length' => 512,
                'default' => null,
                'comment' => 'Url of the remote owncloud instance'
            ]);

            $table->addColumn('remote_id', 'bigint', [
                'unsigned' => false,
                'notnull' => true,
                'default' => -1,
                'length' => 11,
            ]);

            $table->addColumn('share_token', 'string', [
                'length' => 64,
                'notnull' => true,
                'comment' => 'Public share token'
            ]);

            $table->addColumn('password', 'string', [
                'length' => 64,
                'notnull' => false,
                'default' => null,
                'comment' => 'Optional password for the public share'
            ]);

            $table->addColumn('name', 'string', [
                'length' => 64,
                'notnull' => true,
                'comment' => 'Original name on the remote server'
            ]);

            $table->addColumn('owner', 'string', [
                'length' => 64,
                'notnull' => true,
                'comment' => 'User that owns the public share on the remote server'
            ]);

            $table->addColumn('user', 'string', [
                'length' => 64,
                'notnull' => true,
                'comment' => 'Local user which added the external share'
            ]);

            $table->addColumn('mountpoint', 'string', [
                'length' => 4000,
                'notnull' => true,
                'comment' => 'Full path where the share is mounted'
            ]);

            $table->addColumn('mountpoint_hash', 'string', [
                'length' => 32,
                'notnull' => true,
                'comment' => 'md5 hash of the mountpoint'
            ]);

            $table->addColumn('accepted', 'integer', [
                'notnull' => true,
                'default' => 0,
            ]);

            $table->setPrimaryKey(['id']);

            $table->addIndex(
                ['user'],
                'sh_external_user'
            );
            $table->addUniqueIndex(
                ['user', 'mountpoint_hash'],
                'sh_external_mp'
            );
        }
    }
}