saml_idp 0.2.1 → 0.3.0
Sign up to get free protection for your applications and to get access to all the features.
- data/README.md +16 -2
- data/app/controllers/saml_idp/idp_controller.rb +11 -0
- data/lib/saml_idp.rb +2 -2
- data/lib/saml_idp/assertion_builder.rb +11 -1
- data/lib/saml_idp/configurator.rb +1 -0
- data/lib/saml_idp/controller.rb +39 -4
- data/lib/saml_idp/encryptor.rb +86 -0
- data/lib/saml_idp/logout_builder.rb +42 -0
- data/lib/saml_idp/logout_request_builder.rb +36 -0
- data/lib/saml_idp/logout_response_builder.rb +35 -0
- data/lib/saml_idp/metadata_builder.rb +3 -0
- data/lib/saml_idp/request.rb +94 -10
- data/lib/saml_idp/response_builder.rb +1 -1
- data/lib/saml_idp/saml_response.rb +12 -4
- data/lib/saml_idp/service_provider.rb +7 -2
- data/lib/saml_idp/signable.rb +1 -1
- data/lib/saml_idp/signed_info_builder.rb +1 -1
- data/lib/saml_idp/version.rb +1 -1
- data/lib/saml_idp/xml_security.rb +15 -2
- data/saml_idp.gemspec +7 -1
- data/spec/lib/saml_idp/assertion_builder_spec.rb +24 -0
- data/spec/lib/saml_idp/configurator_spec.rb +1 -0
- data/spec/lib/saml_idp/controller_spec.rb +32 -2
- data/spec/lib/saml_idp/encryptor_spec.rb +27 -0
- data/spec/lib/saml_idp/logout_request_builder_spec.rb +43 -0
- data/spec/lib/saml_idp/logout_response_builder_spec.rb +41 -0
- data/spec/lib/saml_idp/metadata_builder_spec.rb +7 -0
- data/spec/lib/saml_idp/request_spec.rb +77 -19
- data/spec/lib/saml_idp/saml_response_spec.rb +32 -0
- data/spec/support/saml_request_macros.rb +20 -0
- data/spec/xml_security_spec.rb +2 -1
- metadata +40 -6
@@ -16,6 +16,27 @@ module SamlIdp
|
|
16
16
|
Saml::XML::Namespaces::AuthnContext::ClassRef::PASSWORD
|
17
17
|
}
|
18
18
|
let(:expiry) { 3 * 60 * 60 }
|
19
|
+
let (:encryption_opts) do
|
20
|
+
{
|
21
|
+
cert: Default::X509_CERTIFICATE,
|
22
|
+
block_encryption: 'aes256-cbc',
|
23
|
+
key_transport: 'rsa-oaep-mgf1p',
|
24
|
+
}
|
25
|
+
end
|
26
|
+
let(:subject_encrypted) { described_class.new(reference_id,
|
27
|
+
response_id,
|
28
|
+
issuer_uri,
|
29
|
+
name_id,
|
30
|
+
audience_uri,
|
31
|
+
saml_request_id,
|
32
|
+
saml_acs_url,
|
33
|
+
algorithm,
|
34
|
+
authn_context_classref,
|
35
|
+
expiry,
|
36
|
+
encryption_opts
|
37
|
+
)
|
38
|
+
}
|
39
|
+
|
19
40
|
subject { described_class.new(reference_id,
|
20
41
|
response_id,
|
21
42
|
issuer_uri,
|
@@ -32,5 +53,16 @@ module SamlIdp
|
|
32
53
|
it "has a valid build" do
|
33
54
|
subject.build.should be_present
|
34
55
|
end
|
56
|
+
|
57
|
+
it "builds encrypted" do
|
58
|
+
subject_encrypted.build.should_not match(audience_uri)
|
59
|
+
encoded_xml = subject_encrypted.build
|
60
|
+
resp_settings = saml_settings(saml_acs_url)
|
61
|
+
resp_settings.private_key = Default::SECRET_KEY
|
62
|
+
resp_settings.issuer = audience_uri
|
63
|
+
saml_resp = OneLogin::RubySaml::Response.new(encoded_xml, settings: resp_settings)
|
64
|
+
saml_resp.soft = false
|
65
|
+
saml_resp.is_valid?.should == true
|
66
|
+
end
|
35
67
|
end
|
36
68
|
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
require 'saml_idp/logout_request_builder'
|
2
|
+
|
1
3
|
module SamlRequestMacros
|
2
4
|
|
3
5
|
def make_saml_request(requested_saml_acs_url = "https://foo.example.com/saml/consume")
|
@@ -6,6 +8,18 @@ module SamlRequestMacros
|
|
6
8
|
CGI.unescape(auth_url.split("=").last)
|
7
9
|
end
|
8
10
|
|
11
|
+
def make_saml_logout_request(requested_saml_logout_url = 'https://foo.example.com/saml/logout')
|
12
|
+
request_builder = SamlIdp::LogoutRequestBuilder.new(
|
13
|
+
'some_response_id',
|
14
|
+
'http://example.com',
|
15
|
+
requested_saml_logout_url,
|
16
|
+
'some_name_id',
|
17
|
+
'abc123index',
|
18
|
+
OpenSSL::Digest::SHA256
|
19
|
+
)
|
20
|
+
request_builder.encoded
|
21
|
+
end
|
22
|
+
|
9
23
|
def saml_settings(saml_acs_url = "https://foo.example.com/saml/consume")
|
10
24
|
settings = OneLogin::RubySaml::Settings.new
|
11
25
|
settings.assertion_consumer_service_url = saml_acs_url
|
@@ -16,4 +30,10 @@ module SamlRequestMacros
|
|
16
30
|
settings
|
17
31
|
end
|
18
32
|
|
33
|
+
def print_pretty_xml(xml_string)
|
34
|
+
doc = REXML::Document.new xml_string
|
35
|
+
outbuf = ""
|
36
|
+
doc.write(outbuf, 1)
|
37
|
+
puts outbuf
|
38
|
+
end
|
19
39
|
end
|
data/spec/xml_security_spec.rb
CHANGED
@@ -116,7 +116,8 @@ module SamlIdp
|
|
116
116
|
|
117
117
|
it "be able to validate a good response" do
|
118
118
|
Timecop.freeze Time.parse('2012-11-28 17:55:00 UTC') do
|
119
|
-
response.
|
119
|
+
response.stub(:validate_subject_confirmation).and_return(true)
|
120
|
+
response.should be_is_valid
|
120
121
|
end
|
121
122
|
end
|
122
123
|
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: saml_idp
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.3.0
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date:
|
12
|
+
date: 2016-06-07 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: activesupport
|
@@ -146,7 +146,7 @@ dependencies:
|
|
146
146
|
requirements:
|
147
147
|
- - ~>
|
148
148
|
- !ruby/object:Gem::Version
|
149
|
-
version: '
|
149
|
+
version: '1.2'
|
150
150
|
type: :development
|
151
151
|
prerelease: false
|
152
152
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -154,7 +154,7 @@ dependencies:
|
|
154
154
|
requirements:
|
155
155
|
- - ~>
|
156
156
|
- !ruby/object:Gem::Version
|
157
|
-
version: '
|
157
|
+
version: '1.2'
|
158
158
|
- !ruby/object:Gem::Dependency
|
159
159
|
name: rails
|
160
160
|
requirement: !ruby/object:Gem::Requirement
|
@@ -203,6 +203,22 @@ dependencies:
|
|
203
203
|
- - ! '>='
|
204
204
|
- !ruby/object:Gem::Version
|
205
205
|
version: '0'
|
206
|
+
- !ruby/object:Gem::Dependency
|
207
|
+
name: xmlenc
|
208
|
+
requirement: !ruby/object:Gem::Requirement
|
209
|
+
none: false
|
210
|
+
requirements:
|
211
|
+
- - ! '>='
|
212
|
+
- !ruby/object:Gem::Version
|
213
|
+
version: 0.6.4
|
214
|
+
type: :development
|
215
|
+
prerelease: false
|
216
|
+
version_requirements: !ruby/object:Gem::Requirement
|
217
|
+
none: false
|
218
|
+
requirements:
|
219
|
+
- - ! '>='
|
220
|
+
- !ruby/object:Gem::Version
|
221
|
+
version: 0.6.4
|
206
222
|
description: SAML IdP (Identity Provider) library in ruby
|
207
223
|
email: jon.phenow@sportngin.com
|
208
224
|
executables: []
|
@@ -219,9 +235,13 @@ files:
|
|
219
235
|
- lib/saml_idp/configurator.rb
|
220
236
|
- lib/saml_idp/controller.rb
|
221
237
|
- lib/saml_idp/default.rb
|
238
|
+
- lib/saml_idp/encryptor.rb
|
222
239
|
- lib/saml_idp/engine.rb
|
223
240
|
- lib/saml_idp/hashable.rb
|
224
241
|
- lib/saml_idp/incoming_metadata.rb
|
242
|
+
- lib/saml_idp/logout_builder.rb
|
243
|
+
- lib/saml_idp/logout_request_builder.rb
|
244
|
+
- lib/saml_idp/logout_response_builder.rb
|
225
245
|
- lib/saml_idp/metadata_builder.rb
|
226
246
|
- lib/saml_idp/name_id_formatter.rb
|
227
247
|
- lib/saml_idp/persisted_metadata.rb
|
@@ -246,6 +266,9 @@ files:
|
|
246
266
|
- spec/lib/saml_idp/attribute_decorator_spec.rb
|
247
267
|
- spec/lib/saml_idp/configurator_spec.rb
|
248
268
|
- spec/lib/saml_idp/controller_spec.rb
|
269
|
+
- spec/lib/saml_idp/encryptor_spec.rb
|
270
|
+
- spec/lib/saml_idp/logout_request_builder_spec.rb
|
271
|
+
- spec/lib/saml_idp/logout_response_builder_spec.rb
|
249
272
|
- spec/lib/saml_idp/metadata_builder_spec.rb
|
250
273
|
- spec/lib/saml_idp/name_id_formatter_spec.rb
|
251
274
|
- spec/lib/saml_idp/request_spec.rb
|
@@ -349,6 +372,14 @@ post_install_message: ! 'If you''re just recently updating saml_idp - please be
|
|
349
372
|
|
350
373
|
defaults in a Production environment. Post any issues you to github.
|
351
374
|
|
375
|
+
|
376
|
+
** New in Version 0.3.0 **
|
377
|
+
|
378
|
+
|
379
|
+
Encrypted Assertions require the xmlenc gem. See the example in the Controller
|
380
|
+
|
381
|
+
section of the README.
|
382
|
+
|
352
383
|
'
|
353
384
|
rdoc_options:
|
354
385
|
- --charset=UTF-8
|
@@ -362,7 +393,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
362
393
|
version: '0'
|
363
394
|
segments:
|
364
395
|
- 0
|
365
|
-
hash:
|
396
|
+
hash: 1850283737976678938
|
366
397
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
367
398
|
none: false
|
368
399
|
requirements:
|
@@ -371,7 +402,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
371
402
|
version: '0'
|
372
403
|
segments:
|
373
404
|
- 0
|
374
|
-
hash:
|
405
|
+
hash: 1850283737976678938
|
375
406
|
requirements: []
|
376
407
|
rubyforge_project:
|
377
408
|
rubygems_version: 1.8.23
|
@@ -386,6 +417,9 @@ test_files:
|
|
386
417
|
- spec/lib/saml_idp/attribute_decorator_spec.rb
|
387
418
|
- spec/lib/saml_idp/configurator_spec.rb
|
388
419
|
- spec/lib/saml_idp/controller_spec.rb
|
420
|
+
- spec/lib/saml_idp/encryptor_spec.rb
|
421
|
+
- spec/lib/saml_idp/logout_request_builder_spec.rb
|
422
|
+
- spec/lib/saml_idp/logout_response_builder_spec.rb
|
389
423
|
- spec/lib/saml_idp/metadata_builder_spec.rb
|
390
424
|
- spec/lib/saml_idp/name_id_formatter_spec.rb
|
391
425
|
- spec/lib/saml_idp/request_spec.rb
|