private static void Initialize()
        {
            providerCollection = new PayPalIPNHandlerProviderCollection();

            try
            {
                PayPalIPNHandlerProviderConfig config
                    = PayPalIPNHandlerProviderConfig.GetConfig();

                if (config != null)
                {

                    if (
                        (config.Providers == null)
                        || (config.Providers.Count < 1)
                        )
                    {
                        throw new ProviderException("No PayPalIPNHandlerProviderCollection found.");
                    }

                    ProvidersHelper.InstantiateProviders(
                        config.Providers,
                        providerCollection,
                        typeof(PayPalIPNHandlerProvider));

                }
                else
                {
                    // config was null, not a good thing
                    log.Error("PayPalIPNHandlerProviderConfig could not be loaded so empty provider collection was returned");

                }
            }
            catch (NullReferenceException ex)
            {
                log.Error(ex);
            }
            catch (TypeInitializationException ex)
            {
                log.Error(ex);
            }
            catch (ProviderException ex)
            {
                log.Error(ex);
            }

            providerCollection.SetReadOnly();
        }
        private static void Initialize()
        {
            providerCollection = new PayPalIPNHandlerProviderCollection();

            try
            {
                PayPalIPNHandlerProviderConfig config
                    = PayPalIPNHandlerProviderConfig.GetConfig();

                if (config != null)
                {
                    if (
                        (config.Providers == null) ||
                        (config.Providers.Count < 1)
                        )
                    {
                        throw new ProviderException("No PayPalIPNHandlerProviderCollection found.");
                    }

                    ProvidersHelper.InstantiateProviders(
                        config.Providers,
                        providerCollection,
                        typeof(PayPalIPNHandlerProvider));
                }
                else
                {
                    // config was null, not a good thing
                    log.Error("PayPalIPNHandlerProviderConfig could not be loaded so empty provider collection was returned");
                }
            }
            catch (NullReferenceException ex)
            {
                log.Error(ex);
            }
            catch (TypeInitializationException ex)
            {
                log.Error(ex);
            }
            catch (ProviderException ex)
            {
                log.Error(ex);
            }

            providerCollection.SetReadOnly();
        }