76 lines
2.5 KiB
PHP
76 lines
2.5 KiB
PHP
<?php
|
|
|
|
use Carbon\Carbon;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Illuminate\Database\Schema\Blueprint;
|
|
use Illuminate\Database\Migrations\Migration;
|
|
|
|
class TransferOldTasksToNewScheduler extends Migration
|
|
{
|
|
/**
|
|
* Run the migrations.
|
|
*/
|
|
public function up()
|
|
{
|
|
$tasks = DB::table('tasks_old')->get();
|
|
|
|
DB::beginTransaction();
|
|
$tasks->each(function ($task) {
|
|
$schedule = DB::table('schedules')->insertGetId([
|
|
'server_id' => $task->server_id,
|
|
'name' => null,
|
|
'cron_day_of_week' => $task->day_of_week,
|
|
'cron_day_of_month' => $task->day_of_month,
|
|
'cron_hour' => $task->hour,
|
|
'cron_minute' => $task->minute,
|
|
'is_active' => (bool) $task->active,
|
|
'is_processing' => false,
|
|
'last_run_at' => $task->last_run,
|
|
'next_run_at' => $task->next_run,
|
|
'created_at' => $task->created_at,
|
|
'updated_at' => Carbon::now()->toDateTimeString(),
|
|
]);
|
|
|
|
DB::table('tasks')->insert([
|
|
'schedule_id' => $schedule,
|
|
'sequence_id' => 1,
|
|
'action' => $task->action,
|
|
'payload' => $task->data,
|
|
'time_offset' => 0,
|
|
'is_queued' => false,
|
|
'updated_at' => Carbon::now()->toDateTimeString(),
|
|
'created_at' => Carbon::now()->toDateTimeString(),
|
|
]);
|
|
|
|
DB::table('tasks_old')->delete($task->id);
|
|
DB::commit();
|
|
});
|
|
|
|
Schema::dropIfExists('tasks_old');
|
|
}
|
|
|
|
/**
|
|
* Reverse the migrations.
|
|
*/
|
|
public function down()
|
|
{
|
|
Schema::create('tasks_old', function (Blueprint $table) {
|
|
$table->increments('id');
|
|
$table->unsignedInteger('user_id')->nullable();
|
|
$table->unsignedInteger('server_id');
|
|
$table->tinyInteger('active')->default(1);
|
|
$table->string('action');
|
|
$table->text('data');
|
|
$table->unsignedTinyInteger('queued')->default(0);
|
|
$table->string('year')->default('*');
|
|
$table->string('month')->default('*');
|
|
$table->string('day_of_week')->default('*');
|
|
$table->string('day_of_month')->default('*');
|
|
$table->string('minute')->default('*');
|
|
$table->timestamp('last_run')->nullable();
|
|
$table->timestamp('next_run');
|
|
$table->timestamps();
|
|
});
|
|
}
|
|
}
|