Class: Saml::ProviderStores::File
- Inherits:
-
Object
- Object
- Saml::ProviderStores::File
- Defined in:
- lib/saml/provider_stores/file.rb
Instance Attribute Summary collapse
-
#providers ⇒ Object
Returns the value of attribute providers.
Instance Method Summary collapse
- #add_metadata(metadata_xml, encryption_key = nil, signing_key = nil) ⇒ Object
- #find_by_entity_id(entity_id) ⇒ Object
-
#find_by_source_id(source_id) ⇒ Object
Returns provider by source_id or nil if not found.
-
#initialize(metadata_dir = "config/metadata", encryption_key_file = "config/ssl/key.pem", encryption_key_password = nil, signing_key_file = nil, signing_key_password = nil) ⇒ File
constructor
A new instance of File.
- #load_files(metadata_dir, encryption_key_file, encryption_key_password = nil, sign_key_file = nil, sign_key_password = nil) ⇒ Object
Constructor Details
#initialize(metadata_dir = "config/metadata", encryption_key_file = "config/ssl/key.pem", encryption_key_password = nil, signing_key_file = nil, signing_key_password = nil) ⇒ File
Returns a new instance of File.
6 7 8 9 10 11 12 13 |
# File 'lib/saml/provider_stores/file.rb', line 6 def initialize( = "config/metadata", encryption_key_file = "config/ssl/key.pem", encryption_key_password = nil, signing_key_file = nil, signing_key_password = nil) @mutex = Mutex.new self.providers = {} load_files(, encryption_key_file, encryption_key_password, signing_key_file, signing_key_password) end |
Instance Attribute Details
#providers ⇒ Object
Returns the value of attribute providers.
4 5 6 |
# File 'lib/saml/provider_stores/file.rb', line 4 def providers @providers end |
Instance Method Details
#add_metadata(metadata_xml, encryption_key = nil, signing_key = nil) ⇒ Object
34 35 36 37 38 39 40 41 42 |
# File 'lib/saml/provider_stores/file.rb', line 34 def (, encryption_key = nil, signing_key = nil) entity_descriptor = Saml::Elements::EntityDescriptor.parse(, single: true) type = entity_descriptor.sp_sso_descriptor.present? ? 'service_provider' : 'identity_provider' provider = BasicProvider.new(entity_descriptor, encryption_key, type, signing_key) @mutex.synchronize do providers[provider.entity_id] = provider end end |
#find_by_entity_id(entity_id) ⇒ Object
15 16 17 |
# File 'lib/saml/provider_stores/file.rb', line 15 def find_by_entity_id(entity_id) providers[entity_id] end |
#find_by_source_id(source_id) ⇒ Object
Returns provider by source_id or nil if not found.
20 21 22 23 24 |
# File 'lib/saml/provider_stores/file.rb', line 20 def find_by_source_id(source_id) providers.find do |entity_id, _| Digest::SHA1.digest(entity_id) == source_id end.to_a[1] end |
#load_files(metadata_dir, encryption_key_file, encryption_key_password = nil, sign_key_file = nil, sign_key_password = nil) ⇒ Object
26 27 28 29 30 31 32 |
# File 'lib/saml/provider_stores/file.rb', line 26 def load_files(, encryption_key_file, encryption_key_password = nil, sign_key_file = nil, sign_key_password = nil) Dir[::File.join(, '*.xml')].each do |file| (::File.read(file), get_private_key(encryption_key_file, encryption_key_password), sign_key_file.present? ? get_private_key(sign_key_file, sign_key_password) : nil) end end |