2014-09-02 18:07:02 +05:30
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: keys
|
|
|
|
#
|
|
|
|
# id :integer not null, primary key
|
|
|
|
# user_id :integer
|
|
|
|
# created_at :datetime
|
|
|
|
# updated_at :datetime
|
|
|
|
# key :text
|
|
|
|
# title :string(255)
|
|
|
|
# type :string(255)
|
|
|
|
# fingerprint :string(255)
|
2015-09-11 14:41:01 +05:30
|
|
|
# public :boolean default(FALSE), not null
|
2014-09-02 18:07:02 +05:30
|
|
|
#
|
|
|
|
|
|
|
|
class DeployKey < Key
|
|
|
|
has_many :deploy_keys_projects, dependent: :destroy
|
|
|
|
has_many :projects, through: :deploy_keys_projects
|
|
|
|
|
|
|
|
scope :in_projects, ->(projects) { joins(:deploy_keys_projects).where('deploy_keys_projects.project_id in (?)', projects) }
|
2015-04-26 12:48:37 +05:30
|
|
|
scope :are_public, -> { where(public: true) }
|
|
|
|
|
|
|
|
def private?
|
|
|
|
!public?
|
|
|
|
end
|
|
|
|
|
|
|
|
def orphaned?
|
|
|
|
self.deploy_keys_projects.length == 0
|
|
|
|
end
|
|
|
|
|
|
|
|
def almost_orphaned?
|
|
|
|
self.deploy_keys_projects.length == 1
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroyed_when_orphaned?
|
|
|
|
self.private?
|
|
|
|
end
|
2014-09-02 18:07:02 +05:30
|
|
|
end
|