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(); }