|
- <?php
-
- namespace App\Database\Migrations;
-
- use CodeIgniter\Database\Migration;
-
- class CreateAuthTables extends Migration
- {
- public function up()
- {
- // Users
- $this->forge->addField([
- 'id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true],
- 'email' => ['type' => 'varchar', 'constraint' => 255],
- 'password_hash' => ['type' => 'varchar', 'constraint' => 255],
- 'reset_hash' => ['type' => 'varchar', 'constraint' => 255, 'null' => true],
- 'reset_at' => ['type' => 'datetime', 'null' => true],
- 'reset_expires' => ['type' => 'datetime', 'null' => true],
- 'activate_hash' => ['type' => 'varchar', 'constraint' => 255, 'null' => true],
- 'status' => ['type' => 'varchar', 'constraint' => 255, 'null' => true],
- 'status_message' => ['type' => 'varchar', 'constraint' => 255, 'null' => true],
- 'active' => ['type' => 'tinyint', 'constraint' => 1, 'null' => 0, 'default' => 0],
- 'force_pass_reset' => ['type' => 'tinyint', 'constraint' => 1, 'null' => 0, 'default' => 0],
- 'created_at' => ['type' => 'datetime', 'null' => true],
- 'updated_at' => ['type' => 'datetime', 'null' => true],
- 'deleted_at' => ['type' => 'datetime', 'null' => true],
- 'idprestador' => ['type' => 'int', 'null' => true],
- ]);
-
- $this->forge->addKey('id', true);
- $this->forge->addUniqueKey('email');
-
-
- $this->forge->createTable('users', true);
-
- // Auth Login Attempts
- $this->forge->addField([
- 'id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true],
- 'ip_address' => ['type' => 'varchar', 'constraint' => 255, 'null' => true],
- 'email' => ['type' => 'varchar', 'constraint' => 255, 'null' => true],
- 'user_id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'null' => true], // Only for successful logins
- 'date' => ['type' => 'datetime'],
- 'success' => ['type' => 'tinyint', 'constraint' => 1],
- ]);
- $this->forge->addKey('id', true);
- $this->forge->addKey('email');
- $this->forge->addKey('user_id');
- // NOTE: Do NOT delete the user_id or email when the user is deleted for security audits
- $this->forge->createTable('auth_logins', true);
-
- /*
- * Auth Tokens
- * @see https://paragonie.com/blog/2015/04/secure-authentication-php-with-long-term-persistence
- */
- $this->forge->addField([
- 'id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true],
- 'selector' => ['type' => 'varchar', 'constraint' => 255],
- 'hashedValidator' => ['type' => 'varchar', 'constraint' => 255],
- 'user_id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true],
- 'expires' => ['type' => 'datetime'],
- ]);
- $this->forge->addKey('id', true);
- $this->forge->addKey('selector');
- $this->forge->addForeignKey('user_id', 'users', 'id', '', 'CASCADE');
- $this->forge->createTable('auth_tokens', true);
-
- // Password Reset Table
- $this->forge->addField([
- 'id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true],
- 'email' => ['type' => 'varchar', 'constraint' => 255],
- 'ip_address' => ['type' => 'varchar', 'constraint' => 255],
- 'user_agent' => ['type' => 'varchar', 'constraint' => 255],
- 'token' => ['type' => 'varchar', 'constraint' => 255, 'null' => true],
- 'created_at' => ['type' => 'datetime', 'null' => false],
- ]);
- $this->forge->addKey('id', true);
- $this->forge->createTable('auth_reset_attempts', true);
-
- // Activation Attempts Table
- $this->forge->addField([
- 'id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true],
- 'ip_address' => ['type' => 'varchar', 'constraint' => 255],
- 'user_agent' => ['type' => 'varchar', 'constraint' => 255],
- 'token' => ['type' => 'varchar', 'constraint' => 255, 'null' => true],
- 'created_at' => ['type' => 'datetime', 'null' => false],
- ]);
- $this->forge->addKey('id', true);
- $this->forge->createTable('auth_activation_attempts', true);
-
- // Groups Table
- $fields = [
- 'id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true],
- 'name' => ['type' => 'varchar', 'constraint' => 255],
- 'description' => ['type' => 'varchar', 'constraint' => 255],
- ];
-
- $this->forge->addField($fields);
- $this->forge->addKey('id', true);
- $this->forge->createTable('auth_groups', true);
-
- // Permissions Table
- $fields = [
- 'id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true],
- 'name' => ['type' => 'varchar', 'constraint' => 255],
- 'description' => ['type' => 'varchar', 'constraint' => 255],
- ];
-
- $this->forge->addField($fields);
- $this->forge->addKey('id', true);
- $this->forge->createTable('auth_permissions', true);
-
- // Groups/Permissions Table
- $fields = [
- 'group_id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'default' => 0],
- 'permission_id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'default' => 0],
- ];
-
- $this->forge->addField($fields);
- $this->forge->addKey(['group_id', 'permission_id']);
- $this->forge->addForeignKey('group_id', 'auth_groups', 'id', '', 'CASCADE');
- $this->forge->addForeignKey('permission_id', 'auth_permissions', 'id', '', 'CASCADE');
- $this->forge->createTable('auth_groups_permissions', true);
-
- // Users/Groups Table
- $fields = [
- 'group_id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'default' => 0],
- 'user_id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'default' => 0],
- ];
-
- $this->forge->addField($fields);
- $this->forge->addKey(['group_id', 'user_id']);
- $this->forge->addForeignKey('group_id', 'auth_groups', 'id', '', 'CASCADE');
- $this->forge->addForeignKey('user_id', 'users', 'id', '', 'CASCADE');
- $this->forge->createTable('auth_groups_users', true);
-
- // Users/Permissions Table
- $fields = [
- 'user_id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'default' => 0],
- 'permission_id' => ['type' => 'int', 'constraint' => 11, 'unsigned' => true, 'default' => 0],
- ];
-
- $this->forge->addField($fields);
- $this->forge->addKey(['user_id', 'permission_id']);
- $this->forge->addForeignKey('user_id', 'users', 'id', '', 'CASCADE');
- $this->forge->addForeignKey('permission_id', 'auth_permissions', 'id', '', 'CASCADE');
- $this->forge->createTable('auth_users_permissions', true);
- }
-
- //--------------------------------------------------------------------
-
- public function down()
- {
- // drop constraints first to prevent errors
- if ($this->db->DBDriver !== 'SQLite3') { // @phpstan-ignore-line
- $this->forge->dropForeignKey('auth_tokens', 'auth_tokens_user_id_foreign');
- $this->forge->dropForeignKey('auth_groups_permissions', 'auth_groups_permissions_group_id_foreign');
- $this->forge->dropForeignKey('auth_groups_permissions', 'auth_groups_permissions_permission_id_foreign');
- $this->forge->dropForeignKey('auth_groups_users', 'auth_groups_users_group_id_foreign');
- $this->forge->dropForeignKey('auth_groups_users', 'auth_groups_users_user_id_foreign');
- $this->forge->dropForeignKey('auth_users_permissions', 'auth_users_permissions_user_id_foreign');
- $this->forge->dropForeignKey('auth_users_permissions', 'auth_users_permissions_permission_id_foreign');
- }
-
- $this->forge->dropTable('users', true);
- $this->forge->dropTable('auth_logins', true);
- $this->forge->dropTable('auth_tokens', true);
- $this->forge->dropTable('auth_reset_attempts', true);
- $this->forge->dropTable('auth_activation_attempts', true);
- $this->forge->dropTable('auth_groups', true);
- $this->forge->dropTable('auth_permissions', true);
- $this->forge->dropTable('auth_groups_permissions', true);
- $this->forge->dropTable('auth_groups_users', true);
- $this->forge->dropTable('auth_users_permissions', true);
- }
- }
|