Skip to content

Commit

Permalink
Use Singlelogout response url in LogoutResponse if set
Browse files Browse the repository at this point in the history
Co-authored-by: Sofia Canclini <[email protected]>
  • Loading branch information
JCB-K and mentimetercanclini committed Dec 8, 2020
1 parent 62ac2fe commit 0cb1843
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 3 deletions.
9 changes: 6 additions & 3 deletions lib/onelogin/ruby-saml/slo_logoutresponse.rb
Original file line number Diff line number Diff line change
Expand Up @@ -32,14 +32,15 @@ def initialize
def create(settings, request_id = nil, logout_message = nil, params = {})
params = create_params(settings, request_id, logout_message, params)
params_prefix = (settings.idp_slo_target_url =~ /\?/) ? '&' : '?'
url = settings.idp_slo_response_service_url || settings.idp_slo_target_url

This comment has been minimized.

Copy link
@yu-allen

yu-allen Mar 24, 2021

Is it suppose to be settings.idp_slo_service_url here and L34?

saml_response = CGI.escape(params.delete("SAMLResponse"))
response_params = "#{params_prefix}SAMLResponse=#{saml_response}"
params.each_pair do |key, value|
response_params << "&#{key.to_s}=#{CGI.escape(value.to_s)}"
end

raise SettingError.new "Invalid settings, idp_slo_target_url is not set!" if settings.idp_slo_target_url.nil? or settings.idp_slo_target_url.empty?
@logout_url = settings.idp_slo_target_url + response_params
raise SettingError.new "Invalid settings, idp_slo_target_url is not set!" if url.nil? or url.empty?
@logout_url = url + response_params
end

# Creates the Get parameters for the logout response.
Expand Down Expand Up @@ -109,12 +110,14 @@ def create_xml_document(settings, request_id = nil, logout_message = nil)
response_doc = XMLSecurity::Document.new
response_doc.uuid = uuid

destination = settings.idp_slo_response_service_url || settings.idp_slo_target_url

root = response_doc.add_element 'samlp:LogoutResponse', { 'xmlns:samlp' => 'urn:oasis:names:tc:SAML:2.0:protocol', "xmlns:saml" => "urn:oasis:names:tc:SAML:2.0:assertion" }
root.attributes['ID'] = uuid
root.attributes['IssueInstant'] = time
root.attributes['Version'] = '2.0'
root.attributes['InResponseTo'] = request_id unless request_id.nil?
root.attributes['Destination'] = settings.idp_slo_target_url unless settings.idp_slo_target_url.nil? or settings.idp_slo_target_url.empty?
root.attributes['Destination'] = destination unless destination.nil? or destination.empty?

if settings.sp_entity_id != nil
issuer = root.add_element "saml:Issuer"
Expand Down
10 changes: 10 additions & 0 deletions test/slo_logoutresponse_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,16 @@ class SloLogoutresponseTest < Minitest::Test
assert_match /<samlp:StatusMessage>Custom Logout Message<\/samlp:StatusMessage>/, inflated
end

it "uses the response location when set" do
settings.idp_slo_response_service_url = "http://unauth.com/logout/return"

unauth_url = OneLogin::RubySaml::SloLogoutresponse.new.create(settings, logout_request.id)
assert_match /^http:\/\/unauth\.com\/logout\/return\?SAMLResponse=/, unauth_url

inflated = decode_saml_response_payload(unauth_url)
assert_match /Destination='http:\/\/unauth.com\/logout\/return'/, inflated
end

describe "when the settings indicate to sign (embedded) logout response" do

before do
Expand Down

0 comments on commit 0cb1843

Please sign in to comment.