forge->addField([ 'id' => [ 'type' => 'BIGINT', 'constraint' => 20, 'unsigned' => true, 'auto_increment' => true, ], 'title' => [ 'type' => 'VARCHAR', 'constraint' => 1024, ], 'name' => [ 'type' => 'VARCHAR', 'constraint' => 191, 'unique' => true, ], 'description' => [ 'type' => 'TEXT', ], 'image_uri' => [ 'type' => 'VARCHAR', 'constraint' => 1024, ], 'language' => [ 'type' => 'VARCHAR', 'constraint' => 2, ], 'category_id' => [ 'type' => 'INT', 'constraint' => 10, 'unsigned' => true, 'default' => 0, ], 'parental_advisory' => [ 'type' => 'ENUM', 'constraint' => ['clean', 'explicit'], 'null' => true, 'default' => null, ], 'owner_name' => [ 'type' => 'VARCHAR', 'constraint' => 1024, ], 'owner_email' => [ 'type' => 'VARCHAR', 'constraint' => 1024, ], 'publisher' => [ 'type' => 'VARCHAR', 'constraint' => 1024, 'null' => true, ], 'type' => [ 'type' => 'ENUM', 'constraint' => ['episodic', 'serial'], 'default' => 'episodic', ], 'copyright' => [ 'type' => 'VARCHAR', 'constraint' => 1024, 'null' => true, ], 'episode_description_footer' => [ 'type' => 'TEXT', 'null' => true, ], 'block' => [ 'type' => 'TINYINT', 'constraint' => 1, 'default' => 0, ], 'complete' => [ 'type' => 'TINYINT', 'constraint' => 1, 'default' => 0, ], 'lock' => [ 'type' => 'TINYINT', 'constraint' => 1, 'comment' => 'This tells other podcast platforms whether they are allowed to import this feed.', 'default' => 1, ], 'imported_feed_url' => [ 'type' => 'VARCHAR', 'constraint' => 1024, 'comment' => 'The RSS feed URL if this podcast was imported, NULL otherwise.', 'null' => true, ], 'new_feed_url' => [ 'type' => 'VARCHAR', 'constraint' => 1024, 'comment' => 'The RSS new feed URL if this podcast is moving out, NULL otherwise.', 'null' => true, ], 'created_by' => [ 'type' => 'INT', 'constraint' => 11, 'unsigned' => true, ], 'updated_by' => [ 'type' => 'INT', 'constraint' => 11, 'unsigned' => true, ], 'created_at' => [ 'type' => 'TIMESTAMP', ], 'updated_at' => [ 'type' => 'TIMESTAMP', ], 'deleted_at' => [ 'type' => 'DATETIME', 'null' => true, ], ]); $this->forge->addKey('id', true); $this->forge->addForeignKey('category_id', 'categories', 'id'); $this->forge->addForeignKey('created_by', 'users', 'id'); $this->forge->addForeignKey('updated_by', 'users', 'id'); $this->forge->createTable('podcasts'); } public function down() { $this->forge->dropTable('podcasts'); } }