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

135 lines
3.5 KiB
Ruby
Raw Normal View History

2018-11-29 15:57:57 -05:00
# frozen_string_literal: true
class DeviseCreateUsers < ActiveRecord::Migration[5.2]
def change
2019-07-21 22:56:28 -04:00
reversible do |dir|
dir.up do
execute <<~SQL
CREATE TYPE sex AS ENUM ('male', 'female');
CREATE TYPE relationship_status AS ENUM (
'supporter',
'excluded',
'member'
);
CREATE TYPE relationship_role AS ENUM ('manager', 'supervisor');
SQL
end
dir.down do
execute <<~SQL
DROP TYPE sex;
DROP TYPE relationship_status;
DROP TYPE relationship_role;
SQL
end
end
2019-07-19 20:41:59 -04:00
create_table :country_states do |t|
t.timestamps null: false
2019-07-19 20:45:55 -04:00
2019-07-19 20:49:59 -04:00
t.string :name, null: false, index: { unique: true }
2019-07-19 20:41:59 -04:00
end
create_table :regional_offices do |t|
t.timestamps null: false
2019-07-19 20:47:21 -04:00
t.references :country_state, null: false, index: { unique: true }
2019-07-19 20:41:59 -04:00
end
2019-07-19 20:38:41 -04:00
create_table :people do |t|
t.timestamps null: false
2019-07-21 22:58:07 -04:00
t.string :first_name, null: false
t.string :middle_name, null: true
t.string :last_name, null: false
2019-07-19 20:38:41 -04:00
end
2019-07-19 19:47:56 -04:00
create_table :accounts do |t|
t.timestamps null: false
2019-07-19 20:37:28 -04:00
2019-07-19 20:49:59 -04:00
t.string :guest_token, null: false, index: { unique: true }
2019-07-21 22:38:23 -04:00
t.string :nickname, null: false, index: { unique: true }
2019-07-19 20:37:28 -04:00
2019-07-21 23:00:42 -04:00
t.string :public_name
t.text :biography
2019-07-21 22:59:35 -04:00
2019-07-19 20:40:21 -04:00
t.references :person, index: { unique: true }
2019-07-19 19:47:56 -04:00
end
2018-11-29 15:57:57 -05:00
create_table :users do |t|
t.timestamps null: false
2019-07-19 19:58:29 -04:00
t.references :account, null: false, index: { unique: true }
2019-07-19 19:53:05 -04:00
2018-11-29 15:57:57 -05:00
## 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
2019-07-19 19:53:05 -04:00
2019-07-19 19:55:57 -04:00
t.index :email, unique: true
t.index :reset_password_token, unique: true
t.index :confirmation_token, unique: true
t.index :unlock_token, unique: true
2019-07-19 19:53:55 -04:00
end
2019-07-19 19:44:21 -04:00
create_table :roles do |t|
t.timestamps null: false
2019-07-19 20:10:44 -04:00
t.string :name, null: false
2019-07-19 19:44:21 -04:00
t.references :resource, polymorphic: true
t.index %i[name resource_type resource_id], unique: true
end
2019-07-19 19:47:56 -04:00
create_table :account_roles do |t|
2019-07-19 19:44:21 -04:00
t.timestamps null: false
2019-07-19 19:47:56 -04:00
t.references :account, null: false
2019-07-19 19:44:21 -04:00
t.references :role, null: false
2019-07-19 19:47:56 -04:00
t.index %i[account_id role_id], unique: true
2019-07-19 19:44:21 -04:00
end
2019-07-19 20:08:50 -04:00
create_table :user_omniauths do |t|
t.timestamps null: false
t.references :user, foreign_key: true
t.string :provider, null: false
t.string :remote_id, null: false
t.string :email, null: false
t.index %i[remote_id provider], unique: true
end
2019-07-19 20:45:55 -04:00
add_foreign_key :users, :accounts
add_foreign_key :account_roles, :accounts
add_foreign_key :account_roles, :roles
add_foreign_key :accounts, :people
add_foreign_key :regional_offices, :country_states
2018-11-29 15:57:57 -05:00
end
end