Click here to Skip to main content
Click here to Skip to main content
Add your own
alternative version

WCF Service Behavior Example: IPFilter - Allow/Deny Access by IP Address

, 15 Jun 2009 CPOL
WCF Service Behavior Example: IPFilter - Allow/Deny Access by IP Address
IPFilterExample.zip
IPFilterTests
bin
Debug
IPFilter.dll
IPFilterTests.dll
Configuration
Mock
Properties
TestWebsite
App_Data
bin
IPFilter.dll
IPFilter.pdb
TestWebsite.dll
TestWebsite.pdb
Filtered
Properties
TestWebsite.csproj.user
IPFilterExample.suo
IPFilterExample.vsmdi
IPFilterExample1.vsmdi
IPFilterExample2.vsmdi
LocalTestRun.testrunconfig
IPFilter
bin
Debug
IPFilter.dll
Configuration
Properties
IPFilterExamples.zip
IPFilterExample3.vsmdi
LocalTestRun.testrunconfig
IPFilter.dll
IPFilter.csproj.user
IPFilter.dll
IPFilterTests.dll
IPFilter.dll
IPFilter.pdb
TestWebsite.dll
TestWebsite.pdb
TestWebsite.csproj.user
IPFilterExample.vsmdi
IPFilterExample1.vsmdi
IPFilterExample2.vsmdi
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Configuration;

namespace IPFiltering.Configuration
{
    public class IPFilterConfiguration : ConfigurationSection
    {
        private const string _defaultSectionName = "IPFilter";
        private const string _httpModuleSectionName = "HttpModule";
        private const string _filtersSectionName = "Filters";
        private static readonly ThreadSafeSingleton<IPFilterConfiguration> _instance = new ThreadSafeSingleton<IPFilterConfiguration>(() => ConfigurationManager.GetSection(_defaultSectionName) as IPFilterConfiguration);
        
        /// <summary>
        /// Gets the default instance.
        /// </summary>
        public static IPFilterConfiguration Default
        {
            get
            {
                return _instance.Value;
            }
        }

        /// <summary>
        /// Gets the HTTP module config.
        /// </summary>
        /// <value>The HTTP module config.</value>
        [ConfigurationProperty(_httpModuleSectionName, IsRequired=false)]
        public HttpModuleConfiguration HttpModuleConfig
        {
            get
            {
                return (this[_httpModuleSectionName] as HttpModuleConfiguration) ?? new HttpModuleConfiguration();                    
            }
        }

        /// <summary>
        /// Gets the filter collection.
        /// </summary>
        /// <value>The filters.</value>
        [ConfigurationProperty(_filtersSectionName, IsRequired = false)]
        public FilterConfigurationCollection Filters
        {
            get
            {
                return (this[_filtersSectionName] as FilterConfigurationCollection) ?? new FilterConfigurationCollection();
            }
        }
    }
}

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

Share

About the Author

Ziad Elmalki

United States United States
No Biography provided

| Advertise | Privacy | Terms of Use | Mobile
Web03 | 2.8.141223.1 | Last Updated 16 Jun 2009
Article Copyright 2009 by Ziad Elmalki
Everything else Copyright © CodeProject, 1999-2014
Layout: fixed | fluid