HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/migration/
Upload File :
Current File : /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/migration/ViewsMigration.inc.php
<?php

/**
 * @file classes/migration/ViewsMigration.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 ViewsMigration
 * @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 ViewsMigration extends Migration {
        /**
         * Run the migrations.
         * @return void
         */
        public function up() {
		// Tracking of views for various types of objects such as files, reviews, etc
		Capsule::schema()->create('item_views', function (Blueprint $table) {
			$table->bigInteger('assoc_type');
			$table->bigInteger('assoc_id');
			$table->bigInteger('user_id')->nullable();
			$table->datetime('date_last_viewed')->nullable();
			$table->unique(['assoc_type', 'assoc_id', 'user_id'], 'item_views_pkey');
		});
	}

	/**
	 * Reverse the migration.
	 * @return void
	 */
	public function down() {
		Capsule::schema()->drop('item_views');
	}
}