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-11-15 18:48:32 +00:00
|
|
|
# : todo : enum 1,2, etc.
|
2020-07-22 04:24:26 +01:00
|
|
|
# enum shortcut_type: {
|
|
|
|
# account: 'account',
|
|
|
|
# group: 'group'
|
|
|
|
# }
|
|
|
|
|
|
|
|
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
|