Skip to content
Snippets Groups Projects
2021-12-09-130000_add_clips.php 2.78 KiB
Newer Older
  • Learn to ignore specific revisions
  •  * @license    https://www.gnu.org/licenses/agpl-3.0.en.html AGPL3
     * @link       https://castopod.org/
     */
    
    namespace App\Database\Migrations;
    
    use CodeIgniter\Database\Migration;
    
    
        {
            $this->forge->addField([
                'id' => [
                    'type' => 'INT',
                    'unsigned' => true,
                    'auto_increment' => true,
                ],
                'podcast_id' => [
                    'type' => 'INT',
                    'unsigned' => true,
                ],
                'episode_id' => [
                    'type' => 'INT',
                    'unsigned' => true,
                ],
                'start_time' => [
    
                    // clip duration cannot be higher than 9999,999 seconds ~ 2.77 hours
    
                ],
                'label' => [
                    'type' => 'VARCHAR',
                    'constraint' => 128,
                    'null' => true,
                ],
    
                'type' => [
                    'type' => 'ENUM',
                    'constraint' => ['audio', 'video'],
                ],
                'media_id' => [
                    'type' => 'INT',
                    'unsigned' => true,
                ],
                'status' => [
                    'type' => 'ENUM',
                    'constraint' => ['queued', 'pending', 'generating', 'passed', 'failed'],
                ],
                'logs' => [
                    'type' => 'TEXT',
                ],
    
                'created_by' => [
                    'type' => 'INT',
                    'unsigned' => true,
                ],
                'updated_by' => [
                    'type' => 'INT',
                    'unsigned' => true,
                ],
                'created_at' => [
                    'type' => 'DATETIME',
                ],
                'updated_at' => [
                    'type' => 'DATETIME',
                ],
                'deleted_at' => [
                    'type' => 'DATETIME',
                    'null' => true,
                ],
            ]);
    
            $this->forge->addKey('id', true);
    
            $this->forge->addUniqueKey(['episode_id', 'start_time', 'duration', 'type']);
    
            $this->forge->addForeignKey('podcast_id', 'podcasts', 'id', '', 'CASCADE');
            $this->forge->addForeignKey('episode_id', 'episodes', 'id', '', 'CASCADE');
    
            $this->forge->addForeignKey('media_id', 'media', 'id', '', 'CASCADE');
    
            $this->forge->addForeignKey('created_by', 'users', 'id');
            $this->forge->addForeignKey('updated_by', 'users', 'id');
    
            $this->forge->createTable('clips');