eval-desempeno-v2/app/Database/Migrations/2017-11-20-223112_create_auth_tables.php
2022-08-01 14:28:07 -05:00

176 lines
8.8 KiB
PHP

<?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);
}
}