From a5ae5bf6e583b7ec99f527a9970d12109e2b5d79 Mon Sep 17 00:00:00 2001 From: Beth Skurrie Date: Tue, 19 Jun 2018 20:10:28 +1000 Subject: [PATCH] fix: ensure non utf-8 characters in the webook response do not cause an error in the Pact Broker response body --- lib/pact_broker/domain/webhook_request.rb | 33 ++++++++++++++----- .../domain/webhook_request_spec.rb | 4 +-- 2 files changed, 27 insertions(+), 10 deletions(-) diff --git a/lib/pact_broker/domain/webhook_request.rb b/lib/pact_broker/domain/webhook_request.rb index 698e3e7c3..9ac139475 100644 --- a/lib/pact_broker/domain/webhook_request.rb +++ b/lib/pact_broker/domain/webhook_request.rb @@ -8,6 +8,7 @@ require 'pact_broker/api/pact_broker_urls' require 'pact_broker/build_http_options' require 'cgi' +require 'delegate' module PactBroker @@ -22,6 +23,24 @@ def initialize message, response end + class WebhookResponseWithUtf8SafeBody < SimpleDelegator + def body + if unsafe_body + unsafe_body.encode('UTF-8', 'binary', invalid: :replace, undef: :replace, replace: '') + else + unsafe_body + end + end + + def unsafe_body + __getobj__().body + end + + def unsafe_body? + unsafe_body != body + end + end + class WebhookRequest include PactBroker::Logging @@ -110,9 +129,10 @@ def build_request uri, pact, verification, execution_logger def do_request uri, req logger.info "Making webhook #{uuid} request #{to_s}" options = PactBroker::BuildHttpOptions.call(uri) - Net::HTTP.start(uri.hostname, uri.port, :ENV, options) do |http| + response = Net::HTTP.start(uri.hostname, uri.port, :ENV, options) do |http| http.request req end + WebhookResponseWithUtf8SafeBody.new(response) end def log_response response, execution_logger, options @@ -131,7 +151,7 @@ def response_body_hidden_message def log_response_to_application_logger response logger.info "Received response for webhook #{uuid} status=#{response.code}" logger.debug "headers=#{response.to_hash}" - logger.debug "body=#{response.body}" + logger.debug "body=#{response.unsafe_body}" end def log_response_to_execution_logger response, execution_logger @@ -140,15 +160,12 @@ def log_response_to_execution_logger response, execution_logger execution_logger.info "#{header.split("-").collect(&:capitalize).join('-')}: #{response[header]}" end - safe_body = nil - if response.body - safe_body = response.body.encode('UTF-8', 'binary', invalid: :replace, undef: :replace, replace: '') - if response.body != safe_body + if response.unsafe_body? execution_logger.debug "Note that invalid UTF-8 byte sequences were removed from response body before saving the logs" end + execution_logger.info response.body end - execution_logger.info safe_body end def log_completion_message options, execution_logger, success @@ -182,7 +199,7 @@ def http_request(uri) end def build_uri(pact, verification) - URI(PactBroker::Webhooks::Render.call(url, pact, verification){ | value | CGI::escape(value)} ) + URI(PactBroker::Webhooks::Render.call(url, pact, verification){ | value | CGI::escape(value) if !value.nil? } ) end def url_with_credentials pact, verification diff --git a/spec/lib/pact_broker/domain/webhook_request_spec.rb b/spec/lib/pact_broker/domain/webhook_request_spec.rb index ab315d653..e40eb7ca8 100644 --- a/spec/lib/pact_broker/domain/webhook_request_spec.rb +++ b/spec/lib/pact_broker/domain/webhook_request_spec.rb @@ -299,7 +299,7 @@ module Domain end it "sets the response on the result" do - expect(execute.response).to be_instance_of(Net::HTTPOK) + expect(execute.response).to be_instance_of(WebhookResponseWithUtf8SafeBody) end end @@ -316,7 +316,7 @@ module Domain end it "sets the response on the result" do - expect(execute.response).to be_instance_of(Net::HTTPInternalServerError) + expect(execute.response).to be_instance_of(WebhookResponseWithUtf8SafeBody) end end