dbd9d8d4c3
When using web hook with credentials secured web resource, one needs to put the credentials in the hook URL. If the credentials contain special symbols (e.g. @ or #), it should be URL-quoted (e.g. %40 instead of @). But when Gitlab is making a request, it should unquote the symbols before base64-encoding them.
45 lines
1.2 KiB
Ruby
45 lines
1.2 KiB
Ruby
# == Schema Information
|
|
#
|
|
# Table name: web_hooks
|
|
#
|
|
# id :integer not null, primary key
|
|
# url :string(255)
|
|
# project_id :integer
|
|
# created_at :datetime not null
|
|
# updated_at :datetime not null
|
|
# type :string(255) default("ProjectHook")
|
|
# service_id :integer
|
|
#
|
|
|
|
class WebHook < ActiveRecord::Base
|
|
include HTTParty
|
|
|
|
attr_accessible :url
|
|
|
|
# HTTParty timeout
|
|
default_timeout 10
|
|
|
|
validates :url, presence: true,
|
|
format: { with: URI::regexp(%w(http https)), message: "should be a valid url" }
|
|
|
|
def execute(data)
|
|
parsed_url = URI.parse(url)
|
|
if parsed_url.userinfo.blank?
|
|
WebHook.post(url, body: data.to_json, headers: { "Content-Type" => "application/json" })
|
|
else
|
|
post_url = url.gsub("#{parsed_url.userinfo}@", "")
|
|
auth = {
|
|
username: URI.decode(parsed_url.user),
|
|
password: URI.decode(parsed_url.password),
|
|
}
|
|
WebHook.post(post_url,
|
|
body: data.to_json,
|
|
headers: {"Content-Type" => "application/json"},
|
|
basic_auth: auth)
|
|
end
|
|
end
|
|
|
|
def async_execute(data)
|
|
Sidekiq::Client.enqueue(ProjectWebHookWorker, id, data)
|
|
end
|
|
end
|