pact_broker 2.106.0 → 2.107.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +24 -0
- data/Gemfile +3 -0
- data/db/migrations/20230131_add_cons_ver_id_ndx_to_latest_pp_id_for_cons_ver.rb +8 -4
- data/db/migrations/20230216_add_branch_heads_branch_version_id_index.rb +21 -0
- data/db/migrations/20230428_add_index_for_webhook_executions_pact_publication_id.rb +17 -0
- data/lib/pact_broker/api/contracts/base_contract.rb +22 -7
- data/lib/pact_broker/api/contracts/can_i_deploy_query_schema.rb +34 -0
- data/lib/pact_broker/api/contracts/configuration.rb +2 -0
- data/lib/pact_broker/api/contracts/consumer_version_selector_contract.rb +140 -0
- data/lib/pact_broker/api/contracts/dry_validation_errors_formatter.rb +50 -0
- data/lib/pact_broker/api/contracts/dry_validation_macros.rb +79 -0
- data/lib/pact_broker/api/contracts/dry_validation_methods.rb +71 -0
- data/lib/pact_broker/api/contracts/environment_schema.rb +19 -33
- data/lib/pact_broker/api/contracts/pacticipant_create_schema.rb +4 -17
- data/lib/pact_broker/api/contracts/pacticipant_schema.rb +15 -24
- data/lib/pact_broker/api/contracts/pacts_for_verification_json_query_schema.rb +37 -146
- data/lib/pact_broker/api/contracts/pacts_for_verification_query_string_schema.rb +7 -20
- data/lib/pact_broker/api/contracts/publish_contracts_contract_contract.rb +62 -0
- data/lib/pact_broker/api/contracts/publish_contracts_schema.rb +25 -124
- data/lib/pact_broker/api/contracts/put_pact_params_contract.rb +21 -26
- data/lib/pact_broker/api/contracts/utf_8_validation.rb +2 -0
- data/lib/pact_broker/api/contracts/validation_helpers.rb +71 -0
- data/lib/pact_broker/api/contracts/verification_contract.rb +10 -29
- data/lib/pact_broker/api/contracts/webhook_contract.rb +20 -172
- data/lib/pact_broker/api/contracts/webhook_pacticipant_contract.rb +33 -0
- data/lib/pact_broker/api/contracts/webhook_request_contract.rb +125 -0
- data/lib/pact_broker/api/contracts.rb +3 -0
- data/lib/pact_broker/api/decorators/custom_error_problem_json_decorator.rb +4 -4
- data/lib/pact_broker/api/decorators/dashboard_text_decorator.rb +2 -2
- data/lib/pact_broker/api/decorators/extended_pact_decorator.rb +1 -1
- data/lib/pact_broker/api/decorators/matrix_decorator.rb +4 -4
- data/lib/pact_broker/api/decorators/matrix_text_decorator.rb +1 -1
- data/lib/pact_broker/api/decorators/pact_decorator.rb +1 -1
- data/lib/pact_broker/api/decorators/pacticipant_collection_decorator.rb +2 -2
- data/lib/pact_broker/api/decorators/pacticipant_decorator.rb +2 -1
- data/lib/pact_broker/api/decorators/pacts_for_verification_query_decorator.rb +4 -1
- data/lib/pact_broker/api/decorators/pagination_links.rb +6 -6
- data/lib/pact_broker/api/decorators/runtime_error_problem_json_decorator.rb +4 -4
- data/lib/pact_broker/api/decorators/validation_errors_problem_json_decorator.rb +6 -6
- data/lib/pact_broker/api/decorators/verifiable_pact_decorator.rb +4 -4
- data/lib/pact_broker/api/decorators/webhook_decorator.rb +2 -3
- data/lib/pact_broker/api/decorators/webhook_execution_result_decorator.rb +5 -12
- data/lib/pact_broker/api/resources/all_webhooks.rb +5 -11
- data/lib/pact_broker/api/resources/base_resource.rb +3 -20
- data/lib/pact_broker/api/resources/branch_version.rb +3 -3
- data/lib/pact_broker/api/resources/can_i_deploy.rb +4 -19
- data/lib/pact_broker/api/resources/can_i_deploy_pacticipant_version_by_branch_to_environment.rb +1 -4
- data/lib/pact_broker/api/resources/can_i_deploy_pacticipant_version_by_tag_to_tag.rb +0 -2
- data/lib/pact_broker/api/resources/can_i_deploy_pacticipant_version_by_tag_to_tag_badge.rb +1 -2
- data/lib/pact_broker/api/resources/currently_deployed_versions_for_environment.rb +2 -2
- data/lib/pact_broker/api/resources/currently_supported_versions_for_environment.rb +2 -2
- data/lib/pact_broker/api/resources/dashboard.rb +3 -3
- data/lib/pact_broker/api/resources/deployed_version.rb +1 -1
- data/lib/pact_broker/api/resources/deployed_versions_for_version_and_environment.rb +2 -2
- data/lib/pact_broker/api/resources/environment.rb +1 -1
- data/lib/pact_broker/api/resources/environments.rb +2 -2
- data/lib/pact_broker/api/resources/error_handling_methods.rb +2 -2
- data/lib/pact_broker/api/resources/integrations.rb +1 -1
- data/lib/pact_broker/api/resources/label.rb +1 -1
- data/lib/pact_broker/api/resources/latest_pact.rb +2 -2
- data/lib/pact_broker/api/resources/latest_pacts.rb +1 -1
- data/lib/pact_broker/api/resources/latest_verifications_for_consumer_version.rb +1 -1
- data/lib/pact_broker/api/resources/matrix.rb +2 -2
- data/lib/pact_broker/api/resources/matrix_for_consumer_and_provider.rb +1 -1
- data/lib/pact_broker/api/resources/pact.rb +7 -4
- data/lib/pact_broker/api/resources/pact_triggered_webhooks.rb +1 -1
- data/lib/pact_broker/api/resources/pact_versions.rb +1 -1
- data/lib/pact_broker/api/resources/pact_webhooks.rb +7 -14
- data/lib/pact_broker/api/resources/pact_webhooks_status.rb +6 -2
- data/lib/pact_broker/api/resources/pacticipant.rb +1 -1
- data/lib/pact_broker/api/resources/pacticipant_webhooks.rb +7 -5
- data/lib/pact_broker/api/resources/pacticipants.rb +2 -2
- data/lib/pact_broker/api/resources/pacticipants_for_label.rb +1 -1
- data/lib/pact_broker/api/resources/previous_distinct_pact_version.rb +1 -1
- data/lib/pact_broker/api/resources/provider_pacts.rb +1 -1
- data/lib/pact_broker/api/resources/provider_pacts_for_verification.rb +4 -13
- data/lib/pact_broker/api/resources/publish_contracts.rb +8 -3
- data/lib/pact_broker/api/resources/released_version.rb +1 -1
- data/lib/pact_broker/api/resources/released_versions_for_version_and_environment.rb +2 -2
- data/lib/pact_broker/api/resources/tag.rb +1 -1
- data/lib/pact_broker/api/resources/tagged_pact_versions.rb +1 -1
- data/lib/pact_broker/api/resources/triggered_webhook_logs.rb +2 -2
- data/lib/pact_broker/api/resources/verification.rb +2 -2
- data/lib/pact_broker/api/resources/verification_triggered_webhooks.rb +1 -1
- data/lib/pact_broker/api/resources/verifications.rb +4 -6
- data/lib/pact_broker/api/resources/version.rb +1 -1
- data/lib/pact_broker/api/resources/versions.rb +1 -1
- data/lib/pact_broker/api/resources/webhook.rb +7 -6
- data/lib/pact_broker/api/resources/webhook_execution.rb +6 -4
- data/lib/pact_broker/api.rb +3 -12
- data/lib/pact_broker/certificates/certificate.rb +1 -0
- data/lib/pact_broker/config/setting.rb +1 -0
- data/lib/pact_broker/contracts/service.rb +1 -0
- data/lib/pact_broker/date_helper.rb +1 -1
- data/lib/pact_broker/db/clean_incremental.rb +1 -1
- data/lib/pact_broker/db/delete_overwritten_data.rb +6 -2
- data/lib/pact_broker/deployments/currently_deployed_version_id.rb +2 -0
- data/lib/pact_broker/deployments/deployed_version.rb +2 -0
- data/lib/pact_broker/deployments/deployed_version_service.rb +5 -1
- data/lib/pact_broker/deployments/environment.rb +2 -0
- data/lib/pact_broker/deployments/environment_service.rb +4 -3
- data/lib/pact_broker/deployments/released_version.rb +2 -0
- data/lib/pact_broker/deployments/released_version_service.rb +4 -0
- data/lib/pact_broker/diagnostic/resources/base_resource.rb +1 -1
- data/lib/pact_broker/doc/views/index/publish-contracts.markdown +5 -5
- data/lib/pact_broker/domain/label.rb +1 -0
- data/lib/pact_broker/domain/tag.rb +2 -0
- data/lib/pact_broker/domain/verification.rb +1 -1
- data/lib/pact_broker/domain/version.rb +4 -1
- data/lib/pact_broker/domain/webhook.rb +1 -1
- data/lib/pact_broker/index/service.rb +1 -1
- data/lib/pact_broker/integrations/integration.rb +1 -0
- data/lib/pact_broker/locale/en.yml +35 -14
- data/lib/pact_broker/matrix/query_ids.rb +4 -4
- data/lib/pact_broker/matrix/resolved_selector.rb +6 -1
- data/lib/pact_broker/matrix/service.rb +1 -0
- data/lib/pact_broker/messages.rb +5 -1
- data/lib/pact_broker/pacticipants/repository.rb +12 -3
- data/lib/pact_broker/pacticipants/service.rb +7 -0
- data/lib/pact_broker/pacts/pact_params.rb +6 -17
- data/lib/pact_broker/pacts/pact_version.rb +1 -0
- data/lib/pact_broker/policies.rb +4 -4
- data/lib/pact_broker/test/http_test_data_builder.rb +46 -2
- data/lib/pact_broker/ui/app.rb +2 -2
- data/lib/pact_broker/verifications/latest_verification_id_for_pact_version_and_provider_version.rb +1 -1
- data/lib/pact_broker/verifications/pact_version_provider_tag_successful_verification.rb +1 -0
- data/lib/pact_broker/verifications/service.rb +0 -6
- data/lib/pact_broker/version.rb +1 -1
- data/lib/pact_broker/versions/branch.rb +1 -0
- data/lib/pact_broker/versions/branch_head.rb +2 -1
- data/lib/pact_broker/versions/branch_version.rb +11 -0
- data/lib/pact_broker/webhooks/execution.rb +1 -1
- data/lib/pact_broker/webhooks/repository.rb +1 -1
- data/lib/pact_broker/webhooks/service.rb +3 -25
- data/lib/pact_broker/webhooks/triggered_webhook.rb +1 -0
- data/lib/pact_broker/webhooks/webhook_event.rb +1 -0
- data/lib/pact_broker/webmachine.rb +22 -0
- data/lib/rack/pact_broker/invalid_uri_protection.rb +1 -1
- data/lib/rack/pact_broker/use_when.rb +6 -5
- data/lib/sequel/plugins/age.rb +13 -0
- data/lib/webmachine/application_monkey_patch.rb +5 -0
- data/lib/webmachine/describe_routes.rb +35 -8
- data/lib/webmachine/render_error_monkey_patch.rb +1 -1
- data/pact_broker.gemspec +7 -17
- metadata +65 -67
- data/lib/pact/doc/README.md +0 -5
- data/lib/pact_broker/api/contracts/dry_validation_predicates.rb +0 -36
- data/lib/pact_broker/api/contracts/dry_validation_workarounds.rb +0 -39
- data/lib/pact_broker/api/contracts/pacticipant_name_contract.rb +0 -24
- data/lib/pact_broker/api/contracts/pacticipant_name_validation.rb +0 -30
- data/lib/pact_broker/api/contracts/request_validations.rb +0 -33
- data/lib/pact_broker/api/resources/webhook_resource_methods.rb +0 -17
- data/lib/pact_broker/matrix/can_i_deploy_query_schema.rb +0 -46
@@ -18,7 +18,7 @@ module PactBroker
|
|
18
18
|
|
19
19
|
property :uuid
|
20
20
|
|
21
|
-
property :description, getter: lambda { |
|
21
|
+
property :description, getter: lambda { |represented:, **| represented.display_description }
|
22
22
|
|
23
23
|
property :consumer, class: Domain::WebhookPacticipant, default: nil do
|
24
24
|
property :name
|
@@ -42,7 +42,6 @@ module PactBroker
|
|
42
42
|
title: represented.display_description,
|
43
43
|
href: webhook_url(represented.uuid, options[:base_url])
|
44
44
|
}
|
45
|
-
|
46
45
|
end
|
47
46
|
|
48
47
|
link :'pb:execute' do | options |
|
@@ -108,7 +107,7 @@ module PactBroker
|
|
108
107
|
}
|
109
108
|
end
|
110
109
|
|
111
|
-
def from_json
|
110
|
+
def from_json(represented)
|
112
111
|
super.tap do | webhook |
|
113
112
|
if webhook.events == nil
|
114
113
|
webhook.events = [PactBroker::Webhooks::WebhookEvent.new(name: PactBroker::Webhooks::WebhookEvent::DEFAULT_EVENT_NAME)]
|
@@ -56,10 +56,12 @@ module PactBroker
|
|
56
56
|
end
|
57
57
|
end
|
58
58
|
|
59
|
-
property :error, :extend => ErrorDecorator, if: lambda { |
|
59
|
+
property :error, :extend => ErrorDecorator, if: lambda { |options:, **| options.dig(:user_options, :show_response) }
|
60
60
|
property :request, :extend => HTTPRequestDecorator
|
61
|
-
property :response, :extend => HTTPResponseDecorator, if: lambda { |
|
62
|
-
property :
|
61
|
+
property :response, :extend => HTTPResponseDecorator, if: lambda { |options:, **| options.dig(:user_options, :show_response) }
|
62
|
+
property :message,
|
63
|
+
if: lambda { |options:, **| !options.dig(:user_options, :show_response) },
|
64
|
+
getter: lambda { |options:, **| PactBroker::Messages.message("messages.response_body_hidden", base_url: options.dig(:user_options, :base_url)) }
|
63
65
|
property :logs
|
64
66
|
property :success?, as: :success
|
65
67
|
|
@@ -77,15 +79,6 @@ module PactBroker
|
|
77
79
|
href: options.fetch(:resource_url)
|
78
80
|
}
|
79
81
|
end
|
80
|
-
|
81
|
-
def to_hash(options)
|
82
|
-
@to_hash_options = options
|
83
|
-
super
|
84
|
-
end
|
85
|
-
|
86
|
-
def response_hidden_message
|
87
|
-
PactBroker::Messages.message("messages.response_body_hidden", base_url: @to_hash_options[:user_options][:base_url])
|
88
|
-
end
|
89
82
|
end
|
90
83
|
end
|
91
84
|
end
|
@@ -30,16 +30,16 @@ module PactBroker
|
|
30
30
|
end
|
31
31
|
|
32
32
|
def malformed_request?
|
33
|
-
super || (request.post? &&
|
33
|
+
super || (request.post? && validation_errors_for_schema?)
|
34
34
|
end
|
35
35
|
|
36
36
|
def to_json
|
37
|
-
decorator_class(:webhooks_decorator).new(webhooks).to_json(decorator_options(resource_title: "Webhooks"))
|
37
|
+
decorator_class(:webhooks_decorator).new(webhooks).to_json(**decorator_options(resource_title: "Webhooks"))
|
38
38
|
end
|
39
39
|
|
40
40
|
def from_json
|
41
41
|
saved_webhook = webhook_service.create(next_uuid, webhook, consumer, provider)
|
42
|
-
response.body = decorator_class(:webhook_decorator).new(saved_webhook).to_json(decorator_options)
|
42
|
+
response.body = decorator_class(:webhook_decorator).new(saved_webhook).to_json(**decorator_options)
|
43
43
|
end
|
44
44
|
|
45
45
|
def policy_name
|
@@ -56,14 +56,8 @@ module PactBroker
|
|
56
56
|
|
57
57
|
private
|
58
58
|
|
59
|
-
def
|
60
|
-
|
61
|
-
|
62
|
-
unless errors.empty?
|
63
|
-
set_json_validation_error_messages(errors.messages)
|
64
|
-
end
|
65
|
-
|
66
|
-
!errors.empty?
|
59
|
+
def schema
|
60
|
+
api_contract_class(:webhook_contract)
|
67
61
|
end
|
68
62
|
|
69
63
|
def consumer
|
@@ -67,12 +67,11 @@ module PactBroker
|
|
67
67
|
end
|
68
68
|
end
|
69
69
|
|
70
|
-
#
|
70
|
+
# Remove the non-path compontents in the path_info (eg. the application context, which is naughtily passed in via the path_info)
|
71
71
|
def identifier_from_path
|
72
72
|
@identifier_from_path ||= request.path_info.each_with_object({}) do | (key, value), hash|
|
73
|
-
|
74
|
-
|
75
|
-
elsif value.is_a?(Symbol) || value.is_a?(Numeric)
|
73
|
+
case value
|
74
|
+
when String, Symbol, Numeric
|
76
75
|
hash[key] = value
|
77
76
|
end
|
78
77
|
end
|
@@ -204,22 +203,6 @@ module PactBroker
|
|
204
203
|
end
|
205
204
|
end
|
206
205
|
|
207
|
-
def validation_errors? model
|
208
|
-
if (errors = model.validate).any?
|
209
|
-
set_json_validation_error_messages errors
|
210
|
-
true
|
211
|
-
else
|
212
|
-
false
|
213
|
-
end
|
214
|
-
end
|
215
|
-
|
216
|
-
def contract_validation_errors? contract, params
|
217
|
-
if (invalid = !contract.validate(params))
|
218
|
-
set_json_validation_error_messages contract.errors.messages
|
219
|
-
end
|
220
|
-
invalid
|
221
|
-
end
|
222
|
-
|
223
206
|
def find_pacticipant name, role
|
224
207
|
pacticipant_service.find_pacticipant_by_name(name).tap do | pacticipant |
|
225
208
|
if pacticipant.nil?
|
@@ -26,7 +26,7 @@ module PactBroker
|
|
26
26
|
end
|
27
27
|
|
28
28
|
def to_json
|
29
|
-
decorator_class(:branch_version_decorator).new(branch_version).to_json(decorator_options)
|
29
|
+
decorator_class(:branch_version_decorator).new(branch_version).to_json(**decorator_options)
|
30
30
|
end
|
31
31
|
|
32
32
|
def delete_resource
|
@@ -36,7 +36,7 @@ module PactBroker
|
|
36
36
|
|
37
37
|
def from_json
|
38
38
|
already_existed = !!branch_version
|
39
|
-
@branch_version = branch_service.find_or_create_branch_version(identifier_from_path)
|
39
|
+
@branch_version = branch_service.find_or_create_branch_version(**identifier_from_path)
|
40
40
|
# Make it return a 201 by setting the Location header
|
41
41
|
response.headers["Location"] = branch_version_url(branch_version, base_url) unless already_existed
|
42
42
|
response.body = to_json
|
@@ -49,7 +49,7 @@ module PactBroker
|
|
49
49
|
private
|
50
50
|
|
51
51
|
def branch_version
|
52
|
-
@branch_version ||= branch_service.find_branch_version(identifier_from_path)
|
52
|
+
@branch_version ||= branch_service.find_branch_version(**identifier_from_path)
|
53
53
|
end
|
54
54
|
end
|
55
55
|
end
|
@@ -1,5 +1,5 @@
|
|
1
1
|
require "pact_broker/api/resources/matrix"
|
2
|
-
require "pact_broker/
|
2
|
+
require "pact_broker/api/contracts/can_i_deploy_query_schema"
|
3
3
|
require "pact_broker/matrix/parse_can_i_deploy_query"
|
4
4
|
require "pact_broker/messages"
|
5
5
|
|
@@ -9,16 +9,9 @@ module PactBroker
|
|
9
9
|
class CanIDeploy < Matrix
|
10
10
|
include PactBroker::Messages
|
11
11
|
|
12
|
+
# Can't call super because it will execute the Matrix validation, not the BaseResource validation
|
12
13
|
def malformed_request?
|
13
|
-
|
14
|
-
set_json_validation_error_messages(errors)
|
15
|
-
true
|
16
|
-
elsif !pacticipant
|
17
|
-
set_json_validation_error_messages(pacticipant: [message("errors.validation.pacticipant_not_found", name: pacticipant_name)])
|
18
|
-
true
|
19
|
-
else
|
20
|
-
false
|
21
|
-
end
|
14
|
+
request.get? && validation_errors_for_schema?(schema, request.query)
|
22
15
|
end
|
23
16
|
|
24
17
|
def policy_name
|
@@ -27,18 +20,10 @@ module PactBroker
|
|
27
20
|
|
28
21
|
private
|
29
22
|
|
30
|
-
def
|
23
|
+
def schema
|
31
24
|
PactBroker::Api::Contracts::CanIDeployQuerySchema
|
32
25
|
end
|
33
26
|
|
34
|
-
def pacticipant
|
35
|
-
@pacticipant ||= pacticipant_service.find_pacticipant_by_name(pacticipant_name)
|
36
|
-
end
|
37
|
-
|
38
|
-
def pacticipant_name
|
39
|
-
selectors.first.pacticipant_name
|
40
|
-
end
|
41
|
-
|
42
27
|
def parsed_query
|
43
28
|
@parsed_query ||= PactBroker::Matrix::ParseCanIDeployQuery.call(query_params)
|
44
29
|
end
|
data/lib/pact_broker/api/resources/can_i_deploy_pacticipant_version_by_branch_to_environment.rb
CHANGED
@@ -1,8 +1,5 @@
|
|
1
1
|
require "pact_broker/api/resources/matrix"
|
2
|
-
require "pact_broker/matrix/can_i_deploy_query_schema"
|
3
|
-
require "pact_broker/matrix/parse_can_i_deploy_query"
|
4
2
|
require "pact_broker/api/decorators/matrix_decorator"
|
5
|
-
require "pact_broker/api/decorators/matrix_text_decorator"
|
6
3
|
|
7
4
|
module PactBroker
|
8
5
|
module Api
|
@@ -47,7 +44,7 @@ module PactBroker
|
|
47
44
|
end
|
48
45
|
|
49
46
|
def to_json
|
50
|
-
decorator_class(:matrix_decorator).new(results).to_json(decorator_options)
|
47
|
+
decorator_class(:matrix_decorator).new(results).to_json(**decorator_options)
|
51
48
|
end
|
52
49
|
|
53
50
|
def results
|
@@ -21,7 +21,7 @@ module PactBroker
|
|
21
21
|
end
|
22
22
|
|
23
23
|
def to_json
|
24
|
-
decorator_class(decorator_name).new(deployed_versions).to_json(decorator_options(title: title))
|
24
|
+
decorator_class(decorator_name).new(deployed_versions).to_json(**decorator_options(title: title))
|
25
25
|
end
|
26
26
|
|
27
27
|
def policy_name
|
@@ -43,7 +43,7 @@ module PactBroker
|
|
43
43
|
end
|
44
44
|
|
45
45
|
def deployed_versions
|
46
|
-
@deployed_versions ||= deployed_version_service.find_currently_deployed_versions_for_environment(environment, query_params)
|
46
|
+
@deployed_versions ||= deployed_version_service.find_currently_deployed_versions_for_environment(environment, **query_params)
|
47
47
|
end
|
48
48
|
|
49
49
|
def environment_uuid
|
@@ -21,7 +21,7 @@ module PactBroker
|
|
21
21
|
end
|
22
22
|
|
23
23
|
def to_json
|
24
|
-
decorator_class(decorator_name).new(released_versions).to_json(decorator_options(title: title))
|
24
|
+
decorator_class(decorator_name).new(released_versions).to_json(**decorator_options(title: title))
|
25
25
|
end
|
26
26
|
|
27
27
|
def policy_name
|
@@ -43,7 +43,7 @@ module PactBroker
|
|
43
43
|
end
|
44
44
|
|
45
45
|
def released_versions
|
46
|
-
@released_versions ||= released_version_service.find_currently_supported_versions_for_environment(environment, query_params)
|
46
|
+
@released_versions ||= released_version_service.find_currently_supported_versions_for_environment(environment, **query_params)
|
47
47
|
end
|
48
48
|
|
49
49
|
def environment_uuid
|
@@ -21,11 +21,11 @@ module PactBroker
|
|
21
21
|
end
|
22
22
|
|
23
23
|
def to_json
|
24
|
-
decorator_class(:dashboard_decorator).new(index_items).to_json(decorator_options)
|
24
|
+
decorator_class(:dashboard_decorator).new(index_items).to_json(**decorator_options)
|
25
25
|
end
|
26
26
|
|
27
27
|
def to_text
|
28
|
-
decorator_class(:dashboard_text_decorator).new(index_items).to_text(decorator_options)
|
28
|
+
decorator_class(:dashboard_text_decorator).new(index_items).to_text(**decorator_options)
|
29
29
|
end
|
30
30
|
|
31
31
|
def policy_name
|
@@ -35,7 +35,7 @@ module PactBroker
|
|
35
35
|
private
|
36
36
|
|
37
37
|
def index_items
|
38
|
-
index_service.find_index_items_for_api(identifier_from_path.merge(pagination_options))
|
38
|
+
index_service.find_index_items_for_api(**identifier_from_path.merge(pagination_options))
|
39
39
|
end
|
40
40
|
end
|
41
41
|
end
|
@@ -33,7 +33,7 @@ module PactBroker
|
|
33
33
|
end
|
34
34
|
|
35
35
|
def to_json
|
36
|
-
decorator_class(:deployed_version_decorator).new(deployed_version).to_json(decorator_options)
|
36
|
+
decorator_class(:deployed_version_decorator).new(deployed_version).to_json(**decorator_options)
|
37
37
|
end
|
38
38
|
|
39
39
|
def from_merge_patch_json
|
@@ -32,11 +32,11 @@ module PactBroker
|
|
32
32
|
def from_json
|
33
33
|
@deployed_version = deployed_version_service.find_or_create(deployed_version_uuid, version, environment, application_instance)
|
34
34
|
response.headers["Location"] = deployed_version_url(deployed_version, base_url)
|
35
|
-
response.body = decorator_class(:deployed_version_decorator).new(deployed_version).to_json(decorator_options)
|
35
|
+
response.body = decorator_class(:deployed_version_decorator).new(deployed_version).to_json(**decorator_options)
|
36
36
|
end
|
37
37
|
|
38
38
|
def to_json
|
39
|
-
decorator_class(:deployed_versions_decorator).new(deployed_versions).to_json(decorator_options(title: title))
|
39
|
+
decorator_class(:deployed_versions_decorator).new(deployed_versions).to_json(**decorator_options(title: title))
|
40
40
|
end
|
41
41
|
|
42
42
|
def policy_name
|
@@ -35,7 +35,7 @@ module PactBroker
|
|
35
35
|
end
|
36
36
|
|
37
37
|
def from_json
|
38
|
-
response.body = decorator_class(:environment_decorator).new(create_environment).to_json(decorator_options)
|
38
|
+
response.body = decorator_class(:environment_decorator).new(create_environment).to_json(**decorator_options)
|
39
39
|
end
|
40
40
|
|
41
41
|
def policy_name
|
@@ -43,7 +43,7 @@ module PactBroker
|
|
43
43
|
end
|
44
44
|
|
45
45
|
def to_json
|
46
|
-
decorator_class(:environments_decorator).new(environments).to_json(decorator_options)
|
46
|
+
decorator_class(:environments_decorator).new(environments).to_json(**decorator_options)
|
47
47
|
end
|
48
48
|
|
49
49
|
def parsed_environment
|
@@ -26,7 +26,7 @@ module PactBroker
|
|
26
26
|
def set_json_validation_error_messages errors
|
27
27
|
response.headers["Content-Type"] = error_response_content_type
|
28
28
|
if problem_json_error_content_type?
|
29
|
-
response.body = PactBroker::Api::Decorators::ValidationErrorsProblemJSONDecorator.new(errors).to_json(decorator_options)
|
29
|
+
response.body = PactBroker::Api::Decorators::ValidationErrorsProblemJSONDecorator.new(errors).to_json(**decorator_options)
|
30
30
|
else
|
31
31
|
response.body = { errors: errors }.to_json
|
32
32
|
end
|
@@ -42,7 +42,7 @@ module PactBroker
|
|
42
42
|
|
43
43
|
def error_response_body(detail, title, type, status)
|
44
44
|
if problem_json_error_content_type?
|
45
|
-
PactBroker::Api::Decorators::CustomErrorProblemJSONDecorator.new(detail: detail, title: title, type: type, status: status).to_json(decorator_options)
|
45
|
+
PactBroker::Api::Decorators::CustomErrorProblemJSONDecorator.new(detail: detail, title: title, type: type, status: status).to_json(**decorator_options)
|
46
46
|
else
|
47
47
|
{ error: detail }.to_json
|
48
48
|
end
|
@@ -30,11 +30,11 @@ module PactBroker
|
|
30
30
|
|
31
31
|
def to_json
|
32
32
|
response.headers["X-Pact-Consumer-Version"] = pact.consumer_version_number
|
33
|
-
decorator_class(:pact_decorator).new(pact).to_json(decorator_options(metadata: metadata))
|
33
|
+
decorator_class(:pact_decorator).new(pact).to_json(**decorator_options(metadata: metadata))
|
34
34
|
end
|
35
35
|
|
36
36
|
def to_extended_json
|
37
|
-
decorator_class(:extended_pact_decorator).new(pact).to_json(decorator_options(metadata: metadata))
|
37
|
+
decorator_class(:extended_pact_decorator).new(pact).to_json(**decorator_options(metadata: metadata))
|
38
38
|
end
|
39
39
|
|
40
40
|
def to_html
|
@@ -23,7 +23,7 @@ module PactBroker
|
|
23
23
|
|
24
24
|
def to_json
|
25
25
|
summary = verification_service.verification_summary_for_consumer_version(identifier_from_path)
|
26
|
-
decorator_for(summary).to_json(decorator_options(identifier_from_path))
|
26
|
+
decorator_for(summary).to_json(**decorator_options(identifier_from_path))
|
27
27
|
end
|
28
28
|
|
29
29
|
def policy_name
|
@@ -29,11 +29,11 @@ module PactBroker
|
|
29
29
|
end
|
30
30
|
|
31
31
|
def to_json
|
32
|
-
decorator_class(:matrix_decorator).new(results).to_json(decorator_options)
|
32
|
+
decorator_class(:matrix_decorator).new(results).to_json(**decorator_options)
|
33
33
|
end
|
34
34
|
|
35
35
|
def to_text
|
36
|
-
decorator_class(:matrix_text_decorator).new(results).to_text(decorator_options)
|
36
|
+
decorator_class(:matrix_text_decorator).new(results).to_text(**decorator_options)
|
37
37
|
end
|
38
38
|
|
39
39
|
def policy_name
|
@@ -54,9 +54,8 @@ module PactBroker
|
|
54
54
|
potential_duplicate_pacticipants?(pact_params.pacticipant_names) || merge_conflict || disallowed_modification?
|
55
55
|
end
|
56
56
|
|
57
|
-
|
58
57
|
def malformed_request?
|
59
|
-
super || ((request.patch? || request.really_put?) &&
|
58
|
+
super || ((request.patch? || request.really_put?) && validation_errors_for_schema?(schema, pact_params.to_hash_for_validation))
|
60
59
|
end
|
61
60
|
|
62
61
|
def resource_exists?
|
@@ -78,11 +77,11 @@ module PactBroker
|
|
78
77
|
end
|
79
78
|
|
80
79
|
def to_json
|
81
|
-
decorator_class(:pact_decorator).new(pact).to_json(decorator_options(metadata: identifier_from_path[:metadata]))
|
80
|
+
decorator_class(:pact_decorator).new(pact).to_json(**decorator_options(metadata: identifier_from_path[:metadata]))
|
82
81
|
end
|
83
82
|
|
84
83
|
def to_extended_json
|
85
|
-
decorator_class(:extended_pact_decorator).new(pact).to_json(decorator_options(metadata: identifier_from_path[:metadata]))
|
84
|
+
decorator_class(:extended_pact_decorator).new(pact).to_json(**decorator_options(metadata: identifier_from_path[:metadata]))
|
86
85
|
end
|
87
86
|
|
88
87
|
def to_html
|
@@ -118,6 +117,10 @@ module PactBroker
|
|
118
117
|
false
|
119
118
|
end
|
120
119
|
end
|
120
|
+
|
121
|
+
def schema
|
122
|
+
api_contract_class(:put_pact_params_contract)
|
123
|
+
end
|
121
124
|
end
|
122
125
|
end
|
123
126
|
end
|
@@ -18,7 +18,7 @@ module PactBroker
|
|
18
18
|
end
|
19
19
|
|
20
20
|
def to_json
|
21
|
-
decorator_class(:triggered_webhooks_decorator).new(triggered_webhooks).to_json(decorator_options(resource_title: resource_title))
|
21
|
+
decorator_class(:triggered_webhooks_decorator).new(triggered_webhooks).to_json(**decorator_options(resource_title: resource_title))
|
22
22
|
end
|
23
23
|
|
24
24
|
def policy_name
|
@@ -19,7 +19,7 @@ module PactBroker
|
|
19
19
|
end
|
20
20
|
|
21
21
|
def to_json
|
22
|
-
decorator_class(:pact_versions_decorator).new(pacts).to_json(decorator_options(identifier_from_path))
|
22
|
+
decorator_class(:pact_versions_decorator).new(pacts).to_json(**decorator_options(identifier_from_path))
|
23
23
|
end
|
24
24
|
|
25
25
|
def pacts
|
@@ -25,18 +25,7 @@ module PactBroker
|
|
25
25
|
end
|
26
26
|
|
27
27
|
def malformed_request?
|
28
|
-
super || (request.post? &&
|
29
|
-
end
|
30
|
-
|
31
|
-
def validation_errors? webhook
|
32
|
-
errors = webhook_service.errors(webhook)
|
33
|
-
|
34
|
-
unless errors.empty?
|
35
|
-
response.headers["Content-Type"] = "application/hal+json;charset=utf-8"
|
36
|
-
response.body = { errors: errors.messages }.to_json
|
37
|
-
end
|
38
|
-
|
39
|
-
!errors.empty?
|
28
|
+
super || (request.post? && validation_errors_for_schema?)
|
40
29
|
end
|
41
30
|
|
42
31
|
def create_path
|
@@ -49,11 +38,11 @@ module PactBroker
|
|
49
38
|
|
50
39
|
def from_json
|
51
40
|
saved_webhook = webhook_service.create next_uuid, webhook, consumer, provider
|
52
|
-
response.body = decorator_class(:webhook_decorator).new(saved_webhook).to_json(decorator_options)
|
41
|
+
response.body = decorator_class(:webhook_decorator).new(saved_webhook).to_json(**decorator_options)
|
53
42
|
end
|
54
43
|
|
55
44
|
def to_json
|
56
|
-
decorator_class(:webhooks_decorator).new(webhooks).to_json(decorator_options(resource_title: "Pact webhooks"))
|
45
|
+
decorator_class(:webhooks_decorator).new(webhooks).to_json(**decorator_options(resource_title: "Pact webhooks"))
|
57
46
|
end
|
58
47
|
|
59
48
|
def policy_name
|
@@ -62,6 +51,10 @@ module PactBroker
|
|
62
51
|
|
63
52
|
private
|
64
53
|
|
54
|
+
def schema
|
55
|
+
api_contract_class(:webhook_contract)
|
56
|
+
end
|
57
|
+
|
65
58
|
def webhooks
|
66
59
|
@webhooks ||= webhook_service.find_by_consumer_and_provider consumer, provider
|
67
60
|
end
|
@@ -19,11 +19,15 @@ module PactBroker
|
|
19
19
|
end
|
20
20
|
|
21
21
|
def to_json
|
22
|
-
decorator_for(latest_triggered_webhooks).to_json(decorator_options(identifier_from_path))
|
22
|
+
decorator_for(latest_triggered_webhooks).to_json(**decorator_options(identifier_from_path))
|
23
23
|
end
|
24
24
|
|
25
25
|
def policy_name
|
26
|
-
:'
|
26
|
+
:'pacts::pact'
|
27
|
+
end
|
28
|
+
|
29
|
+
def policy_record
|
30
|
+
pact
|
27
31
|
end
|
28
32
|
|
29
33
|
private
|
@@ -71,7 +71,7 @@ module PactBroker
|
|
71
71
|
end
|
72
72
|
|
73
73
|
def to_json
|
74
|
-
decorator_class(:pacticipant_decorator).new(pacticipant).to_json(decorator_options)
|
74
|
+
decorator_class(:pacticipant_decorator).new(pacticipant).to_json(**decorator_options)
|
75
75
|
end
|
76
76
|
|
77
77
|
def parsed_pacticipant(pacticipant)
|
@@ -2,13 +2,11 @@ require "pact_broker/api/resources/base_resource"
|
|
2
2
|
require "pact_broker/api/decorators/webhook_decorator"
|
3
3
|
require "pact_broker/api/decorators/webhooks_decorator"
|
4
4
|
require "pact_broker/api/contracts/webhook_contract"
|
5
|
-
require "pact_broker/api/resources/webhook_resource_methods"
|
6
5
|
|
7
6
|
module PactBroker
|
8
7
|
module Api
|
9
8
|
module Resources
|
10
9
|
class PacticipantWebhooks < BaseResource
|
11
|
-
include WebhookResourceMethods
|
12
10
|
|
13
11
|
def allowed_methods
|
14
12
|
["POST", "GET", "OPTIONS"]
|
@@ -27,7 +25,7 @@ module PactBroker
|
|
27
25
|
end
|
28
26
|
|
29
27
|
def malformed_request?
|
30
|
-
super || (request.post? &&
|
28
|
+
super || (request.post? && validation_errors_for_schema?)
|
31
29
|
end
|
32
30
|
|
33
31
|
def create_path
|
@@ -40,11 +38,11 @@ module PactBroker
|
|
40
38
|
|
41
39
|
def from_json
|
42
40
|
saved_webhook = webhook_service.create next_uuid, webhook, consumer, provider
|
43
|
-
response.body = decorator_class(:webhook_decorator).new(saved_webhook).to_json(decorator_options)
|
41
|
+
response.body = decorator_class(:webhook_decorator).new(saved_webhook).to_json(**decorator_options)
|
44
42
|
end
|
45
43
|
|
46
44
|
def to_json
|
47
|
-
decorator_class(:webhooks_decorator).new(webhooks).to_json(decorator_options(resource_title: "Webhooks"))
|
45
|
+
decorator_class(:webhooks_decorator).new(webhooks).to_json(**decorator_options(resource_title: "Webhooks"))
|
48
46
|
end
|
49
47
|
|
50
48
|
def policy_name
|
@@ -57,6 +55,10 @@ module PactBroker
|
|
57
55
|
|
58
56
|
private
|
59
57
|
|
58
|
+
def schema
|
59
|
+
api_contract_class(:webhook_contract)
|
60
|
+
end
|
61
|
+
|
60
62
|
def webhooks
|
61
63
|
webhook_service.find_by_consumer_and_provider(consumer, provider)
|
62
64
|
end
|
@@ -39,7 +39,7 @@ module PactBroker
|
|
39
39
|
|
40
40
|
def from_json
|
41
41
|
created_model = pacticipant_service.create(parsed_pacticipant.to_h)
|
42
|
-
response.body = decorator_for(created_model).to_json(decorator_options)
|
42
|
+
response.body = decorator_for(created_model).to_json(**decorator_options)
|
43
43
|
end
|
44
44
|
|
45
45
|
def create_path
|
@@ -51,7 +51,7 @@ module PactBroker
|
|
51
51
|
end
|
52
52
|
|
53
53
|
def generate_json pacticipants
|
54
|
-
decorator_class(:deprecated_pacticipant_collection_decorator).new(pacticipants).to_json(decorator_options)
|
54
|
+
decorator_class(:deprecated_pacticipant_collection_decorator).new(pacticipants).to_json(**decorator_options)
|
55
55
|
end
|
56
56
|
|
57
57
|
def decorator_for model
|