AnonSec Team
Server IP : 103.11.96.170  /  Your IP : 3.142.135.246
Web Server : Microsoft-IIS/10.0
System : Windows NT WIN-F6SLGVICLOP 10.0 build 17763 (Windows Server 2016) AMD64
User : elibrary.unsap.ac.id ( 0)
PHP Version : 7.4.19
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : OFF  |  Perl : OFF  |  Python : OFF
Directory (0777) :  D:/localhost/ejournal_unsap/classes/migration/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : D:/localhost/ejournal_unsap/classes/migration/OJSMigration.inc.php
<?php

/**
 * @file classes/migration/OJSMigration.inc.php
 *
 * Copyright (c) 2014-2021 Simon Fraser University
 * Copyright (c) 2000-2021 John Willinsky
 * Distributed under the GNU GPL v3. For full terms see the file docs/COPYING.
 *
 * @class OJSMigration
 * @brief Describe database table structures.
 */

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Builder;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Capsule\Manager as Capsule;

class OJSMigration extends Migration {
        /**
         * Run the migrations.
         * @return void
         */
        public function up() {
		// Journals and basic journal settings.
		Capsule::schema()->create('journals', function (Blueprint $table) {
			$table->bigInteger('journal_id')->autoIncrement();
			$table->string('path', 32);
			$table->float('seq', 8, 2)->default(0)->comment('Used to order lists of journals');
			$table->string('primary_locale', 14);
			$table->smallInteger('enabled')->default(1)->comment('Controls whether or not the journal is considered "live" and will appear on the website. (Note that disabled journals may still be accessible, but only if the user knows the URL.)');
			$table->unique(['path'], 'journals_path');
		});

		// Journal settings.
		Capsule::schema()->create('journal_settings', function (Blueprint $table) {
			$table->bigInteger('journal_id');
			$table->string('locale', 14)->default('');
			$table->string('setting_name', 255);
			$table->mediumText('setting_value')->nullable();
			$table->string('setting_type', 6)->nullable();
			$table->index(['journal_id'], 'journal_settings_journal_id');
			$table->unique(['journal_id', 'locale', 'setting_name'], 'journal_settings_pkey');
		});

		// Journal sections.
		Capsule::schema()->create('sections', function (Blueprint $table) {
			$table->bigInteger('section_id')->autoIncrement();
			$table->bigInteger('journal_id');
			$table->bigInteger('review_form_id')->nullable();
			$table->float('seq', 8, 2)->default(0);
			$table->smallInteger('editor_restricted')->default(0);
			$table->smallInteger('meta_indexed')->default(0);
			$table->smallInteger('meta_reviewed')->default(1);
			$table->smallInteger('abstracts_not_required')->default(0);
			$table->smallInteger('hide_title')->default(0);
			$table->smallInteger('hide_author')->default(0);
			$table->smallInteger('is_inactive')->default(0);
			$table->bigInteger('abstract_word_count')->nullable();
			$table->index(['journal_id'], 'sections_journal_id');
		});

		// Section-specific settings
		Capsule::schema()->create('section_settings', function (Blueprint $table) {
			$table->bigInteger('section_id');
			$table->string('locale', 14)->default('');
			$table->string('setting_name', 255);
			$table->text('setting_value')->nullable();
			$table->string('setting_type', 6)->comment('(bool|int|float|string|object)');
			$table->index(['section_id'], 'section_settings_section_id');
			$table->unique(['section_id', 'locale', 'setting_name'], 'section_settings_pkey');
		});

		// Journal issues.
		Capsule::schema()->create('issues', function (Blueprint $table) {
			$table->bigInteger('issue_id')->autoIncrement();
			$table->bigInteger('journal_id');
			$table->smallInteger('volume')->nullable();
			$table->string('number', 40)->nullable();
			$table->smallInteger('year')->nullable();
			$table->smallInteger('published')->default(0);
			$table->smallInteger('current')->default(0);
			$table->datetime('date_published')->nullable();
			$table->datetime('date_notified')->nullable();
			$table->datetime('last_modified')->nullable();
			$table->smallInteger('access_status')->default(1);
			$table->datetime('open_access_date')->nullable();
			$table->smallInteger('show_volume')->default(0);
			$table->smallInteger('show_number')->default(0);
			$table->smallInteger('show_year')->default(0);
			$table->smallInteger('show_title')->default(0);
			$table->string('style_file_name', 90)->nullable();
			$table->string('original_style_file_name', 255)->nullable();
			$table->string('url_path', 64)->nullable();
			$table->index(['journal_id'], 'issues_journal_id');
			$table->index(['url_path'], 'issues_url_path');
		});

		// Locale-specific issue data
		Capsule::schema()->create('issue_settings', function (Blueprint $table) {
			$table->bigInteger('issue_id');
			$table->string('locale', 14)->default('');
			$table->string('setting_name', 255);
			$table->text('setting_value')->nullable();
			$table->string('setting_type', 6);
			$table->index(['issue_id'], 'issue_settings_issue_id');
			$table->unique(['issue_id', 'locale', 'setting_name'], 'issue_settings_pkey');
		});
		// Add partial index (DBMS-specific)
		switch (Capsule::connection()->getDriverName()) {
			case 'mysql': Capsule::connection()->unprepared('CREATE INDEX issue_settings_name_value ON issue_settings (setting_name(50), setting_value(150))'); break;
			case 'pgsql': Capsule::connection()->unprepared("CREATE INDEX issue_settings_name_value ON issue_settings (setting_name, setting_value) WHERE setting_name IN ('medra::registeredDoi', 'datacite::registeredDoi')"); break;
		}

		// Issue galleys.
		Capsule::schema()->create('issue_galleys', function (Blueprint $table) {
			$table->bigInteger('galley_id')->autoIncrement();
			$table->string('locale', 14)->nullable();
			$table->bigInteger('issue_id');
			$table->bigInteger('file_id');
			$table->string('label', 32)->nullable();
			$table->float('seq', 8, 2)->default(0);
			$table->string('url_path', 64)->nullable();
			$table->index(['issue_id'], 'issue_galleys_issue_id');
			$table->index(['url_path'], 'issue_galleys_url_path');
		});

		// Issue galley metadata.
		Capsule::schema()->create('issue_galley_settings', function (Blueprint $table) {
			$table->bigInteger('galley_id');
			$table->string('locale', 14)->default('');
			$table->string('setting_name', 255);
			$table->text('setting_value')->nullable();
			$table->string('setting_type', 6)->comment('(bool|int|float|string|object)');
			$table->index(['galley_id'], 'issue_galley_settings_galley_id');
			$table->unique(['galley_id', 'locale', 'setting_name'], 'issue_galley_settings_pkey');
		});

		Capsule::schema()->create('issue_files', function (Blueprint $table) {
			$table->bigInteger('file_id')->autoIncrement();
			$table->bigInteger('issue_id');
			$table->string('file_name', 90);
			$table->string('file_type', 255);
			$table->bigInteger('file_size');
			$table->bigInteger('content_type');
			$table->string('original_file_name', 127)->nullable();
			$table->datetime('date_uploaded');
			$table->datetime('date_modified');
			$table->index(['issue_id'], 'issue_files_issue_id');
		});

		// Custom sequencing information for journal issues, when available
		Capsule::schema()->create('custom_issue_orders', function (Blueprint $table) {
			$table->bigInteger('issue_id');
			$table->bigInteger('journal_id');
			$table->float('seq', 8, 2)->default(0);
			$table->unique(['issue_id'], 'custom_issue_orders_pkey');
		});

		// Custom sequencing information for journal sections by issue, when available.
		Capsule::schema()->create('custom_section_orders', function (Blueprint $table) {
			$table->bigInteger('issue_id');
			$table->bigInteger('section_id');
			$table->float('seq', 8, 2)->default(0);
			$table->unique(['issue_id', 'section_id'], 'custom_section_orders_pkey');
		});

		// Archived, removed from TOC, unscheduled or unpublished journal articles.
		Capsule::schema()->create('submission_tombstones', function (Blueprint $table) {
			$table->bigInteger('tombstone_id')->autoIncrement();
			$table->bigInteger('submission_id');
			$table->datetime('date_deleted');
			$table->bigInteger('journal_id');
			$table->bigInteger('section_id');
			$table->string('set_spec', 255);
			$table->string('set_name', 255);
			$table->string('oai_identifier', 255);
			$table->index(['journal_id'], 'submission_tombstones_journal_id');
			$table->index(['submission_id'], 'submission_tombstones_submission_id');
		});

		// Publications
		Capsule::schema()->create('publications', function (Blueprint $table) {
			$table->bigInteger('publication_id')->autoIncrement();
			$table->bigInteger('access_status')->default(0)->nullable();
			$table->date('date_published')->nullable();
			$table->datetime('last_modified')->nullable();
			$table->string('locale', 14)->nullable();
			$table->bigInteger('primary_contact_id')->nullable();
			$table->bigInteger('section_id')->nullable();
			$table->float('seq', 8, 2)->default(0);
			$table->bigInteger('submission_id');
			$table->smallInteger('status')->default(1); // STATUS_QUEUED
			$table->string('url_path', 64)->nullable();
			$table->bigInteger('version')->nullable();
			$table->index(['submission_id'], 'publications_submission_id');
			$table->index(['section_id'], 'publications_section_id');
			$table->index(['url_path'], 'publications_url_path');
		});

		// Publication galleys
		Capsule::schema()->create('publication_galleys', function (Blueprint $table) {
			$table->bigInteger('galley_id')->autoIncrement();
			$table->string('locale', 14)->nullable();
			$table->bigInteger('publication_id');
			$table->string('label', 255)->nullable();
			$table->bigInteger('submission_file_id')->unsigned()->nullable();
			$table->float('seq', 8, 2)->default(0);
			$table->string('remote_url', 2047)->nullable();
			$table->smallInteger('is_approved')->default(0);
			$table->string('url_path', 64)->nullable();
			$table->index(['publication_id'], 'publication_galleys_publication_id');
			$table->index(['url_path'], 'publication_galleys_url_path');
			$table->foreign('submission_file_id')->references('submission_file_id')->on('submission_files');
		});

		// Galley metadata.
		Capsule::schema()->create('publication_galley_settings', function (Blueprint $table) {
			$table->bigInteger('galley_id');
			$table->string('locale', 14)->default('');
			$table->string('setting_name', 255);
			$table->text('setting_value')->nullable();
			$table->index(['galley_id'], 'publication_galley_settings_galley_id');
			$table->unique(['galley_id', 'locale', 'setting_name'], 'publication_galley_settings_pkey');
		});
		// Add partial index (DBMS-specific)
		switch (Capsule::connection()->getDriverName()) {
			case 'mysql': Capsule::connection()->unprepared('CREATE INDEX publication_galley_settings_name_value ON publication_galley_settings (setting_name(50), setting_value(150))'); break;
			case 'pgsql': Capsule::connection()->unprepared("CREATE INDEX publication_galley_settings_name_value ON publication_galley_settings (setting_name, setting_value)"); break;
		}

		// Subscription types.
		Capsule::schema()->create('subscription_types', function (Blueprint $table) {
			$table->bigInteger('type_id')->autoIncrement();
			$table->bigInteger('journal_id');
			$table->float('cost', 8, 2);
			$table->string('currency_code_alpha', 3);
			$table->smallInteger('duration')->nullable();
			$table->smallInteger('format');
			$table->smallInteger('institutional')->default(0);
			$table->smallInteger('membership')->default(0);
			$table->smallInteger('disable_public_display');
			$table->float('seq', 8, 2);
		});

		// Locale-specific subscription type data
		Capsule::schema()->create('subscription_type_settings', function (Blueprint $table) {
			$table->bigInteger('type_id');
			$table->string('locale', 14)->default('');
			$table->string('setting_name', 255);
			$table->text('setting_value')->nullable();
			$table->string('setting_type', 6);
			$table->index(['type_id'], 'subscription_type_settings_type_id');
			$table->unique(['type_id', 'locale', 'setting_name'], 'subscription_type_settings_pkey');
		});

		// Journal subscriptions.
		Capsule::schema()->create('subscriptions', function (Blueprint $table) {
			$table->bigInteger('subscription_id')->autoIncrement();
			$table->bigInteger('journal_id');
			$table->bigInteger('user_id');
			$table->bigInteger('type_id');
			$table->date('date_start')->nullable();
			$table->datetime('date_end')->nullable();
			$table->smallInteger('status')->default(1);
			$table->string('membership', 40)->nullable();
			$table->string('reference_number', 40)->nullable();
			$table->text('notes')->nullable();
		});

		// Journal institutional subscriptions.
		Capsule::schema()->create('institutional_subscriptions', function (Blueprint $table) {
			$table->bigInteger('institutional_subscription_id')->autoIncrement();
			$table->bigInteger('subscription_id');
			$table->string('institution_name', 255);
			$table->string('mailing_address', 255)->nullable();
			$table->string('domain', 255)->nullable();
			$table->index(['subscription_id'], 'institutional_subscriptions_subscription_id');
			$table->index(['domain'], 'institutional_subscriptions_domain');
		});

		// Journal institutional subscription IPs and IP ranges.
		Capsule::schema()->create('institutional_subscription_ip', function (Blueprint $table) {
			$table->bigInteger('institutional_subscription_ip_id')->autoIncrement();
			$table->bigInteger('subscription_id');
			$table->string('ip_string', 40);
			$table->bigInteger('ip_start');
			$table->bigInteger('ip_end')->nullable();
			$table->index(['subscription_id'], 'institutional_subscription_ip_subscription_id');
			$table->index(['ip_start'], 'institutional_subscription_ip_start');
			$table->index(['ip_end'], 'institutional_subscription_ip_end');
		});

		// Logs queued (unfulfilled) payments.
		Capsule::schema()->create('queued_payments', function (Blueprint $table) {
			$table->bigInteger('queued_payment_id')->autoIncrement();
			$table->datetime('date_created');
			$table->datetime('date_modified');
			$table->date('expiry_date')->nullable();
			$table->text('payment_data')->nullable();
		});

		// Logs completed (fulfilled) payments.
		Capsule::schema()->create('completed_payments', function (Blueprint $table) {
			$table->bigInteger('completed_payment_id')->autoIncrement();
			$table->datetime('timestamp');
			$table->bigInteger('payment_type');
			$table->bigInteger('context_id');
			$table->bigInteger('user_id')->nullable();
			$table->bigInteger('assoc_id')->nullable();
			$table->float('amount', 8, 2);
			$table->string('currency_code_alpha', 3)->nullable();
			$table->string('payment_method_plugin_name', 80)->nullable();
		});

	}

	/**
	 * Reverse the migration.
	 * @return void
	 */
	public function down() {
		Capsule::schema()->drop('completed_payments');
		Capsule::schema()->drop('queued_payments');
		Capsule::schema()->drop('institutional_subscription_ip');
		Capsule::schema()->drop('institutional_subscriptions');
		Capsule::schema()->drop('subscriptions');
		Capsule::schema()->drop('subscription_type_settings');
		Capsule::schema()->drop('subscription_types');
		Capsule::schema()->drop('publication_galley_settings');
		Capsule::schema()->drop('publication_galleys');
		Capsule::schema()->drop('publications');
		Capsule::schema()->drop('submission_tombstones');
		Capsule::schema()->drop('custom_section_orders');
		Capsule::schema()->drop('custom_issue_orders');
		Capsule::schema()->drop('issue_files');
		Capsule::schema()->drop('issue_galley_settings');
		Capsule::schema()->drop('issue_galleys');
		Capsule::schema()->drop('issue_settings');
		Capsule::schema()->drop('issues');
		Capsule::schema()->drop('section_settings');
		Capsule::schema()->drop('sections');
		Capsule::schema()->drop('journal_settings');
		Capsule::schema()->drop('journals');
	}
}

AnonSec - 2021