CROSS-REFERENCE TO RELATED APPLICATIONSThis application is a continuation of U.S. patent application Ser. No. 13/526,510 filed on Jun. 18, 2012, which is a continuation of U.S. patent application Ser. No. 13/114,292 filed on May 24, 2011, now U.S. Pat. No. 8,205,251, which is a continuation of U.S. patent application Ser. No. 11/283,891 filed on Nov. 22, 2005, now U.S. Pat. No. 7,966,654, each of which is hereby incorporated by reference in its entirety for all purposes.
COPYRIGHT NOTICEContained herein is material that is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction of the patent disclosure by any person as it appears in the Patent and Trademark Office patent files or records, but otherwise reserves all rights to the copyright whatsoever. Copyright © 2005-2013, Fortinet, Inc.
BACKGROUND1. Field
Embodiments of the present invention generally relate to network security. In particular, embodiments of the present invention relate to application-level content processing of network service protocols using a firewall.
2. Description of the Related Art
Security threats have evolved dramatically over the past 10 years, moving from network-level, connection-oriented attacks to application-level, agent-based attacks. Conventional networking devices (firewalls) can deal with network-level packet processing; for example, conventional firewalls can stop packets that do not come from a valid source, and VPN gateways can encrypt packets on the fly, making it safe for them to traverse the Internet.
But today's critical network threats, like viruses and worms, are embedded in the application-level contents of packet streams. Enormous processing power is needed to detect and stop these application-layer threats by extracting the content from multiple packets, reconstructing the original content, and scanning it for the telltale signs of attacks or for inappropriate content.
A firewall is typically implemented as a hardware/software appliance having a number of physical networking interfaces for the incoming and outgoing network traffic. Firewalls can be software-implemented and installed on a stand-alone computer, or they can be full-blown hardware appliances placed in a network to filter traffic going between multiple computers and/or the Internet. Network traffic enters one of these interfaces and, after filtering and other appropriate processing, is routed to a remote host typically attached to a different physical interface.
In a firewall, processing of network traffic is performed in accordance with a set of specific rules, which collectively form a firewall policy. The firewall policy dictates how the firewall should handle network traffic associated with specific applications such as web browsers, email or telnet. Exemplary rules include filtering of banned words, blocking specific URLs, blocking transmission of specific file types, antivirus scans, blocking of spam, etc. The firewall policy is usually created by the network administrator and is based on the information security policy of the respective organization.
Conventional firewalls were capable of blocking traffic at the packet level but were not intelligent enough to examine the content of those packets and to protect against application-layer threats. Modern firewalls have the ability to examine the content of various network traffic streams and appropriately react to threats transferred within the content of the traffic stream. With the growth of these abilities of the firewalls, there has also been a growth in the number of options and settings that an administrator would need to configure to ensure a secure network.
Many existing firewall systems use global configuration settings, such as global lists of URLs to block, lists of spam addresses, options to scan for viruses, spam, and others similar parameters. These settings are applied globally to all policies within the firewall.
This approach, however, does not provide much flexibility to the administrator. For example it may be desirable to block general staff members of an organization from accessing certain websites that don't necessarily contain objectionable material but may be a work distraction. On the other hand, staff managers may not need to be restricted from accessing the same websites. Using global configuration options to enable the above firewall configuration presents a difficult task. In other words, the existing firewall systems, which are often configured using global settings, tend to apply the same firewall configuration scheme to all the network content passing through the firewall.
Therefore, what is needed is a firewall system providing a flexible and effective control over configuration parameters applied to filtering and/or processing of various network content. Such a system would achieve an optimal content processing performance without compromising the security of the protected network.
SUMMARYMethods and systems are described for processing application-level content of network service protocols. According to one embodiment, a firewall device maintains a security policy database including information defining multiple firewall security policies. The information defining the firewall security policies includes an action to take with respect to a particular network session based on one or more of a set of one or more source internet protocol (IP) addresses, a set of one or more destination IP addresses and a network service protocol. When the action to take for a firewall security policy is to allow the particular network session to pass through the firewall device, then the firewall security policy also includes information regarding a configuration scheme defining a set of administrator-configurable content filtering processes to be performed on traffic associated with the particular network session. Policy-based content filtering of network sessions is performed by the firewall device by (i) identifying a firewall security policy that matches traffic associated with the network session; (ii) identifying multiple content filtering processes to be performed on the traffic based on the configuration scheme associated with the matching firewall security policy; and (iii) applying the identified content filtering processes on the traffic.
Other features of embodiments of the present invention will be apparent from the accompanying drawings and from the detailed description that follows.
BRIEF DESCRIPTION OF THE DRAWINGSEmbodiments of the present invention are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
FIG. 1 depicts a conceptual block-diagram of a firewall system in accordance with an embodiment of the present invention.
FIG. 2 illustrates an operating sequence of a firewall system to establish a basic network communication session in accordance with an embodiment of the present invention.
FIGS. 3 and 4 illustrate graphical user interface screen shots, which may be used to define one or more configuration schemes in accordance with various embodiments of the present invention.
FIGS. 5 and 6 illustrate graphical user interface screen shots for displaying and adjusting parameters of firewall policies in accordance with various embodiments of the present invention.
FIGS. 7 and 8 illustrate graphical user interface screen shots in accordance with alternative embodiments of the present invention.
FIG. 9 is a flow diagram illustrating network content processing in accordance with an embodiment of the present invention.
FIG. 10 is a flow diagram illustrating network content processing in accordance with an alternative embodiment of the present invention.
FIG. 11 illustrates a computer platform with which embodiments of the present invention may be employed.
DETAILED DESCRIPTIONMethods and systems are described for processing application-level content of network service protocols. In the following detailed description, reference will be made to the accompanying drawing(s), in which identical functional elements are designated with like numerals. The aforementioned accompanying drawings show by way of illustration, and not by way of limitation, specific embodiments and implementations consistent with principles of the present invention. These implementations are described in sufficient detail to enable those skilled in the art to practice the invention and it is to be understood that other implementations may be utilized and that structural changes and/or substitutions of various elements may be made without departing from the scope and spirit of present invention. The following detailed description is, therefore, not to be construed in a limited sense. Additionally, the various embodiments of the invention as described may be implemented in the form of a software running on a general purpose computer, in the form of a specialized hardware, or combination of software and hardware.
Embodiments of the present invention are directed to methods and systems that substantially obviate one or more of the above and other problems associated with conventional techniques for configuring firewalls to filter and/or otherwise process network content.
The inventor recognized that it would have been advantageous to provide methods and systems, which would enable more granular control over firewall settings. Such configuration flexibility was not permitted under the conventional techniques.
Firewalls and other filtering gateways have become common security devices for improving computer network security. As more features and functionality are added to these devices they become quite complex to configure. By associating configuration schemes with firewall policies, configuration can be simplified without compromising flexibility. Administrators have more options to filter different traffic streams based on their type and sources. They also have increased flexibility to be able to filter traffic on a per user basis, through authentication mechanisms tied to various filtering options.
Generally, firewall policies are designed to control the flow of network traffic through the firewall. A typical firewall policy defines a set of rules applied to handling of the entire passing network traffic or any specific portion thereof. The portion of the network traffic to which a predetermined firewall policy applies may be specified using, for example, the network address of the source entity, the network address of the destination entity as well as the networking protocol used in the transmission. Different firewall policies may be assigned to different transmission protocols, which, in turn, implement different networking services.
When a specific network connection is initiated, the connection will commonly have an associated source network address, destination network address and service port identifier. This information is gathered by the firewall and checked against existing firewall policies. If the connection information matches a specific firewall policy, the firewall applies the relevant policy to the connection.
Low-level, network layer firewalls generally may only permit or reject the network traffic, typically at the network packet level, and they make their decisions based on the source and destination addresses and the associated network ports in individual IP packets. In such firewalls, the set of rules associated with the firewall policy may generally specify which network traffic is permitted to proceed and which is rejected and the firewall policy may be defined in terms of source and destination IP addresses together with the associated communication ports. This information is contained in individual IP packets and is retrieved by the firewall upon packet inspection.
Higher-level, content-filtering application layer firewalls generally are hosts running proxy servers, which permit no traffic directly between networks, and which perform elaborate logging and auditing of traffic passing through them. Because the proxy applications are software components running on the firewall, they are used to perform logging and access control. In such systems, the firewall policy may provide an additional option for handling of the network traffic, which may include re-directing specific packets to another routine or program, such as a proxy, which may perform a specified operation upon the packets or gather the content of the packets for deeper examination and/or logging. Because of the greater flexibility of the network traffic processing in the proxy, the configuration of the proxy may involve a substantial number of configuration parameters.
In accordance with an embodiment of the invention, in a firewall system having the ability to redirect the communication stream to the proxy program, each firewall policy is provided with an associated collection of settings. These settings may generally include, but are not limited to, various types of filters. By having the ability to associate a collection of settings (hereinafter referred to as “configuration scheme”) with individual firewall polices, the administrator of the inventive firewall system has a greater control over how various communication pathways are filtered.
In an exemplary embodiment of the inventive firewall system, a configuration scheme is associated with a specific firewall policy by means of a scheme identifier, a variable, comprising numeric information, character information or binary bits, that is stored in a data structure associated with the firewall policy, which is called a “policy structure.” The policy structure may be disposed within the kernel of the firewall computer system. When a new communication session matching a particular firewall policy is initiated, this session inherits the scheme identifier value from the corresponding policy structure. The proxy program, to which the communication connection is redirected, then retrieves this identifier value from the communication connection structure and uses it to look up the scheme settings from the configuration database or, alternatively, from a local cache. The configuration database in the inventive system may be as simple as a text file holding records of information or as complex as a fully featured database system.
FIG. 1 illustrates a topology of a firewall-protectednetwork100 in accordance with an embodiment of the present invention. Twonetwork entities104 and105 are connected to opposite sides of a physical device (the firewall)101, which monitors thenetwork traffic108,109 passing between them. The firewall101 may drop or alter some of this traffic based on a predefined set of rules. Therefore, the content of thenetwork traffic108 may not be identical to the content of thetraffic109. According to an embodiment of the inventive technique, the twonetwork entities104 and105 are connected to the firewall101 by a direct link. In an alternative embodiment, the connection is accomplished through a routed network (not shown).
As shown inFIG. 1, the firewall101 is disposed within the network communication channel between the twouser systems104 and105 and monitors network packet exchanges between them. As would be appreciated by those of skill in the art, for some well-known protocols, such as TCP, the transmitted network packets can be inspected for known threats or questionable content by one or more scanning engines. When a packet that matches one of the known signatures is detected, the inventive firewall system may generate a log message or set off an alarm, and the packet may be dropped. In one embodiment of the inventive system, the entire connection between the two users would be dropped as well.
As would be also appreciated by those of skill in the art, in many cases, the rules or signatures used to detect questionable data cannot be applied to individual packets.
Stream protocols, such as TCP, will break up data into smaller chunks during transmission, but the detection heuristics must be applied to the entire data stream rather than the individual packets. Therefore, in the inventive system, the data would be first buffered by the firewall101 in order to extract the data stream, and then the filtering rules would be applied to this stream. In many cases, the packets would be redirected by thenetworking subsystem106 of the kernel of the firewall101 to a user space application (proxy)107 that builds and interprets the data buffer.
The firewall system shown inFIG. 1 includes physical network interfaces102 and103, and theaforesaid networking subsystem106, which may be implemented as a part of the kernel of the operating system of the firewall appliance101. Thenetworking subsystem106 routes the packets between thephysical interfaces102 and103 and transfers the data between various logical subsystems on the firewall system101. Several types of stream-based data are intercepted by thenetworking subsystem106 and buffered by aproxying module107 for future processing. It should be noted that whileFIG. 1 shows only physical interfaces, in another embodiment of the inventive firewall, one or both of theinterfaces102 and103 may be logical interfaces.
Thenetworking subsystem106 may be configured to intercept data transmissions formatted in accordance with various networking protocols including, without limitation, Server Message Block/Common Internet File System (SMB/CIFS), instant messaging (IM) protocols (e.g., AOL Instant Messenger (AIM), MICROSOFT Network (MSN) messenger, YAHOO! Messenger, SKYPE), and peer-to-peer (P2P) protocols (e.g., FASTTRACK, BEEP, GNUTELLA, AVALANCHE, BITTORRENT). Additionally, Simple Mail Transfer Protocol (SMTP), Post Office Protocol 3 (POP3), Internet Message Access Protocol (IMAP), HyperText Transfer Protocol (HTTP), File Transfer Protocol (FTP), telnet, etc. The intercepted data packets are routed to theproxy module107 for re-assembly, inspection and other processing.
In one embodiment of the invention, theproxying module107 is implemented in the OS kernel. In an alternative embodiment, theproxy107 is implemented in the form of an application executing in the user space provided by the operating system of the firewall appliance101. Theproxying module107 assembles the formatted packets intercepted by thenetworking subsystem106 in accordance with the specification of the respective communication protocol to arrive at the transmission content. Depending on the specifics of the used communication protocol, an embodiment of the inventive system may provide for re-ordering of the data packets prior to, or during the transmission re-assembly.
Aconfiguration database110 stores various firewall policies, configuration schemes and other parameters used by the firewall system101. The stored parameters are retrieved from thedatabase110 by theproxy107. In one embodiment of the inventive system, theproxying module107 is configured to support one network protocol. In such implementation, multiple proxying subsystems may be provided if the system is designed to handle multiple protocols. Additionally or alternatively, multiple instances ofproxy107 may be executed to support the same network protocol or different network protocols. Moreover, theproxy107 may be designed to support the entire communication language of the respective protocol or any portion thereof. Finally, theproxy107 may use an external program to retrieve various configuration settings from thedatabase110. Likewise, an external program may be used to apply various filters to the network transmission content processed by theproxy107.
FIG. 2 illustrates an operating sequence of the inventive firewall system associated with establishment of a basic network communication session. Anincoming connection201 is accepted by thenetworking subsystem106 of the firewall kernel after a lookup of an applicable firewall policy. In the shown sequence, the policy indicates that the session should be redirected (at202) to theuser level proxy107. Theproxy107 performs any needed initialization and then queries the kernel (at203) to retrieve the configuration scheme associated with the session. Once the scheme identifier has been retrieved (at204) the proxy queries (at205) the configuration database (110) to retrieve the settings for the configuration scheme matching the specified identifier. Once the settings are retrieved (at206) theproxy107 can continue with any filtering tasks or other tasks necessary to handle the networking session.
In an embodiment of the inventive concept, multiple configuration schemes may be specified by the network administrator using, for example, a graphical user interface or a command line interface of the firewall system101. The settings specified by the administrator, as well as other appropriate parameters, may be stored in theconfiguration database110 for subsequent retrieval. In an exemplary embodiment of the inventive technique, each created configuration scheme is assigned a unique identifier value, which may or may not be displayed to the administrator. This identifier value is subsequently stored in one or more data structures associated with the corresponding firewall policy and used to retrieve the appropriate configuration scheme.
Theconfiguration database110 may be implemented on the same computer platform as the rest of the firewall101. This database may be implemented using any suitable database system, such as general-purpose relational database systems distributed by ORACLE Corporation, IBM Corporation and MICROSOFT Corporation. In an alternative embodiment of the invention, a special-purpose embedded database may be utilized. In yet alternative embodiment, the configuration database may be implemented using file system facilities of the firewall101. Finally, thedatabase system110 may be implemented on separate computer hardware from the rest of the firewall101.
FIGS. 3 and 4 display exemplary embodiments of a graphical user interface which may be used by an administrator of the inventive firewall system in defining one or more configuration schemes. Specifically, theinterface300 shown inFIG. 3 displays a list of existing configuration schemes301-304. Each of the schemes301-304 may be assigned a unique name or alias for easy reference. Using theinterface300, new schemes may be created and the existing schemes may be modified or deleted.
Theinterface400 shown inFIG. 4 displays a detailed view of a specific configuration scheme. The displayedexemplary scheme400 is arranged into separate protocol sections (columns401-406). Each such section may include multiple configuration settings corresponding to the specific protocol. The protocols shown inFIG. 4 include HTTP, FTP, SMTP, IMAP, POP3, SMB/CIFS. However, the invention is not limited only to the shown protocols. Any other suitable protocols may be used. Normally, theinventive interface400 only displays protocols supported by theproxy engine107 of the firewall101. However, as the proxy functionality is expanded to support additional networking protocols, thegraphical user interface400 may be configured, either manually or automatically, to display those additional protocols as well.
As will be appreciated by those of skill in the art, not all configuration settings are appropriate for all protocols. Therefore, in theinventive interface400, some settings are not available for some protocols. For example, the e-mail spam block is not available for non-email protocols. Various parameters of the specific configuration scheme displayed using theinterface400 may be input or adjusted by the network administrator by means of toggle options (checkboxes), named selections (drop down combo boxes), multi-selections, as well as number and text based entries. The configuration scheme may include lists of various items, such as lists of banned words or lists of HTTP URLs to be blocked. Such lists may be linked to appropriate graphical primitive(s) within theinterface400, such as items408-410 shown inFIG. 4. Upon administrator's selection of the appropriate graphical primitive, the corresponding list may be displayed and the administrator may be provided with an ability to add to or otherwise modify its content.
As it would be appreciated by those of skill in the art, the inventive concept is by no means limited only to the shown parameters and settings. Various other settings and parameters may be displayed and appropriately configured by theinterfaces300 and400. Moreover, theinterface400 may be configured to automatically display new parameters and configuration options when it detects that theproxy module107 of the firewall101 has been enhanced to support new protocols as well as new filtering and other content processing capabilities.
In addition to the capability to create and/or modify firewall configuration schemes, an embodiment of the present invention is additionally provided with a graphical user interface or, alternatively, a command line interface enabling an administrator to specify and manage multiple firewall policies. The policy settings may also be stored in theconfiguration database110. In an embodiment of the invention, at least a portion of information descriptive of the policy settings is stored in the kernel of the firewall101.
Exemplary embodiments of the policy-setting graphical user interfaces of the inventive firewall system101 are illustrated inFIGS. 5 and 6. Specifically,exemplary interface500 shown inFIG. 5 displays a list of all firewall policies in effect. The showninterface500 is organized in a tabular form with each of therows501,502 and503 corresponding to firewall policies withpolicy identification numbers 1, 2 and 5, respectively. Parameters incolumns504,505 and507 specify source network address, destination network address and transmission protocol to which specific listed policy is made applicable. Column506 specifies when the specific policy has effect. Column508 contains settings specifying how the corresponding network traffic should be handled. The configuration scheme for each effective policy is specified incolumn509. The network administrator is provided with an option to enable or disable any specific policy and to modify or delete it, seecolumns510 and511.
FIG. 6 illustratesgraphical user interface600 for displaying and adjusting various individual parameters of a specific firewall policy. The policy parameters included in theinterface600 generally correspond to the columns ofinterface500. Using theinterface600, the administrator may modify any appropriate policy settings.
As described in details above, any specific firewall policy may be provided with an associated configuration scheme such that networking protocols supported by the policy are filtered or otherwise processed in accordance with the settings of that configuration scheme. The relevant configuration scheme is identified and assigned to a session when the session is created. At that point, the configuration scheme identifier is written into the policy structure in the kernel so that it can be transferred into new session structures as new sessions connect. If more than one policy is defined, different policies may use either the same configuration scheme, all different configuration schemes, or any combination of the above. It is also permissible, in an embodiment of the invention, to apply no configuration scheme to a policy. In such a case, the policy becomes a conventional firewall policy with no filtering capabilities. In another embodiment of the invention, multiple configuration schemes may be assigned to a single firewall policy.
In another embodiment of the invention, the policy-based filters are implemented using user-authenticated groups. Specifically, certain firewall policies may utilize some form of user authentication. To enable utilization of such policies, one or more users on the network may be grouped together into one or more named groups of users, for example Accounting Team. It should be noted that certain groups may consist of only one user. A specific firewall configuration scheme may be assigned to a user group or an individual user. As would be appreciated by those of skill in the art, the utilization of user group-based firewall policies and associated configuration schemes enables flexible assignment of different levels of use restrictions of various network services to different groups of users.
FIGS. 7 and 8 illustrate an alternative embodiment of the user interface of the inventive firewall system. In the interface shown inFIG. 7, multiple configuration schemes are displayed on the same page together with their parameters. Each of the rows701 and702 corresponds to a specific configuration scheme, while each of the columns703-707 displays settings corresponding to one specific networking protocol. On the other hand, theinterface800 shown inFIG. 8 may be used to edit various parameters associated with a specific configuration scheme. In theinterface800, shown in that figure, various protocols are grouped together in accordance with protocol type, includingweb protocol801,mail protocols802 and filetransfer protocol803. The configuration scheme parameters displayed inFIG. 8 generally correspond to parameters included in each of the rows701 or702 ofFIG. 7.
FIG. 9 illustratesexemplary operating sequence900 of an embodiment of the inventive firewall system101. Upon the receipt of the incoming connection, atstep902, the inventive firewall system101 uses the connection information to identify the applicable firewall policy, seestep903. The relevant connection information may include, without limitation, the connection source and destination addresses, as well as connection service protocol determined in accordance to the connection port number information. The necessary connection information may be extracted from the network packets intercepted by thenetworking subsystem106 of the kernel.
Atstep904, the system applies packet-layer firewall rules to determine whether the connection should be allowed. Non-compliant connections are rejected at step909. The allowed connections are checked against a list of service protocols supported by theproxy107, seestep905. Content formatted according to non-supported protocols is sent directly to the destination atstep908. If the connection protocol is supported by theproxy107, atstep906, the system checks whether a specific configuration scheme is assigned to the connection, and, if so, applies the scheme atstep907. Atstep910, the system checks whether the transmission content needs to be modified and modifies the content, if appropriate, atstep911.
FIG. 10 illustrates anexemplary operating sequence1000 of an alternative embodiment of the inventive firewall system101. Thesequence1000 differs from thesequence900 ofFIG. 9 in applyingadditional authentication steps1005 and1006 to the networking connection. Specifically, upon determination, atstep904, that the connection satisfies the packet-layer rules, the system authenticates the user and rejects the connection if the authentication fails, seesteps1005 and1006, respectively. In addition, in the sequence shown inFIG. 10, atstep1007, the inventive system checks for a configuration scheme assigned to the user/usergroup, which, in turn, corresponds to the firewall policy that applies to the current connection. The found scheme is then applied atstep907. The remaining steps of thesequence1000 are equivalent to the corresponding steps of thesequence900 ofFIG. 9.
An example of a hardware platform in accordance with an embodiment of the present invention will now be described.FIG. 11 is a block diagram that illustrates an embodiment of acomputer platform1100 upon which an embodiment of the inventive methodology may be implemented. Thesystem1100 includes a computer/server platform1101,peripheral devices1102 and network resources1103.
Thecomputer platform1101 may include adata bus1104 or other communication mechanism for communicating information across and among various parts of thecomputer platform1101, and a processor1105 coupled withbus1101 for processing information and performing other computational and control tasks.Computer platform1101 also includes avolatile storage1106, such as a random access memory (RAM) or other dynamic storage device, coupled tobus1104 for storing various information as well as instructions to be executed by processor1105. Thevolatile storage1106 also may be used for storing temporary variables or other intermediate information during execution of instructions by processor1105.Computer platform1101 may further include a read only memory (ROM or EPROM)1107 or other static storage device coupled tobus1104 for storing static information and instructions for processor1105, such as basic input-output system (BIOS), as well as various system configuration parameters. Apersistent storage device1108, such as a magnetic disk, optical disk, or solid-state flash memory device is provided and coupled tobus1101 for storing information and instructions.
Computer platform1101 may be coupled viabus1104 to adisplay1109, such as a cathode ray tube (CRT), plasma display, or a liquid crystal display (LCD), for displaying information to a system administrator or user of thecomputer platform1101. Aninput device1110, including alphanumeric and other keys, is coupled tobus1101 for communicating information and command selections to processor1105. Another type of user input device iscursor control device1111, such as a mouse, a trackball, or cursor direction keys for communicating direction information and command selections toprocessor1104 and for controlling cursor movement ondisplay1109. This input device typically has two degrees of freedom in two axes, a first axis (e.g., x) and a second axis (e.g., y), that allows the device to specify positions in a plane.
An external storage device1112 may be connected to thecomputer platform1101 viabus1104 to provide an extra or removable storage capacity for thecomputer platform1101. In an embodiment of thecomputer system1100, the external removable storage device1112 may be used to facilitate exchange of data with other computer systems.
Embodiments of the invention relate to the use ofcomputer system1100 for implementing the techniques described herein. In an embodiment, the inventivecontent processing systems300 and400 may reside on a machine such ascomputer platform1101. In an embodiment, database313 may be deployed on a machine such ascomputer platform1101. According to one embodiment of the invention, the techniques described herein are performed bycomputer system1100 in response to processor1105 executing one or more sequences of one or more instructions contained in thevolatile memory1106. Such instructions may be read intovolatile memory1106 from another computer-readable medium, such aspersistent storage device1108. Execution of the sequences of instructions contained in thevolatile memory1106 causes processor1105 to perform the process steps described herein. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the invention. Thus, embodiments of the invention are not limited to any specific combination of hardware circuitry and software.
The term “computer-readable medium” as used herein refers to any medium that participates in providing instructions to processor1105 for execution. The computer-readable medium is just one example of a non-transitory machine-readable medium, which may carry or otherwise embody instructions for implementing any of the methods and/or techniques described herein. Such a medium may take many forms, including but not limited to, non-volatile media and volatile media. Non-volatile media includes, for example, optical or magnetic disks, such asstorage device1108. Volatile media includes dynamic memory, such asvolatile storage1106.
Common forms of non-transitory computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punchcards, papertape, any other physical medium with patterns of holes, a RAM, a PROM, an EPROM, a FLASH-EPROM, a flash drive, a memory card, any other memory chip or cartridge.
Various forms of computer readable media may be involved in carrying one or more sequences of one or more instructions to processor1105 for execution. For example, the instructions may initially be carried on a magnetic disk from a remote computer.
Alternatively, a remote computer can load the instructions into its dynamic memory and send the instructions over a telephone line using a modem. A modem local tocomputer system1100 can receive the data on the telephone line and use an infrared transmitter to convert the data to an infrared signal. An infrared detector can receive the data carried in the infrared signal and appropriate circuitry can place the data on thedata bus1104. Thebus1104 carries the data to thevolatile storage1106, from which processor1105 retrieves and executes the instructions. The instructions received by thevolatile memory1106 may optionally be stored onpersistent storage device1108 either before or after execution by processor1105. The instructions may also be downloaded into thecomputer platform1101 via Internet using a variety of network data communication protocols well known in the art.
Thecomputer platform1101 also includes a communication interface, such asnetwork interface card1113 coupled to thedata bus1104.Communication interface1113 provides a two-way data communication coupling to anetwork link1114 that is connected to alocal network1115. For example,communication interface1113 may be an integrated services digital network (ISDN) card or a modem to provide a data communication connection to a corresponding type of telephone line. As another example,communication interface1113 may be a local area network interface card (LAN NIC) to provide a data communication connection to a compatible LAN. Wireless links, such as well-known 802.11a, 802.11b, 802.11g and Bluetooth may also be used for network implementation. In any such implementation,communication interface1113 sends and receives electrical, electromagnetic or optical signals that carry digital data streams representing various types of information.
Network link1113 typically provides data communication through one or more networks to other network resources. For example,network link1114 may provide a connection throughlocal network1115 to a host computer1116, or a network storage/server1117. Additionally or alternatively, thenetwork link1113 may connect throughgateway1117 to the wide-area orglobal network1118, such as an Internet. Thus, thecomputer platform1101 can access network resources located anywhere on theInternet1118, such as a remote network storage/server1119. On the other hand, thecomputer platform1101 may also be accessed by clients located anywhere on thelocal area network1115 and/or theInternet1118. Thenetwork clients1120 and1121 may themselves be implemented based on the computer platform similar to theplatform1101.
Local network1115 and theInternet1118 both use electrical, electromagnetic or optical signals that carry digital data streams. The signals through the various networks and the signals onnetwork link1114 and throughcommunication interface1113, which carry the digital data to and fromcomputer platform1101, are exemplary forms of carrier waves transporting the information.
Computer platform1101 can send messages and receive data, including program code, through the variety of network(s) includingInternet1118 andLAN1115,network link1114 andcommunication interface1113. In the Internet example, when thesystem1101 acts as a network server, it might transmit a requested code or data for an application program running on client(s)1120 and/or1121 throughInternet1118,gateway1117,local area network1115 andcommunication interface1113. Similarly, it may receive code from other network resources.
The received code may be executed by processor1105 as it is received, and/or stored in persistent orvolatile storage devices1108 and1106, respectively, or other non-volatile storage for later execution. In this manner,computer system1101 may obtain application code in the form of a carrier wave.
It should be noted that embodiments of the present invention are not limited to any specific firewall system. For example, the inventive policy-based content processing system may be used in any of the three firewall operating modes and specifically NAT, routed and transparent.
Finally, it should be understood that processes and techniques described herein are not inherently related to any particular apparatus and may be implemented by any suitable combination of components. Further, various types of general purpose devices may be used in accordance with the teachings described herein. It may also prove advantageous to construct specialized apparatus to perform the method steps described herein. The present invention has been described in relation to particular examples, which are intended in all respects to be illustrative rather than restrictive. Those skilled in the art will appreciate that many different combinations of hardware, software, and firmware will be suitable for practicing the present invention. For example, the described software may be implemented in a wide variety of programming or scripting languages, such as Assembler, C/C++, perl, shell, PHP, Java, etc.
Moreover, other implementations of various embodiments of the present invention will be apparent to those skilled in the art from consideration of the specification and practice of the invention disclosed herein. Various aspects and/or components of the described embodiments may be used singly or in any combination in the computerized network content processing system. It is intended that the specification and examples be considered as exemplary only, with a true scope and spirit of the invention being indicated by the following claims.