Class: Saml::ProviderStores::File

Inherits:
Object
  • Object
show all
Defined in:
lib/saml/provider_stores/file.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(metadata_dir = "config/metadata", key_file = "config/ssl/key.pem", key_password = nil) ⇒ File

Returns a new instance of File.



6
7
8
9
10
11
# File 'lib/saml/provider_stores/file.rb', line 6

def initialize( = "config/metadata", key_file = "config/ssl/key.pem", key_password = nil)
  @mutex         = Mutex.new
  self.providers = {}

  load_files(, key_file, key_password)
end

Instance Attribute Details

#providersObject

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, private_key = nil) ⇒ Object



30
31
32
33
34
35
36
37
38
# File 'lib/saml/provider_stores/file.rb', line 30

def (, private_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, private_key, type)

  @mutex.synchronize do
    providers[provider.entity_id] = provider
  end
end

#find_by_entity_id(entity_id) ⇒ Object



13
14
15
# File 'lib/saml/provider_stores/file.rb', line 13

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.



18
19
20
21
22
# File 'lib/saml/provider_stores/file.rb', line 18

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, key_file, key_password = nil) ⇒ Object



24
25
26
27
28
# File 'lib/saml/provider_stores/file.rb', line 24

def load_files(, key_file, key_password = nil)
  Dir[::File.join(, '*.xml')].each do |file|
    (::File.read(file), get_private_key(key_file, key_password))
  end
end