This application is a U.S. National Stage Application of PCT International Application No. PCT/IN2007/00359, titled “Identity and Policy-Based Network Security System and Method”, filed Aug. 21, 2007, which in turn claims the benefit of Indian Patent Application Number 1299/Mum/2007, filed Jul. 6, 2007. PCT International Application No. PCT/IN2007/00359 and Indian Patent Application Number 1299/Mum/2007 are hereby incorporated herein by reference.
The present invention relates generally to a method and system for managing a network connection, and specifically for conducting an identity-based and policy/rules-based analysis of one or more packets sent over a connection in the network to provide increased security and optimize computing resources.
In conventional network environments, firewalls have played an increasingly important role in protecting resources residing on a private network, while allowing communication with and access to systems located on an unprotected network, such as, for example, the Internet. The firewall acts as a gatekeeper, configured to prevent attacks on a private network deriving from the unprotected network by providing a single connection with limited services.
In this regard, the firewall is able to secure a private network by allowing the network administrator to develop and implement a particular security policy. Some conventional firewalls are configured to implement access rules which are based on the association of the source IP address and the destination IP address. While this approach is effective for a static network environment, it is not effective for systems including conventional dynamic addressing, such as, for example, a Dynamic Host Configuration Protocol (DHCP) or a wi-fi network environment. In a typical dynamic IP environment, the user's information is not available on the LAN side, and, as such, no user-specific rules or decisions can be implemented.
Network Address Translation (NAT) firewalls have been developed to provide for the mapping of port numbers to allow multiple machines to share a single IP address. NAT is also used to provide mapping of private and public IP addresses. One can not have a pool of public IP addresses to be used for NAT whereby a single user or a group of users can be NATed by a specific IP address so as to identify themselves uniquely to an external server.
Furthermore, a conventional firewall is not able to identify a user. Even those firewalls which are adapted to include an authentication of the user are limited in that they are unable to apply user-specific rules to perform NATing. According to these systems, the user's identity is not part of the rule matching criteria considered by the firewall.
Accordingly, there is a need in the art for a method and system for a more robust network security system capable of considering a user's identity as part of the firewall rule matching criteria.
The above-described problems are addressed and a technical solution is achieved in the art by a system and a method for managing and securing a network. According to an embodiment of the present invention, the network security system and method comprise a firewall wherein the user's identity and user-specific policies are combined to provide enhanced network security and resource optimization.
According to an embodiment of the present invention, a method and system is provided for managing a network connection between a source and a destination for the transmission of at least one data packet. According to the present invention, a login request comprising a user IP address, and login credentials is received from a user. Based on the login credentials, the user is authenticated. Following authentication, a profile associated with the authenticated user is identified. The profile is specific to the user and comprises user data and one or more user-specific security and management policies.
According to an embodiment of the present invention, the system determines if the user is authorized to login. To determine whether the login request is authorized, the system applies the at least one user-specific policy of the identified profile. For example, to determine if the login request is authorized, the system may apply an access time policy and/or quota policy. If the login request is in compliance with the at least one user-specific policy, then the login request is authorized.
Next, a record including identity information related to the authorized user is created and stored, wherein the identity information comprises the profile and the user IP address. The identity information creates an association between the user and the one or more user IP addresses associated with that user.
The system is configured to receive a data communication from a source intended for a destination. The data communication includes one or more data packet, with each packet comprising a source IP address and a destination IP address. The system is configured to identify and apply the user-specific policy associated with the user.
According to an embodiment of the present invention, the system creates a connection object associated with the connection based at least on the source IP address and a destination IP address. The connection object is then associated with the at least one packet.
Based on the source IP address, the system identifies the identity information associated with the authorized user. Next, the connection object is updated with the identified identity information and a connection is established based on the information and policies included in the updated connection object. In this regard, the connection is secured and managed according to the user-specific policy associated with the user.
The present invention will be more readily understood from the detailed description of preferred embodiments presented below considered in conjunction with the attached drawings, of which:
It is to be understood that these figures are for purposes of illustrating the concepts of the invention and may not be to scale.
According to an embodiment of the present invention, the Network Management System 10 is a computer-based security system, accessible by one or more communicatively connected user computers or “sources” seeking to establish a connection and transmit and/or receive data to and from a computer-based resource, herein referred to as a “destination”. The term “computer” is intended to include any data processing device, such as a desktop computer, a laptop computer, a mainframe computer, a personal digital assistant, a server, or any other device able to process data. The term “communicatively connected” is intended to include any type of connection, whether wired or wireless, in which data may be communicated. The term “communicatively connected” is intended to include a connection between devices and/or programs within a single computer or between devices and/or programs on separate computers.
According to an embodiment of the present invention, the Network Management System 10 and related methods described herein comprises a User Creation Module 20, a User Database 25, a Login Module 30, a User IP Map 40, a Connection Tracker 50, a Firewall Module 60, and a Management Module 70, configured to manage and secure the connection between the User Computer 1, or source, and a destination (identified as Destination 80 in
One having ordinary skill in the art will appreciate that the components of the Network Management System 10 may be located on a single computer, as schematically illustrated in
A user or source may access the Network Management System 10 using a computer, herein referred to as a User Computer 1. According to an embodiment of the present invention, the User Computer 1 may include, but is not limited to, a Web browser that provides a portal to one or more Web-based networks (e.g., the Internet) or an executable or binary program that provides an interface to the user and is connectable to a remote Authentication Server 35 and/or the Login Module 30. One having ordinary skill in the art will appreciate that any suitable Web browser may be used in accordance with the present invention, including but not limited to FireFox, Microsoft® Internet Explorer, Netscape, Opera, WebTV®, and Mozilla™.
For each user that is permitted to interact with and traverse the Network Management System 10 a “profile” is created and stored, thereby registering the user with the system. According to an embodiment of the present invention, one or more persons responsible for managing, updating, editing, or controlling the Network Management System 10, herein referred to as an Administrator 5, creates the profile for each user using the User Creation Module 20, according to the user creation processes illustrated in
As shown in
As used herein, the term “Application Security Policy” is intended to include, but is not limited to, a rule or policy related to the control of application layer capabilities based on information related to one or more application protocols.
As used herein, the term “Internet access policy” is intended to include, but is not limited to, a rule or policy related to the control of access to a Wide Area Network (WAN) from a Local Area Network (LAN).
As used herein, the term “quota policy” is intended to include, but is not limited to, a rule or policy that governs the amount of time (i.e., the limit or quota) that a user is permitted to access and/or surf the WAN or the Internet.
As used herein, the term “access time policy” is intended to include, but is not limited to, a rule or policy that governs the amount of time and timing of when a user is permitted to access and/or surf the WAN or the Internet.
As used herein, the term “anti-virus scanning policy” is intended to include, but is not limited to, a policy that governs whether the specific traffic should be scanned for a virus or not.
As used herein, the term “routing policy” is intended to include, but is not limited to, a policy that governs the manner in which a packet should be routed.
As used herein, the term “logging policy” is intended to include, but is not limited to, a policy that governs whether a packet, connection and/or relevant policy/rule information should be logged or not.
The profile (or user profile) comprising the user data and the user-specific policy is created and stored in the User Database 25.
According to an embodiment of the present invention, the Administrator 5 may employ an automated utility configured to extract and copy user data from an existing legacy systems or conventional user databases and store such user data in the User Database 25. Exemplary legacy systems and/or user databases from which the automated utility may extract user data include, but are not limited to, a Lightweight Directory Access Protocol (LDAP) server, a Radius server, a Windows Active Directory, and a Windows Domain Controller.
Prior to interacting with the network, the user logs on to the Network Management System 10, as illustrated in
According to an embodiment of the present invention, the Login Module 30 is configured to authenticate the User Computer 1 by checking the login credentials against the one or more user profiles stored in the User Database 25. In this regard, the Login Module 30 searches the User Database 25 to determine if there is a profile stored therein that includes user data which corresponds to the login credentials presented by the User Computer 1.
Optionally, the Login Module 30 may be communicatively connected to an Authentication Server 35. According to this option, the Login Module 30 is configured to send an authentication request to the Authentication Server 35 for processing, and, in response, the Authentication Server 35 returns an authentication reply indicating whether the user has been authenticated. The Authentication Server 35 is a computer-based module configured to perform authentication services, and may be any suitable authentication means known to those having ordinary skill in the art, such as, for example, an Active Directory, a Windows Domain Controller, a LDAP Server, or a Radius Server. One having ordinary skill in the art will appreciate that the Authentication Server 35 may reside within the Network Management System 10 or may be a separate component accessible by the Network Management System 10, as denoted by the dashed line in
If the user is not authenticated (i.e., the authentication is not successful), the Login Module 30 sends a message indicating same to the User Computer 1.
If the user is authenticated, the Login Module 30 next determines if the user is authorized to perform the login request by comparing the login credentials with the user-specific policy associated with the particular user's profile stored in the User Database 25. To determine if the login request is authorized, the system may apply the appropriate user-specific policy, such as, for example, the access time policy and/or the quota policy. If the login request is compliant with and conforms to all of the applied user-specific policies, the user is authorized, and the Login Module 30 sends the profile (i.e., the user data and user-specific policy) and the user's IP address to the communicatively connected User IP Map 40. The profile data (i.e., the user data and user-specific policy) and the user's IP address are associated with one another and stored as the user's “identity information” in the User IP Map 40. The identity information comprises the profile data (i.e., the user data and user-specific policy) and the user IP address.
Once the user is authenticated and the associated login request is authorized, the Network Management System 10 may process one or more packets via a connection between a source (User Computer 1) and a Destination 80. As shown in
The Connection Tracker 50, a computer-based module configures to track each connection between a user and a destination, checks each packet received from the source to determine if the packet belongs to an existing connection. To do so, the Connection Tracker 50 checks the communicatively connected Connection Database 55, a database configured to store information related to each connection. According to an embodiment of the present invention, the connection information, herein referred to as a “connection object” includes, but is not limited to a request tuple (i.e., information related to the source and destination available to the source) and a reply tuple (i.e., information related to the source and destination available to the destination), and is stored in the Connection Database 55, preferably when the first packet (i.e., the synchronizing packet) of the connection between the source and destination arrives. Each connection object stored in the Connection Database 55 is represented by an address, herein referred to as the “connection reference.”
As each packet enters, the Connection Tracker 50 reviews the source and destination address data, and based on this data, retrieves the associated connection object from the Connection Database 55. If the packet belongs to an existing connection (i.e., there is an existing connection reference and object related to the source address and destination address associated with the packet), the Connection Tracker 50 retrieves the connection object and updates the packet data structure with connection reference associated with the connection object. As such, each connection managed by the Connection Tracker 50 is assigned a unique connection reference which may be added to packets related to that particular connection.
If the packet does not belong to an existing connection, the Connection Tracker 50 creates a connection object (including the request tuple and reply tuple). In addition, the Connection Tracker 50 creates an associated connection reference related to the connection object, and stores the connection reference in the Connection Database 55. As shown in
Next, using the source IP address, the Connection Tracker 50 accesses the communicatively connected User IP Map 40 to look up and identify the appropriate identity information. To do so, the Connection Tracker 50 locates the IP address in the plurality of identity information records that matches the source IP address, and retrieves the associated identity information. As described above, at the time the user is authenticated, the user and source IP address have been associated or mapped to one another in the User IP Map 40. As such, using the source IP address, the Connection Tracker 50 is able to identify the appropriate identity information.
The Connection Tracker 50 then updates the connection object with the portion of the user-specific policy which relates to the connection (e.g., an application security policy, IDP, the upload data transfer limit, and route information/policy). Further, the Connection Tracker 50 updates the packet with the portion of the user-specific policy which relates to the packet (e.g., the bandwidth class information). Accordingly, as the source (e.g., User Computer 1) transmits packets of data to the Destination 80 via the Network Management System 10, each packet is associated with and governed by the particular user's user-specific policy.
The Connection Tracker 50 comprises a zone lookup sub-module is configured to use the inbound interface (interface with the source) and outbound interface (interface with the destination) to determine the appropriate source and destination zones. According to an embodiment of the present invention, the zone lookup sub-module uses the interfaces to zone mapping information provided by the administrator during creation of the user.
Advantageously, the packet and connection may be managed by the user-specific policy comprised within the identity information. In addition, the user identity information may further be used as part of the firewall traversal criteria, as described in detail below with reference to
According to an embodiment of the present invention, the Connection Tracker 50 passes the updated connection object including the request tuple, reply tuple, user-specific policy, and source and destination zone information to the communicatively connected Firewall Module 60.
The Firewall Module 60 determines the appropriate firewall rule to associate with the connection object by applying the “rule matching criteria,” according to any suitable search method known to those having ordinary skill in the art, such as, for example, a sequential searching method. As used herein, the term “rule matching criteria” is intended to include, but is not limited to, the Mac address, the source zone, the destination zone, source IP address, destination IP address, user identity, service data, Transport layer information, and schedule information.
The Firewall Module 60 examines the connection object (and information contained therein) received from the Connection Tracker 50 and applies the rules matching criteria to determine the applicable firewall rule. Next, the Firewall Module 60 updates the connection object with at least a portion of the firewall rule which relates to the connection. As noted above, optionally, the Firewall Module 60 may update the connection object with policy information retrieved from the firewall store, wherein the policy information is applied to override or overwrite one or more of the user-specific policies. In the example shown in
According to an embodiment of the present invention, the Firewall Module 60 also updates the packet data structure with route information which it retrieves from the connection object. Next, the Firewall Module 60 retrieves the firewall action (i.e., drop/reject or accept) from the connection object. If the firewall action is ‘drop/reject,’ the Firewall Module 60 then determines if the action is ‘drop.’ If so, the Firewall Module 60 determines if the packet drop is to be logged. If so, the Firewall Module 60 logs the packet, and then drops it. If logging is not to be performed, the packet is dropped.
If the firewall action is ‘accept,’ the Firewall Module 60 passes the packet to the Management Module 70. The Management Module 70 is a computer-based module configured to perform the steps illustrated in
As illustrated in
With reference to
Upon receipt of the connection object and packet, the Application Filter 71 submits the packet to the appropriate application filter (e.g., HTTP, FTP, SMTP, POP3, IMAP, etc.). In addition, the Application Filter 71 fetches any application security policies associated with the connection object, applies the policies at the application layer, and submits the packet to the next sub-module (if applicable).
According to an exemplary embodiment of the present invention, as shown in
According to an exemplary embodiment of the present invention, the NAT Module 72 passes the packet to the Routing Module 73. The Routing Module 73 is a computer-based module configured to route the packet according to the one or more defined routing policies.
For example, if there are more than one defined routing policies, the Routing Module 73 may route the packet according to any suitable sequence or application of the policies. As shown in
Next, the packet is submitted to the IDP Module 74. The IDP Module 74 is a computer-based module configured to retrieve the IDP policy from the connection object and scan the packet pursuant to the IDP policy. If the IDP Module 74 determines that there is no network traffic pattern signature match, the packet is submitted or passed to the next sub-module of the Management Module 70 (i.e., the NAT Module 72 in
If the IDP Module 74 determines that the packet matches a network traffic pattern signature, the IDP Module 74 executes the appropriate IDP policy action (i.e., drop or detect). If the IDP policy action is ‘drop,’ the packet is dropped. Optionally, the packet may be logged prior to being dropped. If the IDP policy is ‘detect,’ the IDP Module 74 generates an alert and submits the packet to the next sub-module.
According to the exemplary embodiment illustrated in
Next, in the example shown in
Finally, once the packet has been reviewed by each of the sub-modules of the Management Module 70, it is passed back to the Firewall Module 60, where the packet is submitted to an output device driver for transmission to Destination 80.
It is to be understood that the exemplary embodiments and the above example are merely illustrative of the present invention and that many variations of the above-described embodiments and example can be devised by one skilled in the art without departing from the scope of the invention. It is therefore intended that all such variations be included within the scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
1299/MUM/2007 | Jul 2007 | IN | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IN2007/000359 | 8/21/2007 | WO | 00 | 11/27/2007 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2009/007985 | 1/15/2009 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5050161 | Golestani | Sep 1991 | A |
5983270 | Abraham et al. | Nov 1999 | A |
5983350 | Minear et al. | Nov 1999 | A |
6230271 | Wadlow et al. | May 2001 | B1 |
6330590 | Cotten | Dec 2001 | B1 |
6356529 | Zarom | Mar 2002 | B1 |
6463474 | Fuh et al. | Oct 2002 | B1 |
6496935 | Fink et al. | Dec 2002 | B1 |
6502131 | Vaid et al. | Dec 2002 | B1 |
6587466 | Bhattacharya et al. | Jul 2003 | B1 |
6609154 | Fuh et al. | Aug 2003 | B1 |
6615358 | Dowd et al. | Sep 2003 | B1 |
6678828 | Pham et al. | Jan 2004 | B1 |
6678835 | Shah et al. | Jan 2004 | B1 |
6738377 | Boden | May 2004 | B1 |
6832248 | Byrnes | Dec 2004 | B1 |
6895511 | Borsato et al. | May 2005 | B1 |
6931530 | Pham et al. | Aug 2005 | B2 |
6944183 | Iyer et al. | Sep 2005 | B1 |
7010807 | Yanovsky | Mar 2006 | B1 |
7032022 | Shanumgam et al. | Apr 2006 | B1 |
7080077 | Ramamurthy et al. | Jul 2006 | B2 |
7089586 | Kilgore | Aug 2006 | B2 |
7143151 | Kayashima et al. | Nov 2006 | B1 |
7143288 | Pham et al. | Nov 2006 | B2 |
7272625 | Hannel et al. | Sep 2007 | B1 |
7293175 | Brown et al. | Nov 2007 | B2 |
7333430 | Li et al. | Feb 2008 | B2 |
7366812 | Lambourn et al. | Apr 2008 | B2 |
7389533 | Bartlett et al. | Jun 2008 | B2 |
7398552 | Pardee et al. | Jul 2008 | B2 |
7461401 | Leppanen et al. | Dec 2008 | B2 |
7480707 | Morlitz | Jan 2009 | B2 |
7506054 | Fuh et al. | Mar 2009 | B1 |
7565532 | Pham et al. | Jul 2009 | B2 |
7610330 | Quinn et al. | Oct 2009 | B1 |
7624424 | Morita et al. | Nov 2009 | B2 |
7630338 | Vesterinen et al. | Dec 2009 | B2 |
7643416 | Pardee et al. | Jan 2010 | B2 |
7735129 | Nagata et al. | Jun 2010 | B2 |
7768920 | Goshen et al. | Aug 2010 | B2 |
7769851 | Guruswamy et al. | Aug 2010 | B1 |
7783666 | Zhuge et al. | Aug 2010 | B1 |
7809826 | Guruswamy | Oct 2010 | B1 |
7810151 | Guruswamy | Oct 2010 | B1 |
7823185 | Seaman et al. | Oct 2010 | B1 |
7849497 | Hurst et al. | Dec 2010 | B1 |
7881215 | Daigle et al. | Feb 2011 | B1 |
7904941 | Jagadeesan et al. | Mar 2011 | B2 |
7937755 | Guruswamy | May 2011 | B1 |
7948952 | Hurtta et al. | May 2011 | B2 |
7966654 | Crawford | Jun 2011 | B2 |
7996912 | Spalink et al. | Aug 2011 | B2 |
8046578 | Trudeau et al. | Oct 2011 | B1 |
8069244 | Wiryaman et al. | Nov 2011 | B2 |
8176561 | Hurst et al. | May 2012 | B1 |
8234702 | Maes | Jul 2012 | B2 |
8341723 | Abzarian et al. | Dec 2012 | B2 |
8355413 | Vasamsetti et al. | Jan 2013 | B2 |
8584199 | Chen et al. | Nov 2013 | B1 |
20020065835 | Fujisaki | May 2002 | A1 |
20020116545 | Mandato et al. | Aug 2002 | A1 |
20020147733 | Gold et al. | Oct 2002 | A1 |
20030005331 | Williams | Jan 2003 | A1 |
20030074563 | Spacey | Apr 2003 | A1 |
20030110379 | Ylonen et al. | Jun 2003 | A1 |
20040001475 | Mikkonen | Jan 2004 | A1 |
20040078568 | Pham et al. | Apr 2004 | A1 |
20040098620 | Shay | May 2004 | A1 |
20040107342 | Pham et al. | Jun 2004 | A1 |
20040123153 | Wright et al. | Jun 2004 | A1 |
20040162901 | Mangipudi et al. | Aug 2004 | A1 |
20040234056 | Heilmann et al. | Nov 2004 | A1 |
20050027980 | Peled et al. | Feb 2005 | A1 |
20050044138 | Albert et al. | Feb 2005 | A1 |
20050138162 | Byrnes | Jun 2005 | A1 |
20050138204 | Iyer et al. | Jun 2005 | A1 |
20050188197 | Bordes et al. | Aug 2005 | A1 |
20050226250 | Makayama et al. | Oct 2005 | A1 |
20050229237 | Xie et al. | Oct 2005 | A1 |
20050283823 | Okajo et al. | Dec 2005 | A1 |
20060059551 | Borella | Mar 2006 | A1 |
20060104233 | Zhang | May 2006 | A1 |
20060104284 | Chen | May 2006 | A1 |
20060174337 | Bernoth | Aug 2006 | A1 |
20060239254 | Short et al. | Oct 2006 | A1 |
20060250968 | Hudis et al. | Nov 2006 | A1 |
20060272013 | Kilgore | Nov 2006 | A1 |
20070008971 | Li et al. | Jan 2007 | A1 |
20070016937 | Bassett et al. | Jan 2007 | A1 |
20070016945 | Bassett et al. | Jan 2007 | A1 |
20070044144 | Knouse et al. | Feb 2007 | A1 |
20070168499 | Chu | Jul 2007 | A1 |
20070174905 | Martherus et al. | Jul 2007 | A1 |
20070195788 | Vasamsetti et al. | Aug 2007 | A1 |
20070204326 | Bocking et al. | Aug 2007 | A1 |
20070239987 | Hoole et al. | Oct 2007 | A1 |
20070294755 | Dadhia et al. | Dec 2007 | A1 |
20080028436 | Hannel et al. | Jan 2008 | A1 |
20080028445 | Dubuc et al. | Jan 2008 | A1 |
20080086473 | Searl et al. | Apr 2008 | A1 |
20080115190 | Aaron | May 2008 | A1 |
20080134308 | Yalakanti et al. | Jun 2008 | A1 |
20080148381 | Aaron | Jun 2008 | A1 |
20080222532 | Mester et al. | Sep 2008 | A1 |
20080229381 | Sikka et al. | Sep 2008 | A1 |
20080282336 | Diaz Cuellar et al. | Nov 2008 | A1 |
20090006847 | Abzarian et al. | Jan 2009 | A1 |
20090106433 | Knouse et al. | Apr 2009 | A1 |
20090138968 | Serber | May 2009 | A1 |
20100284327 | Miklos | Nov 2010 | A1 |
Number | Date | Country | |
---|---|---|---|
20100100949 A1 | Apr 2010 | US |