2020-07-07 22:01:51 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: shortcuts
|
|
|
|
#
|
2020-07-22 04:24:26 +01:00
|
|
|
# id :bigint(8) not null, primary key
|
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
|
|
|
# account_id :bigint(8) not null
|
|
|
|
# shortcut_id :bigint(8) not null
|
|
|
|
# shortcut_type :string default(""), not null
|
2020-07-07 22:01:51 +01:00
|
|
|
#
|
|
|
|
|
|
|
|
class Shortcut < ApplicationRecord
|
2020-12-21 18:25:05 +00:00
|
|
|
SHORTCUT_TYPE_MAP = {
|
|
|
|
account: 'account',
|
|
|
|
group: 'group',
|
|
|
|
}.freeze
|
2020-07-22 04:24:26 +01:00
|
|
|
|
|
|
|
belongs_to :account
|
|
|
|
|
|
|
|
PER_ACCOUNT_LIMIT = 50
|
|
|
|
|
|
|
|
validates_each :account_id, on: :create do |record, _attr, value|
|
|
|
|
record.errors.add(:base, I18n.t('shortcuts.errors.limit')) if Shortcut.where(account_id: value).count >= PER_ACCOUNT_LIMIT
|
|
|
|
end
|
2020-07-07 22:01:51 +01:00
|
|
|
end
|