1
0
Fork 0
mirror of https://github.com/maybe-finance/maybe.git synced 2025-07-22 22:59:39 +02:00
Maybe/db/migrate/20241106193743_add_plaid_domain.rb

57 lines
1.6 KiB
Ruby
Raw Normal View History

class AddPlaidDomain < ActiveRecord::Migration[7.2]
def change
create_table :plaid_items, id: :uuid do |t|
t.references :family, null: false, type: :uuid, foreign_key: true
t.string :access_token
t.string :plaid_id
t.string :name
t.string :next_cursor
t.boolean :scheduled_for_deletion, default: false
t.timestamps
end
create_table :plaid_accounts, id: :uuid do |t|
t.references :plaid_item, null: false, type: :uuid, foreign_key: true
t.string :plaid_id
t.string :plaid_type
t.string :plaid_subtype
t.decimal :current_balance, precision: 19, scale: 4
t.decimal :available_balance, precision: 19, scale: 4
t.string :currency
t.string :name
t.string :mask
t.timestamps
end
create_table :syncs, id: :uuid do |t|
t.references :syncable, polymorphic: true, null: false, type: :uuid
t.datetime :last_ran_at
t.date :start_date
t.string :status, default: "pending"
t.string :error
t.jsonb :data
t.timestamps
end
remove_column :families, :last_synced_at, :datetime
add_column :families, :last_auto_synced_at, :datetime
remove_column :accounts, :last_sync_date, :date
remove_reference :accounts, :institution
add_reference :accounts, :plaid_account, type: :uuid, foreign_key: true
add_column :account_entries, :plaid_id, :string
add_column :accounts, :scheduled_for_deletion, :boolean, default: false
drop_table :account_syncs do |t|
t.timestamps
end
drop_table :institutions do |t|
t.timestamps
end
end
end