ruby-saml-for-portal 0.3.5 → 0.3.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,42 @@
1
+ require "base64"
2
+ require "uuid"
3
+ require "zlib"
4
+ require "cgi"
5
+
6
+ module Onelogin::Saml
7
+ class Logoutrequest
8
+ def create(name_id,session_index,settings, params = {})
9
+ uuid = "_" + UUID.new.generate
10
+ time = Time.now.utc.strftime("%Y-%m-%dT%H:%M:%SZ")
11
+
12
+ request = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"+
13
+ "<saml2p:LogoutRequest Destination= \"#{settings.idp_ssl_target_url}\" ID=\"#{uuid}\" IssueInstant=\"#{time}\" Reason=\"urn:oasis:names:tc:SAML:2.0:logout:user\" Version=\"2.0\" xmlns:saml2=\"urn:oasis:names:tc:SAML:2.0:assertion\" xmlns:saml2p=\"urn:oasis:names:tc:SAML:2.0:protocol\">" +
14
+ "<saml2:Issuer>#{settings.issuer}</saml2:Issuer>" +
15
+ "<saml2:NameID Format=\"urn:oasis:names:tc:SAML:2.0:nameid-format:transient\">#{name_id}</saml2:NameID>" +
16
+ "<saml2p:SessionIndex>#{session_index}</saml2p:SessionIndex>" +
17
+ "</saml2p:LogoutRequest>"
18
+
19
+ deflated_request = Zlib::Deflate.deflate(request, 9)[2..-5]
20
+ base64_request = Base64.encode64(deflated_request)
21
+ encoded_request = CGI.escape(base64_request)
22
+ request_params = "?SAMLRequest=" + encoded_request
23
+
24
+ params.each_pair do |key, value|
25
+ request_params << "&#{key}=#{CGI.escape(value.to_s)}"
26
+ end
27
+ request_params << "&SigAlg=http%3A%2F%2Fwww.w3.org%2F2000%2F09%2Fxmldsig%23rsa-sha1&Signature=#{sign_request_xml(request, settings)}"
28
+ settings.idp_ssl_target_url + request_params
29
+ end
30
+
31
+ def sign_request_xml(xml_request, settings)
32
+ sig = settings.private_key.sign(OpenSSL::Digest::SHA1.new, xml_request)
33
+ Base64.encode64(sig).gsub(/\n/, '')
34
+ end
35
+
36
+ def xml
37
+ "<?xml version=\"1.0\" encoding=\"UTF-8\"?>
38
+ <saml2p:LogoutRequest Destination=\"https://sia-dev.egov.at-consulting.ru/idp/profile/SAML2/Redirect/SLO\" ID=\"_d1c51491-5966-4a60-9113-386d04734df5\" IssueInstant=\"2011-08-17T12:30:51.744Z\" Reason=\"urn:oasis:names:tc:SAML:2.0:logout:user\" Version=\"2.0\" xmlns:saml2=\"urn:oasis:names:tc:SAML:2.0:assertion\" xmlns:saml2p=\"urn:oasis:names:tc:SAML:2.0:protocol\"><saml2:Issuer>http://saml.pgu-dev.egov.at-consulting.ru</saml2:Issuer><saml2:NameID Format=\"urn:oasis:names:tc:SAML:2.0:nameid-format:transient\">_52874221a2fc2732af462bd3fa18c4f9</saml2:NameID><saml2p:SessionIndex>eca05eca7415ebb74858c6dcac7a4b2d6cf862534c5f6251c685851a1cec8af4</saml2p:SessionIndex></saml2p:LogoutRequest>"
39
+ end
40
+
41
+ end
42
+ end
@@ -5,7 +5,7 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = %q{ruby-saml-for-portal}
8
- s.version = "0.3.5"
8
+ s.version = "0.3.6"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = ["OneLogin LLC"]
@@ -23,7 +23,7 @@ Gem::Specification.new do |s|
23
23
  "VERSION",
24
24
  "lib/onelogin/saml.rb",
25
25
  "lib/onelogin/saml/authrequest.rb",
26
- "lib/onelogin/saml/authrequest.rb",
26
+ "lib/onelogin/saml/logout_request.rb",
27
27
  "lib/onelogin/saml/response.rb",
28
28
  "lib/onelogin/saml/settings.rb",
29
29
  "lib/ruby-saml-for-portal.rb",
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: ruby-saml-for-portal
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.5
4
+ version: 0.3.6
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -13,7 +13,7 @@ date: 2011-03-08 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: xmlcanonicalizer
16
- requirement: &18075780 !ruby/object:Gem::Requirement
16
+ requirement: &19026180 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ~>
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: 0.1.1
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *18075780
24
+ version_requirements: *19026180
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: uuid
27
- requirement: &18075180 !ruby/object:Gem::Requirement
27
+ requirement: &19025660 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ~>
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: 2.3.3
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *18075180
35
+ version_requirements: *19025660
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: systemu
38
- requirement: &18074580 !ruby/object:Gem::Requirement
38
+ requirement: &19025180 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ~>
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: 2.2.0
44
44
  type: :runtime
45
45
  prerelease: false
46
- version_requirements: *18074580
46
+ version_requirements: *19025180
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: rsa
49
- requirement: &18073980 !ruby/object:Gem::Requirement
49
+ requirement: &19024580 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ~>
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: 0.1.4
55
55
  type: :runtime
56
56
  prerelease: false
57
- version_requirements: *18073980
57
+ version_requirements: *19024580
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: shoulda
60
- requirement: &18073380 !ruby/object:Gem::Requirement
60
+ requirement: &19024020 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ! '>='
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: '0'
66
66
  type: :development
67
67
  prerelease: false
68
- version_requirements: *18073380
68
+ version_requirements: *19024020
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: mocha
71
- requirement: &18072800 !ruby/object:Gem::Requirement
71
+ requirement: &19023480 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ! '>='
@@ -76,7 +76,7 @@ dependencies:
76
76
  version: '0'
77
77
  type: :development
78
78
  prerelease: false
79
- version_requirements: *18072800
79
+ version_requirements: *19023480
80
80
  description: SAML toolkit for Ruby on Rails
81
81
  email: support@onelogin.com
82
82
  executables: []
@@ -91,6 +91,7 @@ files:
91
91
  - VERSION
92
92
  - lib/onelogin/saml.rb
93
93
  - lib/onelogin/saml/authrequest.rb
94
+ - lib/onelogin/saml/logout_request.rb
94
95
  - lib/onelogin/saml/response.rb
95
96
  - lib/onelogin/saml/settings.rb
96
97
  - lib/ruby-saml-for-portal.rb