forge->addField([ 'id' => [ 'type' => 'CHAR', 'constraint' => 36, 'null' => false, ], 'user_id' => [ 'type' => 'CHAR', 'constraint' => 36, 'null' => false, ], 'title' => [ 'type' => 'VARCHAR', 'constraint' => 255, 'null' => false, ], 'description' => [ 'type' => 'TEXT', 'null' => true, ], 'status' => [ 'type' => 'ENUM', 'constraint' => ['open', 'in_progress', 'completed', 'archived'], 'default' => 'open', ], 'due_date' => [ 'type' => 'DATE', 'null' => true, ], 'due_time' => [ 'type' => 'TIME', 'null' => true, ], 'sync_enabled' => [ 'type' => 'BOOLEAN', 'default' => true, ], 'reminder_enabled' => [ 'type' => 'BOOLEAN', 'default' => false, ], 'recurring_enabled' => [ 'type' => 'BOOLEAN', 'default' => false, ], 'project_id' => [ 'type' => 'CHAR', 'constraint' => 36, 'null' => true, ], 'created_at' => [ 'type' => 'DATETIME', 'null' => true, ], 'updated_at' => [ 'type' => 'DATETIME', 'null' => true, ], ]); $this->forge->addKey('id', true); $this->forge->addKey('user_id'); $this->forge->addKey('due_date'); $this->forge->addKey('status'); $this->forge->addForeignKey('user_id', 'users', 'id', 'CASCADE', 'CASCADE'); $this->forge->addForeignKey('project_id', 'projects', 'id', 'SET NULL', 'CASCADE'); $this->forge->createTable('todos'); } public function down() { $this->forge->dropTable('todos'); } }