2016-12-23 07:03:57 +09:00
|
|
|
# frozen_string_literal: true
|
2017-05-02 09:14:47 +09:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: follow_requests
|
|
|
|
#
|
2017-11-18 08:16:48 +09:00
|
|
|
# id :integer not null, primary key
|
2017-05-02 09:14:47 +09:00
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
2017-11-16 16:21:16 +09:00
|
|
|
# account_id :bigint not null
|
|
|
|
# id :bigint not null, primary key
|
|
|
|
# target_account_id :bigint not null
|
2017-11-09 23:41:10 +09:00
|
|
|
# show_reblogs :boolean default(TRUE), not null
|
2017-05-02 09:14:47 +09:00
|
|
|
#
|
2016-12-23 07:03:57 +09:00
|
|
|
|
|
|
|
class FollowRequest < ApplicationRecord
|
2016-12-27 03:30:45 +09:00
|
|
|
include Paginable
|
|
|
|
|
2017-04-05 07:29:56 +09:00
|
|
|
belongs_to :account, required: true
|
|
|
|
belongs_to :target_account, class_name: 'Account', required: true
|
2016-12-23 07:03:57 +09:00
|
|
|
|
2016-12-27 05:52:03 +09:00
|
|
|
has_one :notification, as: :activity, dependent: :destroy
|
|
|
|
|
2016-12-23 07:03:57 +09:00
|
|
|
validates :account_id, uniqueness: { scope: :target_account_id }
|
|
|
|
|
|
|
|
def authorize!
|
2017-11-11 11:11:10 +09:00
|
|
|
account.follow!(target_account, reblogs: show_reblogs)
|
2017-01-26 11:56:26 +09:00
|
|
|
MergeWorker.perform_async(target_account.id, account.id)
|
2017-02-11 10:12:05 +09:00
|
|
|
|
2016-12-23 07:03:57 +09:00
|
|
|
destroy!
|
|
|
|
end
|
|
|
|
|
2017-11-09 22:36:52 +09:00
|
|
|
alias reject! destroy!
|
2016-12-23 07:03:57 +09:00
|
|
|
end
|