Files
ubicloud/model/account.rb
Jeremy Evans 30247a3800 Include model annotations at the bottom of all model files
This makes it easier for developers new to the codebase to
easily get important information on the model's table in the
same file as the model code.

To ensure the model annotations stay accurate, run them on
test_up/test_down.  In CI, regenerate the annotations, and
check for no changes, similar to how the linters work.
2024-11-13 09:13:30 -08:00

72 lines
4.1 KiB
Ruby

# frozen_string_literal: true
require_relative "../model"
class Account < Sequel::Model(:accounts)
one_to_many :usage_alerts, key: :user_id
plugin :association_dependencies, usage_alerts: :destroy
include ResourceMethods
include Authorization::HyperTagMethods
def hyper_tag_name(project = nil)
"user/#{email}"
end
include Authorization::TaggableMethods
def create_project_with_default_policy(name, default_policy: Authorization::ManagedPolicy::Admin)
project = Project.create_with_id(name: name)
project.associate_with_project(project)
associate_with_project(project)
default_policy&.apply(project, [self])
project
end
def suspend
update(suspended_at: Time.now)
DB[:account_active_session_keys].where(account_id: id).delete(force: true)
projects.each { _1.billing_info&.payment_methods_dataset&.update(fraud: true) }
end
end
# Table: accounts
# Columns:
# id | uuid | PRIMARY KEY
# status_id | integer | NOT NULL DEFAULT 1
# email | citext | NOT NULL
# name | text |
# created_at | timestamp with time zone | NOT NULL DEFAULT now()
# suspended_at | timestamp with time zone |
# Indexes:
# accounts_pkey | PRIMARY KEY btree (id)
# accounts_email_index | UNIQUE btree (email) WHERE status_id = ANY (ARRAY[1, 2])
# Check constraints:
# valid_email | (email ~ '^[^,;@ \r\n]+@[^,@; \r\n]+\.[^,@; \r\n]+$'::citext)
# Foreign key constraints:
# accounts_status_id_fkey | (status_id) REFERENCES account_statuses(id)
# Referenced By:
# account_active_session_keys | account_active_session_keys_account_id_fkey | (account_id) REFERENCES accounts(id)
# account_activity_times | account_activity_times_id_fkey | (id) REFERENCES accounts(id)
# account_authentication_audit_logs | account_authentication_audit_logs_account_id_fkey | (account_id) REFERENCES accounts(id)
# account_email_auth_keys | account_email_auth_keys_id_fkey | (id) REFERENCES accounts(id)
# account_jwt_refresh_keys | account_jwt_refresh_keys_account_id_fkey | (account_id) REFERENCES accounts(id)
# account_lockouts | account_lockouts_id_fkey | (id) REFERENCES accounts(id)
# account_login_change_keys | account_login_change_keys_id_fkey | (id) REFERENCES accounts(id)
# account_login_failures | account_login_failures_id_fkey | (id) REFERENCES accounts(id)
# account_otp_keys | account_otp_keys_id_fkey | (id) REFERENCES accounts(id)
# account_password_change_times | account_password_change_times_id_fkey | (id) REFERENCES accounts(id)
# account_password_hashes | account_password_hashes_id_fkey | (id) REFERENCES accounts(id)
# account_password_reset_keys | account_password_reset_keys_id_fkey | (id) REFERENCES accounts(id)
# account_previous_password_hashes | account_previous_password_hashes_account_id_fkey | (account_id) REFERENCES accounts(id)
# account_recovery_codes | account_recovery_codes_id_fkey | (id) REFERENCES accounts(id)
# account_remember_keys | account_remember_keys_id_fkey | (id) REFERENCES accounts(id)
# account_session_keys | account_session_keys_id_fkey | (id) REFERENCES accounts(id)
# account_sms_codes | account_sms_codes_id_fkey | (id) REFERENCES accounts(id)
# account_verification_keys | account_verification_keys_id_fkey | (id) REFERENCES accounts(id)
# account_webauthn_keys | account_webauthn_keys_account_id_fkey | (account_id) REFERENCES accounts(id)
# account_webauthn_user_ids | account_webauthn_user_ids_id_fkey | (id) REFERENCES accounts(id)
# usage_alert | usage_alert_user_id_fkey | (user_id) REFERENCES accounts(id)