2013-05-22 10:59:59 -04:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: services
|
|
|
|
#
|
|
|
|
# id :integer not null, primary key
|
|
|
|
# type :string(255)
|
|
|
|
# title :string(255)
|
|
|
|
# project_id :integer not null
|
2014-04-09 08:05:03 -04:00
|
|
|
# created_at :datetime
|
|
|
|
# updated_at :datetime
|
2013-05-22 10:59:59 -04:00
|
|
|
# active :boolean default(FALSE), not null
|
2014-09-07 20:54:18 -04:00
|
|
|
# properties :text
|
2013-05-22 10:59:59 -04:00
|
|
|
#
|
|
|
|
|
|
|
|
class CampfireService < Service
|
2014-09-07 20:54:18 -04:00
|
|
|
prop_accessor :token, :subdomain, :room
|
2013-05-22 10:59:59 -04:00
|
|
|
validates :token, presence: true, if: :activated?
|
|
|
|
|
|
|
|
def title
|
|
|
|
'Campfire'
|
|
|
|
end
|
|
|
|
|
|
|
|
def description
|
|
|
|
'Simple web-based real-time group chat'
|
|
|
|
end
|
|
|
|
|
|
|
|
def to_param
|
|
|
|
'campfire'
|
|
|
|
end
|
|
|
|
|
|
|
|
def fields
|
|
|
|
[
|
|
|
|
{ type: 'text', name: 'token', placeholder: '' },
|
|
|
|
{ type: 'text', name: 'subdomain', placeholder: '' },
|
|
|
|
{ type: 'text', name: 'room', placeholder: '' }
|
|
|
|
]
|
|
|
|
end
|
|
|
|
|
|
|
|
def execute(push_data)
|
|
|
|
room = gate.find_room_by_name(self.room)
|
|
|
|
return true unless room
|
|
|
|
|
|
|
|
message = build_message(push_data)
|
|
|
|
|
|
|
|
room.speak(message)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def gate
|
|
|
|
@gate ||= Tinder::Campfire.new(subdomain, token: token)
|
|
|
|
end
|
|
|
|
|
|
|
|
def build_message(push)
|
|
|
|
ref = push[:ref].gsub("refs/heads/", "")
|
|
|
|
before = push[:before]
|
|
|
|
after = push[:after]
|
|
|
|
|
|
|
|
message = ""
|
|
|
|
message << "[#{project.name_with_namespace}] "
|
|
|
|
message << "#{push[:user_name]} "
|
|
|
|
|
|
|
|
if before =~ /000000/
|
|
|
|
message << "pushed new branch #{ref} \n"
|
|
|
|
elsif after =~ /000000/
|
|
|
|
message << "removed branch #{ref} \n"
|
|
|
|
else
|
|
|
|
message << "pushed #{push[:total_commits_count]} commits to #{ref}. "
|
|
|
|
message << "#{project.web_url}/compare/#{before}...#{after}"
|
|
|
|
end
|
|
|
|
|
|
|
|
message
|
|
|
|
end
|
|
|
|
end
|