|
Server : Apache/2.4.41 (Ubuntu) System : Linux vmi1525618.contaboserver.net 5.4.0-105-generic #119-Ubuntu SMP Mon Mar 7 18:49:24 UTC 2022 x86_64 User : www-data ( 33) PHP Version : 8.2.12 Disable Function : NONE Directory : /var/www/lecturebazaar.com/database/migrations/ |
Upload File : |
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
class CreateCashbackRulesTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('cashback_rules', function (Blueprint $table) {
$table->increments('id');
$table->enum('target_type', \App\Models\CashbackRule::$targetTypes);
$table->string('target')->nullable();
$table->bigInteger('start_date')->unsigned()->nullable();
$table->bigInteger('end_date')->unsigned()->nullable();
$table->float('amount', 15, 2)->nullable();
$table->enum('amount_type', ['fixed_amount', 'percent'])->nullable();
$table->boolean('apply_cashback_per_item')->default(false);
$table->float('max_amount', 15, 2)->nullable();
$table->float('min_amount', 15, 2)->nullable();
$table->boolean('enable')->default(false);
$table->bigInteger('created_at')->unsigned();
});
Schema::create('cashback_rule_translations', function (Blueprint $table) {
$table->increments('id');
$table->integer('cashback_rule_id')->unsigned();
$table->string('locale', 191)->index();
$table->string('title');
$table->foreign('cashback_rule_id')->on('cashback_rules')->references('id')->cascadeOnDelete();
});
Schema::create('cashback_rule_specification_items', function (Blueprint $table) {
$table->increments('id');
$table->integer('cashback_rule_id')->unsigned();
$table->integer('category_id')->unsigned()->nullable();
$table->integer('instructor_id')->unsigned()->nullable();
$table->integer('seller_id')->unsigned()->nullable();
$table->integer('webinar_id')->unsigned()->nullable();
$table->integer('product_id')->unsigned()->nullable();
$table->integer('bundle_id')->unsigned()->nullable();
$table->integer('subscribe_id')->unsigned()->nullable();
$table->integer('registration_package_id')->unsigned()->nullable();
$table->foreign('cashback_rule_id')->on('cashback_rules')->references('id')->cascadeOnDelete();
$table->foreign('category_id')->on('categories')->references('id')->cascadeOnDelete();
$table->foreign('instructor_id')->on('users')->references('id')->cascadeOnDelete();
$table->foreign('seller_id')->on('users')->references('id')->cascadeOnDelete();
$table->foreign('webinar_id')->on('webinars')->references('id')->cascadeOnDelete();
$table->foreign('product_id')->on('products')->references('id')->cascadeOnDelete();
$table->foreign('bundle_id')->on('bundles')->references('id')->cascadeOnDelete();
$table->foreign('subscribe_id')->on('subscribes')->references('id')->cascadeOnDelete();
$table->foreign('registration_package_id', 'rules_registration_package_id')->on('registration_packages')->references('id')->cascadeOnDelete();
});
Schema::create('cashback_rule_users_groups', function (Blueprint $table) {
$table->increments('id');
$table->integer('cashback_rule_id')->unsigned();
$table->integer('group_id')->unsigned()->nullable();
$table->integer('user_id')->unsigned()->nullable();
$table->foreign('cashback_rule_id')->on('cashback_rules')->references('id')->cascadeOnDelete();
$table->foreign('group_id')->on('groups')->references('id')->cascadeOnDelete();
$table->foreign('user_id')->on('users')->references('id')->cascadeOnDelete();
});
}
/**
* Reverse the migrations.
*
* @return void
*/
public function down()
{
Schema::dropIfExists('cashback_rules');
Schema::dropIfExists('cashback_rule_translations');
Schema::dropIfExists('cashback_rule_specification_items');
Schema::dropIfExists('cashback_rule_users_groups');
}
}