The present invention relates to apparatus for and a method of assessing threat to at least one computer network.
Large organizations, such as international banks and other financial institutions, rely heavily on their computer systems to carry out their business operations. Increasingly, organizations are connecting their networks to public networks, such as the Internet, to allow them to communicate with their customers and other organizations. However, in doing so, they open up their networks to a wider range and greater number of electronic threats, such as computer viruses, Trojan horses, computer worms, hacking and denial-of-service attacks.
To respond to these forms of threat, organizations can implement procedures, tools and countermeasures for providing network security. For example, they can install intrusion detection and prevention systems to protect their network. However, even if these security systems are properly managed and well maintained, their network may still be vulnerable to threat. Furthermore, their network may also be vulnerable to other, non-electronic forms of threat, such as fire, flood or terrorism.
The present invention seeks to provide apparatus for and a method of assessing threat to a computer network or computer networks.
According to the present invention there is provided apparatus for assessing threat to at least one computer network in which a plurality of systems operate, the apparatus configured to determine predicted threat activity, to determine expected downtime of each system in dependence upon said predicted threat activity, to determine loss for each of a plurality of operational processes dependent on the downtimes of the systems, to add losses for the plurality of processes so as to obtain a combined loss arising from the threat activity.
The apparatus may comprise a first module configured to determine the predicted threat activity, a second module configured to determine the expected downtime of each system and a third module configured to determine the loss for each of a plurality of operational processes. The third module may be configured to add the losses for the plurality of processes.
The apparatus may be configured to store at least one of the losses and the combined loss in a storage device. The apparatus may be configured to display at least one of the losses and the combined loss on a display device.
The apparatus may be further configured to output the predicted threat activity to a firewall.
The loss may be value at risk.
The apparatus may be configured to retrieve a list of observed threats and to determine the predicted threat activity based upon the list of observed threats.
The observed list of threats may include, for each threat, information identifying at least one system. The observed list of threats may include, for each threat, information identifying frequency of occurrence of the threat. The frequency of occurrence of the threat may include at least one period of time and corresponding frequency of occurrence for the at least one period of time.
The plurality of systems may include a plurality of software systems
According to a second aspect of the present invention there is provided a method of assessing threat to at least one computer network in which a plurality of system operate, the method comprising determining predicted threat activity, determining expected downtime of each system in dependence upon said predicted threat activity, determining loss for each of a plurality of operational processes dependent on the downtimes of the systems, adding losses for the plurality of processes to obtain a combined loss arising from the threat activity.
The method may further comprise storing at least one of the losses and combined loss in a storage device. The method may further comprise displaying at least one of the losses and combined loss on a display device.
According to a third aspect of the present invention there is provided a computer program, which, when executed by a computer system, causes the computer system to perform the method.
According to a fourth aspect of the present invention there is provided a computer readable medium storing the computer program.
Embodiments of the present invention will now be described, by way of example, with reference to the accompanying drawings in which:
Referring to
The Internet 2 is a source of electronic threat, such as computer viruses (herein referred to simply as “viruses”), Trojan horses (“Trojans”), computer worms (“worms”), hacking and denial-of-service attacks. If a threat enters the corporate network 1 and is not stopped, then it can cause damage within the corporate network 1. For example, a virus may infect information technology (IT) systems 30 (
An IT system may be or include software, such as an operating system, an application or a combination of operating system and application(s). An IT system may be or include hardware, such as server(s), storage, network connections or a combination of one or more hardware elements. As will be explained in more detail later, some types of threat, such as virus, may affect software, and other types of threat, such as fire, may affect hardware and/or software. An IT system can be treated, for the purposes of assessing threats, as a combination of software and hardware.
The degree to which an organization will be affected by a successful attack depends on a number of factors, such as the number of IT systems 30 (
If the likelihood of an attack succeeding can be estimated for a number of different threats, then this can be combined with knowledge of the logical structure of IT systems 30 (
A module 6 (hereinafter referred to as a “threat analyzer”) samples incoming traffic 4 and identifies threats using a list 7 of known threats stored in a database 8. For example, the module 6 may be a computer system running SNORT (for example release 2.6.0.1) available from www.snort.org.
The threat analyzer 6 produces observed threat data 9, which includes a list of observed threats and their frequency of occurrence, and stores the data 9 in a database 10.
In some embodiments of the present invention, a system 11 for assessing threat uses models threats to the corporate network 1 so as to predict loss 12 arising from these threats and/or to provide feedback 13 to the firewall 3.
Each observed threat is defined using an identifier, a name, a description of the threat, a temporal profile specifying frequency of occurrence of the threat, a target (or targets) for the threat and a severity score for the (or each) target.
The identifier (herein the attribute “Threat ID” is used) uniquely identities a threat.
The Threat ID may be string of up to 100 characters. For example, the Threat ID may be “Win32.Word.B32 m”.
The target (“Target”) is a system category attacked by the threat. Targets are preferably named in a systematic way. Examples of targets include “Windows.XP” or “Oracle.9i”. Targets can be identified at different levels using a format “system.version[-system.version[-system.version]]”. For example, if a threat attacks Oracle running on Windows XP, then the target may be specified as “Oracle.9i-Windows.XP”.
A system category may depend on other categories. For example, a company may have a system which depends on Windows Server 2003 and another system which depends on Windows XP, i.e. two different system categories. Thus, if a threat attacks more than one category, such as all versions of Windows, this can be handled by introducing a third system category, such as Windows, on which both of the other categories, in this example Windows Server 2003 and Windows XP, depend.
The severity score (“SeverityScore”) is a measure of the impact of a successful threat. It is not a measure of the prevalence or exposure to the threat, but rather an indication of the damage that would be caused to the target system. Severity score may also be referred to as “damage level”. In this example, the severity score is a value lying in a range between 1 and 10. For example, a value of 1 can represent trivial impact and a value of 10 may represent a catastrophic effect. However, the severity score may be defined as “low”, “medium”, “high” or “critical”.
The temporal profile is used to describe frequency of occurrence of a threat because loss caused by system downtime may vary according to the time of the week. The temporal profile may be visible to and/or editable by a user for some types of threat, such as physical threats, and may be implicit and/or fixed for other types of threat, such as that defined in SNORT data.
The profile is expressed as a sequence of elements, each of which has a time block and a count of the observed occurrences of the threat during the block. Threat occurrences are preferably aggregated as far as possible to provide a simple profile whilst remaining consistent with recorded instances. A more complex profile can be used if the simple profile significantly deviates from recorded instances. For example, if a threat is observed only a very small number of times, then it is appropriate to specify a uniform time profile. However, if a different threat is observed many times and always, for example, on a Monday morning, then a more complex profile reflecting the actual distribution may be used.
Herein the temporal profile is defined in terms of day (attribute “Day”), period of day (“From”, “To”) and frequency (“Count”).
Time blocks need not be same for different threats, although, for any given threat, blocks should do not overlap. If a part of a week is not covered by a block, threat occurrence is assumed to be zero.
The observed threat data is stored as a single file in Extensible Markup Language (XML) format encoded using 8-bit Unicode Transformation Format (UTF) as shown in the following simple example:
<?xml version=“1.0” encoding=“utf-8”?>
<AssessmentSystem Version=“1”>
<ObservedThreats ObservationStart=“2006-07-31T00:00:00” ObservationEnd=“2006-08-07T00:00:00”>
<Threat ID=“Win32.Worm.B32m” Target=“Windows.XP” SeverityScore=“4”>
<Observation From=“00:00:00” To=“12:00:00” Count=“8”/>
<Observation From=“12:00:00” To=“00:00:00” Count=“1”/>
</Threat>
<Threat ID=“Linux.Trojan.A12s” Target=“Oracle.9i” SeverityScore=“6”>
<Observation Day=“Monday” Count=“50”/>
<Observation Day=“Tuesday Wednesday” Count=“23”/>
<Observation Day=“Thursday Friday Saturday” Count=“11”/>
<Observation Day=“Sunday” Count=“0”/>
</Threat>
<Threat ID=“DenialOfService” Target=“IIS” SeverityScore=“2”>
<Observation Day=“Sunday” From=“00:00:00” To=“08:00:00” Count=“1154”/>
<Observation Day=“Sunday” From=“08:00:00” To=“16:30:00” Count=“237”/>
<Observation Day=“Monday” To=“12:00:00” Count=“350”/> <!--From is 00:00:00-->
<Observation Day=“Monday” From=“12:00:00” Count=“208”> <!--To is 00:00:00-->
<Observation Day=“Tuesday Wednesday Thursday Friday Saturday” Count=“2134”/>
</Threat>
</ObservedThreats>
</AssessmentSystem>
In the example just given, three different types of observed threat are specified, namely a virus “Win32.Worm.B32 m”, a Trojan “Linux.Trojan.A12s” and a denial-of-service attack “DenialOfService”. However, it will be appreciated that there may be many more observed threats, e.g. tens or hundreds of thousands of threats or more.
Referring to
The activity predictor 14 receives the observed threat data 9 from the database 10, for example by retrieving the data automatically or in response to user instruction, extrapolates future event frequency and produces a profile 13 of predicted threat activity, which includes a list of predicted threats and their expected frequency of occurrence. The predicted threat activity profile 13 may be stored in a database 16.
Event frequency can be extrapolated from the historical data using a variety of editable factors which can be based upon advice from security consultants, political factors and so on.
Each predicted threat is defined using an identifier, a name, a description, a frequency of occurrence, a category (or categories) of system attacked and a corresponding damage level for each system.
A user, via input device 17, can manually add information 18 about other electronic and non-electronic forms of threat so that it can be added to the predicted threat activity profile 13.
Non-electronic forms of threat include, for example, fire, flood and terrorism attack. Information about non-electronic forms of attack is arranged in a similar way to information about electronic forms of threat and include, for each threat, an identifier, a name, a description and frequency of occurrence, categories of system attacked and corresponding damage levels.
The user can also provide or edit information about threat. For example, they can specify data regarding, extrapolation factors, the IT systems subject to attack, such as its identity, name and category identity, systems categories, such as its identity and name, operational processes, such as its identity, name and value, and process dependencies, such as process identity, system identity, dependency description and dependency level.
As shown in
The threat assessment system 11 includes a second module 19 (hereinafter referred to as a “system risk calculator”) for calculating system risk.
The system risk calculator 19 receives the predicted threat activity profile 13 (either from the activity predictor 14 or the database 16) and information 20 about the IT systems 30 (
Each IT system 30 (
An IT system may be defined in terms of physical location. This may be used to identify threats to some types of threat, such as fire, flooding, terrorism, power loss and so on.
The system 11 includes a third module 24 (hereinafter referred to as a “predicted loss calculator”) for predicting the loss to the organization.
The predicted loss calculator 24 receives the system risk 22 and data 25 listing operational processes from a database 26, then predicts the loss for each operational process, aggregates the results for each process and outputs predicted loss data 12. The predicted loss data 12 may be stored in database 28 and/or output on display device 29.
Each process is defined by identity and a name, value in terms of the cost of downtime. The dependency of each process on an underlying IT system is defined by process identity, system identity, dependency description and dependency level.
Referring also to
In
For example, a system category 33 in a higher level may be Windows and system categories 33 in a lower level may be Windows Server 2003 and Windows XP. A system 30 may be a corporate server which depends on Windows Server 2003 and another system 30 could be desktop computer which depends on Windows XP.
System categories 33 may be omitted and so threats to systems 30 may be considered directly.
The threat assessment system 11 can output a report of the predicted loss, e.g. an aggregate value at risk, to the organization for each process in terms of process name, estimated annual downtime and predicted loss. For example, the report can be shown on the display device 29, for example, as a bar chart of predicted loss for each process and can be exported as a database file, such as an Microsoft® Excel® file (e.g., with an “.xls” extension) or in eXtensible Markup Language file, (e.g., with an “.xml” extension).
Referring to
Computer program code 43 is stored in the hard disk storage 38 and loaded into memory 37 for execution by the processor(s) 36 to provide the modules 14, 19, 24. The computer program code 43 may be stored on and transferred from removable storage 42 or downloaded via the network interface 42 from a remote source (not shown).
The threat assessment system 11 generally has two modes of operation to meet different operational criteria.
In a “live mode”, the activity predictor 14 periodically, for example daily, connects to the known threat database 10 (which is preferably continuously updated), retrieves the observed threat profile 9 and produces a new predicted activity 13. The predicted activity 13 is fed back to the firewall 3.
In an “analysis mode”, a snapshot of the observed threat profile 9 is taken, predicted loss is assessed and a report produced.
Operation of the threat assessment system 11 will now be described in more detail.
The threat assessment system 11 uses an activity prediction process to extrapolate series of numbers in several places to find the next value in the series. In this example, weighted linear extrapolation is used, although other methods may be used, such as polynomial extrapolation.
Weighted linear extrapolation involves fitting a straight line y=mx+c through supplied data, finding values for the parameters m and c, and then using these parameters to find a value for y corresponding to a value of x beyond the range of that data.
A so-called “best fit” line is the one which is as close to as many of the supplied data points as possible. The closeness at a single point x is given by the residual ri, namely:
ri=yi−(mxi+c) (1)
The overall quality of fit is given by the summed square of all the residuals, each weighted by the corresponding weighting factor:
The best fit line is found by minimizing S1 with respect to m and c.
The minimum may be found by differentiating S1 with respect to m and c.
where the summations are from 1 to n for w, x and y.
The minimum is found where the differentials are 0, therefore:
Σwx(y−(mx+c))=0 (5)
Σw(y−(mx+c))=0 (6)
Σwxy−mΣwx2−cΣwx=0 (7)
Σwy−mΣwx−cΣw=0 (8)
Equation (8) may be re-arranged to find c:
and, by substitution, m can be found:
Analogously,
ΣwxΣwxy−Σwx2Σwy=c((Σwx)2−ΣwΣwx2) (13)
c=−ΣwxΣwxy+Σwx2ΣwyΣwΣwx2−(Σwx)2 (14)
Given m and c from the formulae above, the series may be extrapolated to point n+1:
yn+1=mxn+1+c (15)
Referring to
The activity predictor 14 retrieves the observed threat data 9 from the observed threat database 10 (step S1) and sets about determining a time profile for each target, each time profile defined in terms of one of more time blocks and the number of successful threats expected in each time block (steps S2 to S13).
In this example, threats are generally divided into three categories, namely malicious codes (e.g. viruses, Trojans and worms), attacks (e.g. hacking and denial-of-service attacks) and non-electronic forms of attack (e.g. fire and terrorist attacks). Fewer categories may be defined, for example, by excluding non-electronic forms of attack. However, additional categories or sub-categories may be defined or added, for example as new forms of threat emerge. It will be appreciated that these threats can be assessed in any order and may even be evaluated simultaneously, for example, if a multi-core computer system 35 is used.
Equations (9), (10) and (15) and/or (13), (14) and (15) above are used to predict the number of viruses (or other forms of malicious code) using input data specified in Table I below:
The number of viruses seen by a target in a period, obst/pv, is obtained from the threat analyzer 6 running SNORT (or other intrusion detection program). The number of viruses contracted in the given period of time, contrpv, is specified, via input device 17, by the user. The number of new viruses worldwide in a period, newpv, is obtained from a virus (or other malicious software) information gathering organization, such as The Wildlist Organization (www.wildlist.org). The period, p, may be, for example, one week or four weeks. However, other periods, such n-weeks or n-months may be used, where n is positive integer.
The activity predictor 14 takes the number of viruses seen by a target for a given period of time, obst/pv and extrapolates the observed viruses to give the predicted number of viruses by target in the given period, predpv (step S2). The value for each target will be used to calculate the number of viruses expected to be contracted by the target.
The activity predictor 14 normalizes the predicted number of viruses by target in the given period, predpv, to give a predicted fraction of viruses attacking each target, frac predtv, by dividing the predicted number, predtv by the total number of new malicious codes which have been observed over the same period (step S3).
Steps S2 and S3 can be summarized as follows:
The activity predictor 14 divides the number of viruses contracted in each period, contrpv by the number of new viruses worldwide in that period, newpv, to give the fraction of new viruses contracted in each period, frac contrpv (step S4). The activity predictor 14 extrapolates this value to give the predicted fraction of new viruses that will be contracted, pred frac contrv (step S5).
Steps S4 and S5 can be summarized as follows:
The activity predictor 14 extrapolates the number of new viruses, newpv, to give a predicted number of new viruses (step S6), i.e.:
The activity predictor 14 multiplies the predicted fraction of new viruses that will be contracted, pred frac contrv, by the number of new viruses, newpv, to give the predicted number of new viruses contracted, pred contrv (step S7), i.e.:
pred contrv=pred frac contrv×pred newv
The activity predictor 14 multiplies the fraction of viruses for each target, frac predtv, by the predicted number of viruses contracted, pred contrv, to give the predicted number of viruses contracted by target, pred contrtv (step S8), namely:
pred contrtv=frac predtv×pred contrv
Finally, the activity predictor 14 copies the time and severity profile for predicted viruses contracted directly from obst/pv (step S9). For example, for each instance of a virus, the identity of the virus together with its time profile and severity profile is added to a table. This provides the predicted number of viruses contacted by target with time profile.
The activity predictor 14 uses equations (9), (10) and (15) and/or (13), (14) and (15) to carry out a similar process for predicting the number of hacking, denial-of-service attacks and other similar forms of attack, using input data specified in Table II below, using the following steps:
The activity predictor 14 extrapolates observed attacks, obst/pα, to give predicted number of attacks by target, predyα (step S10) and normalizes this to give predicted fraction of attacks attacking each target, frac predtα (step S11).
Steps S10 and S11 can be summarized as follows:
The activity predictor 14 extrapolates the number of successful attacks to give the predicted number of successful attacks, pred contrα (step S12), i.e.:
The activity predictor 14 multiplies the predicted number of successful attacks, pred contrα, by predicted fraction of attacks attacking each target, frac predtα, to give the predicted number of successful attacks by target (step S13), i.e.
pred contrtα=frac predtα=pred contrα
The activity predictor 14 copies time and severity profile for predicted successful attacks directly from obst/pv
For non-electronic threats, the user can provide the expected number of disabling events on the target with a given time profile (step S14).
The activity predictor 14 stores the expected number of malicious codes, attacks and disabling events in the predicted threat activity profile 13 (step S15).
Referring to
For each threat, the risk calculator 19 carries out the following steps, namely steps S16 to S19.
The risk calculator 19 determines downtime for a system category 33, i.e. a target, based on the expected damage level for the successful threat (step S16). In this example, this is done using the value of the attribute “SeverityScore” using a look-up table giving a downtime for each SeverityScore for each system category. The risk calculator 19 can adjust the downtime, for example by taking into account mitigating factors, such as whether the system can operate in a safe mode and whether back-up systems are available (step S17). The risk calculator 19 multiplies each adjusted downtime by the frequency of occurrence of the successful threat to obtain a value of the total downtime for the threat (step S18). The risk calculator 19 then adds the downtime to an accumulated downtime for the system category (step S19).
For each system 30, the risk calculator 19 adds up downtimes of dependencies of the system categories 33 on which the system 30 depends and, if appropriate, dependencies of the system categories on which those system dependencies depend (step S20). Circular dependencies among categories may be forbidden.
Referring to
For each operational process, the predicted loss calculator 24 adds up predicted downtimes of the system categories on which it depends to determine a duration for which the process is unavailable (step S21). The predicted loss calculator 24 multiplies the duration by a value of the process to quantify the loss 12A, 12B, 12C, 12D, 12E, . . . , 12m for the process (step S22). For example, the value of the process may be a monetary value (e.g. given in pounds sterling per hour or dollars per day) and the loss may be value at risk for the process.
Once losses 12A, 12B, 12C, 12D, 12E, . . . , 12m for each process have been determined, the predicted loss calculator 24 adds the losses 12A, 12B, 12C, 12D, 12E, . . . , 12m, for all the processes to obtain a loss to the organization (step S23).
The loss 12A, 12B, 12C, 12D, 12E, . . . , 12m, for each process and the loss 12SUM, to the organization can be stored in database 28 and/or exported. As explained earlier, some or all of the losses 12A, 12B, 12C, 12D, 12E, . . . , 12m, 12SUM, can be displayed, for example as a bar chart, on display device 29.
It will be appreciated that many modifications may be made to the embodiments hereinbefore described.
The present application is a continuation application of U.S. application Ser. No. 14/827,712, Filed Aug. 17, 2015, which is a continuation application of U.S. application Ser. No. 12/811,208, Filed Sep. 1, 2010, granted Apr. 28, 2015. All of the foregoing applications are hereby incorporated herein by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
6742128 | Joiner | May 2004 | B1 |
7409716 | Barnett et al. | Aug 2008 | B2 |
7818797 | Fan | Oct 2010 | B1 |
20020188870 | Gong et al. | Dec 2002 | A1 |
20030110396 | Lewis et al. | Jun 2003 | A1 |
20040064543 | Ashutosh et al. | Apr 2004 | A1 |
20040260947 | Brady et al. | Dec 2004 | A1 |
20050066195 | Jones | Mar 2005 | A1 |
20050278786 | Tippett et al. | Dec 2005 | A1 |
20050289649 | Mitomo et al. | Dec 2005 | A1 |
20060021050 | Cook et al. | Jan 2006 | A1 |
20060106797 | Srinivasa et al. | May 2006 | A1 |
20060218640 | Lotem | Sep 2006 | A1 |
20070011722 | Hoffman | Jan 2007 | A1 |
20070016955 | Goldberg et al. | Jan 2007 | A1 |
20070043656 | Lancaster | Feb 2007 | A1 |
20070067847 | Wiemer et al. | Mar 2007 | A1 |
20070113281 | Leach | May 2007 | A1 |
20070169194 | Church et al. | Jul 2007 | A1 |
20070186282 | Jenkins | Aug 2007 | A1 |
20070194097 | Jones et al. | Aug 2007 | A1 |
20070226796 | Gilbert et al. | Sep 2007 | A1 |
20070294766 | Mir | Dec 2007 | A1 |
20080008085 | Gerstel | Jan 2008 | A1 |
20080082380 | Stephenson | Apr 2008 | A1 |
20080115221 | Yun et al. | May 2008 | A1 |
20080229420 | Jeschke | Sep 2008 | A1 |
20080300837 | Buco et al. | Dec 2008 | A1 |
20090024627 | King | Jan 2009 | A1 |
20090030751 | Barve et al. | Jan 2009 | A1 |
20090204471 | Elenbaas et al. | Aug 2009 | A1 |
20100325731 | Evrard | Dec 2010 | A1 |
Number | Date | Country |
---|---|---|
1768045 | Mar 2007 | EP |
Entry |
---|
Apostolakis, George et al. “A Screening Methodology for the Identification and Ranking of Infrastructure Vulnerabilities Due to Terrorism” Risk Analysis, Plenum Press, New York, New York, US, vol. 25, No. 2, Apr. 1, 2005, pp. 361-376. |
International Search Report, mailed on Jun. 10, 2008, for PCT International Application No. PCT/EP2007/06450, filed on Dec. 31, 2007. |
Number | Date | Country | |
---|---|---|---|
Parent | 14827712 | Aug 2015 | US |
Child | 15017645 | US |