Class HTTPMetadataProvider

    • Constructor Detail

      • HTTPMetadataProvider

        public HTTPMetadataProvider​(String metadataUrl,
                                    String backupFile)
                             throws ResolverException
        Creates a provider that periodically downloads data from the URL given by metadataUrl. If the backupFile parameter is given the provider also stores the downloaded metadata on disk as backup.

        This constructor will initialize the underlying MetadataResolver with a default HttpClient instance that is initialized according to createDefaultHttpClient().

        Parameters:
        metadataUrl - the URL to use when downloading metadata
        backupFile - optional path to the file to where the provider should store downloaded metadata
        Throws:
        ResolverException - if the supplied metadata URL is invalid
      • HTTPMetadataProvider

        public HTTPMetadataProvider​(String metadataUrl,
                                    String backupFile,
                                    org.apache.http.client.HttpClient httpClient)
                             throws ResolverException
        Creates a provider that periodically downloads data from the URL given by metadataUrl. If the backupFile parameter is given the provider also stores the downloaded metadata on disk as backup.
        Parameters:
        metadataUrl - the URL to use when downloading metadata
        backupFile - optional path to the file to where the provider should store downloaded metadata
        httpClient - the HttpClient that should be used to download the metadata
        Throws:
        ResolverException - if the supplied metadata URL is invalid
    • Method Detail

      • createDefaultHttpClient

        public static org.apache.http.client.HttpClient createDefaultHttpClient()
                                                                         throws ResolverException
        Creates a default HttpClient instance that uses system properties and sets a SSLSocketFactory that is configured in a "no trust" mode, meaning that all peer certificates are accepted and no hostname check is made.

        TLS security parameters, such as a trust engine, may later be added by assigning a configured HttpClientSecurityParameters instance in the constructor.

        Returns:
        a default HttpClient instance
        Throws:
        ResolverException - for errors creating the client
      • createDefaultHttpClient

        public static org.apache.http.client.HttpClient createDefaultHttpClient​(KeyStore trustKeyStore,
                                                                                HostnameVerifier hostnameVerifier)
                                                                         throws ResolverException
        Creates a HttpClient instance that sets up a trust manager that accepts all certificates supplied in the trustKeyStore parameter. The hostnameVerifier parameter tells which hostname verifier that should be used. If not supplied, a DefaultHostnameVerifier will be used.
        Parameters:
        trustKeyStore - a KeyStore holding the certificates that should be accepted (if null, all certificates are accepted)
        hostnameVerifier - the HostnameVerifier to use (if null a DefaultHostnameVerifier is used)
        Returns:
        a HttpClient instance
        Throws:
        ResolverException - for errors creating the client
      • getID

        public String getID()
        Returns the identifier for the provider.
        Returns:
        the identifier
      • getMetadataResolver

        public MetadataResolver getMetadataResolver()
        Returns the underlying OpenSAML metadata resolver.
        Returns:
        OpenSAML metadata resolver