1
0
Fork 0
This repository has been archived on 2023-03-27. You can view files and clone it, but cannot push or open issues or pull requests.
lpr-partynest/db/migrate/20181129203927_devise_create_users.rb
2019-07-20 04:53:55 +05:00

78 lines
2.1 KiB
Ruby

# frozen_string_literal: true
class DeviseCreateUsers < ActiveRecord::Migration[5.2]
def change
create_table :accounts do |t|
t.timestamps null: false
end
create_table :users do |t|
t.timestamps null: false
t.references :account, null: false
## Database authenticatable
t.string :email, null: false, default: ''
t.string :encrypted_password, null: false, default: ''
## Recoverable
t.string :reset_password_token
t.datetime :reset_password_sent_at
## Rememberable
t.datetime :remember_created_at
## Trackable
t.integer :sign_in_count, default: 0, null: false
t.datetime :current_sign_in_at
t.datetime :last_sign_in_at
t.inet :current_sign_in_ip
t.inet :last_sign_in_ip
## Confirmable
t.string :confirmation_token
t.datetime :confirmed_at
t.datetime :confirmation_sent_at
t.string :unconfirmed_email
## Lockable
t.integer :failed_attempts, default: 0, null: false
t.string :unlock_token
t.datetime :locked_at
t.index :users, :account, unique: true
t.index :users, :email, unique: true
t.index :users, :reset_password_token, unique: true
t.index :users, :confirmation_token, unique: true
t.index :users, :unlock_token, unique: true
end
add_foreign_key :users, :accounts
create_table :roles do |t|
t.timestamps null: false
t.string :name
t.references :resource, polymorphic: true
t.index %i[name resource_type resource_id], unique: true
end
create_table :account_roles do |t|
t.timestamps null: false
t.references :account, null: false
t.references :role, null: false
t.index %i[account_id role_id], unique: true
end
add_foreign_key :account_roles, :accounts
add_foreign_key :account_roles, :roles
create_table :country_states do |t|
t.timestamps null: false
t.string :name, null: false
t.index :name, unique: true
end
end
end