An access control system
Plaque It!
Sponsored by: Flash of Genius |
[0001] This application claims priority from Japanese patent application number 11-358178, filed Dec. 16, 1999, which is hereby incorporated herein by reference in its entirety.
[0002] The present invention relates to a method for evaluating policy descriptions for access control, and for enforcing a condition portion for implementing the policy descriptions.
[0003] Conventional, well known policy description means for accessing a data file are, for example, KeyNotes [BFIK99] (PolicyMaker [BRL96]), GACL [WL93] [WL98] and ASL [JSSB97] by ATT. These policy descriptions, which are rules used to determine whether to permit access, are based on a list of three elements (Subj, Obj, Op) that is called an access control list (ACL). This means that a subject (Subj) of an access is permitted to perform a specific operation (Op) for an access target (Obj). Therefore, in order to respond to all access requests, ACLs must be prepared for all possible combinations of the three.
[0004] To simplify the access control policy, the above policy description means describes pattern matching using a variable, and introduces the rule ACL(subj, Obj, Op) ← Cond(subj, Obj, Op) in order to write a condition formula for limiting a variable. That is, since it is difficult and requires too much effort to prepare, in response to an access request, ACLs that correspond to each combination of three elements, an abstract of the policy is created by using a variable, and upon the receipt of a relevant access request for the variable, access control is exercised in accordance with a corresponding ACL.
[0005] Two different methods are used when describing an operation performed for a control target on an ACL: a method by which only operations that are permitted are described, and a method by which both operations that are and operation that is not permitted are described. The first method is used with the Closed World Assumption. According to the Closed World Assumption, when the applicable interpretation is that no available ACL corresponds to a particular access request, the specified operation is not permitted. Therefore, when in an ACL only those operations that are permitted are described, and an access request does not match any entry in the ACL, the requested operation is rejected unconditionally. The second method is used for GACL, and in this case, the Default assumption is that an operation is permitted so long as a distinctly negative operation is not requested.
[0006] Although policy evaluation methods may differ in various respects, all of the conventional policy evaluation systems return an evaluation decision as a binary, Yes or No, result. In other words, a value of 1 or 0 is returned in reply to a question ?-ACL(subj, obj, op).
[0007] As is described above, according to the policy evaluation techniques used for conventional access control, a policy evaluation performed in response to an access request produces a simple binary result, either Yes or No. That is, in response to an access request, the conventional technique determines only whether access should or should not be permitted. Thus, the conventional technique is not sufficiently flexible, and it can not provide a conditional response, such as a Yes (a conditional Yes) that is dependent on the establishment of a specific state.
[0008] Therefore, generally it is not possible to provide complicated access control that is dependent on various conditions, such as: the issuing of an instruction to permit access, the embedding of an electronic watermark in data that are read or the writing of an access log when data encoding or format conversion is to be performed, or the issuing of an instruction to permit access when a time condition is the controlling factor.
[0009] To resolve the above technical shortcomings, upon the receipt of an access request, one object of the present invention, when exercising access control, is not only to determine, basically, whether access should or should not be permitted, but also to evaluate for acceptability an access request for which access permission is dependent on the establishment of a specific condition.
[0010] It is another object of the present invention to recurrently evaluate a specific condition if it is requested that a condition that is being evaluated to grant access permission under a condition should establish the specific condition.
[0011] To achieve the above objects, according to the present invention, an access control system comprises: a resource document in which a policy description is stored that is associated with data stored in a data file; policy evaluation means for receiving an external request for accessing the data file, for extracting, from the resource document, the policy description that is associated with target data for the access request, and for evaluating the policy description to determine whether or not the access request is to be permitted; enforcement function verification means for, when an existing condition is such that the policy description can not be evaluated using only the information included in the policy evaluation means, determining whether the condition can be evaluated or can be established; and enforcement means for evaluating or establishing the condition that, in accordance with the enforcement function verification means, is capable of being evaluated or established.
[0012] A plurality of the enforcement means can be provided in accordance with the evaluation or the establishment of the condition, which can not be evaluated using only the information included in the policy evaluation means. When the plurality of enforcement means are provided, the enforcement function verification means further determines whether a condition that one of the enforcement means has received from the policy evaluation means can be evaluated or established. This arrangement is preferable because the contents of a condition can be coped with flexibly. For the verification process to be performed by an enforcement means that can evaluate or establish a condition, a list can be employed in which a component of the enforcement means and a condition governing an operation that the pertinent component can enforce are stored in correlation with each other.
[0013] When access of a different data portion is required in order to evaluate or establish a condition that is determined by the enforcement function verification means can be evaluated or established, the enforcement means issues, to the policy evaluation means, a request to access the different data portion. Upon the receipt of the access request from the enforcement means, as well as upon the receipt of an external access request, the policy evaluation means evaluates a policy description that is associated with data to be accessed. This arrangement is superior in that an access request can be recurrently issued to evaluate or establish the condition. The data portion may be either a different portion of a document to be accessed or a predetermined portion of another document.
[0014] The enforcement means includes: writing/alteration target detection means for detecting a data portion in the data file that is a target for writing or alteration, and for issuing an access request to the policy evaluation means; and writing/alteration execution means for, when in response to the access request access permission is received from the policy evaluation means, writing or altering the data portion, wherein the writing/alteration execution means prepares a desired function by using a plug-in. This arrangement is preferable because a complicated process for evaluating or establishing a condition can be flexibly coped with by adding a corresponding function using a plug-in. When an access target is an XML document, the writing/alteration execution means can be an XSL processor, which is a standard tool for reading XML data, and a conversion rule, for generating new XML data. In this case, plug-in software can be added to carry out a complicated process.
[0015] An access control method, for receiving an external request for accessing a predetermined data file and for evaluating a policy description associated with the data that are to be accessed to determine whether or not the access request is to be permitted, comprises the steps of: receiving an access request and obtaining a policy description that is associated with the data that are to be accessed; evaluating a condition in the obtained policy description; determining, when a condition that can not be currently evaluated is present in the policy description, whether a process that satisfies the condition is capable of being enforced; performing the process that satisfies the condition when it is ascertained that the process is capable of being enforced; and employing, after the process that satisfies the condition has been performed, the evaluation results for all the conditions in the policy description to determine whether or not the access that is requested is to be permitted. The process that satisfies the condition is a process for evaluating or establishing the pertinent condition.
[0016] The step of evaluating the conditions in the policy description includes the steps of: comparing a parameter of the access request with a rule in the policy description, and detecting a matching rule; evaluating condition portions in the rule that is detected; and when the condition portions of the rule can not be currently evaluated, collecting the condition portions and moving to a step at which whether a process for satisfying the condition portions is capable of being performed is determined.
[0017] The access control method further comprises the step of: employing, when a plurality of rules that match the parameter of the access request are detected before the performance of the step of evaluating the condition portions of the rule in the policy description, a predetermined rule to determine a priority order for evaluating the rule. With this arrangement, an appropriate rule can be applied when there are a plurality of rules that match the condition. The priority order may be determined in accordance with a priority that is provided for a policy rule. When as rules that match the same condition there are a policy rule for inhibiting access and a policy rule for permitting access, the policy rule that inhibits access may be employed first in order to prevent the careless granting of access permission.
[0018] The step of determining whether the process that satisfies the condition in the policy description is capable of being performed includes the steps of: receiving the set of the conditions that have been prepared, at the step for evaluating the condition in the policy description, for the rule that can not be evaluated based only on information in the policy description, and extracting the conditions separately; determining whether a function has been prepared for performing a process that satisfies each of the conditions; and calling the function for performing the process that satisfies the condition when it is ascertained that the function has been prepared. To determine whether the function for performing the process that satisfies the condition has been prepared or not, the above described list can be employed wherein a component of the enforcement means and a condition that the pertinent component can enforce are stored in correlation with each other.
[0019] The step of performing the process that satisfies the condition in the policy description includes: employing the function that is called at the step of determining whether the process that satisfies the condition in the policy description can be enforced, and detecting, based on the condition of the policy description, a data portion in a predetermined data file for writing or for alteration; issuing a request for an access required for the writing or the alteration; and writing data to the data portion or changing the data portion upon the receipt of access permission in response to the request for the access that is required in order to perform the writing or the alteration. The data portion is another portion of a document to be accessed, or a predetermined portion of another document.
[0020] According to the present invention, a storage medium is provided on which a program is stored that can be read by input means of a computer, the program permitting the computer to perform: a process for receiving an access request to externally access a predetermined data file, and for obtaining a policy description that is associated with the data that are to be accessed; a process for evaluating a condition in the obtained policy description; a process for determining, when a condition that can not be currently evaluated is present in the policy description, whether a process that satisfies the condition is capable of being enforced; a process for performing the process that satisfies the condition when it is ascertained that the process that satisfies the condition is capable of being enforced; and a process for employing, after the process that satisfies the condition has been performed, the evaluation results for all the conditions in the policy description to determine whether or not the access that is requested is to be permitted. With this arrangement, a computer that has loaded the program can evaluate the granting of access permission under an applicable condition.
[0021] In order to perform the process that satisfies the condition in the policy description, the program permits the computer to perform: a process for employing the function that is called at the step of determining whether the process that satisfies the condition in the policy description can be enforced, and for detecting, based on the condition of the policy description, a data portion in a predetermined data file for writing or for alteration; a process for issuing a request for an access required for the writing or the alteration; and a process for writing data to the data portion or changing the data portion upon the receipt of access permission in response to the request for the access that is required in order to perform the writing or the alteration. With this arrangement, in order to satisfy an applicable condition, a computer that has loaded this program can recurrently issue a request to obtain access permission under the condition.
[0022] According to the present invention, a program transmission apparatus comprises: storage means for storing a program that permits a computer to perform a process for receiving an access request to externally access a predetermined data file, and for obtaining a policy description that is associated with the data that are to be accessed, a process for evaluating a condition in the obtained policy description, a process for determining, when a condition that can not be currently evaluated is present in the policy description, whether a process that satisfies the condition is capable of being enforced, a process for performing the process that satisfies the condition when it is ascertained that the process that satisfies the condition is capable of being enforced, and a process for employing, after the process that satisfies the condition has been performed, the evaluation results for all the conditions in the policy description to determine whether or not the access that is requested is to be permitted; and transmission means for reading the program from the storage means and transmitting the program. The thus arranged program transmission apparatus can provide the technique of the present invention as a program provision form for a client that does not have a storage medium, such as a CD-ROM.
[0023] In order to perform the process that satisfies the condition in the policy description, the program stored in the storage means permits the computer to perform: a process for employing the function that is called at the step of determining whether the process that satisfies the condition in the policy description can be enforced, and for detecting, based on the condition of the policy description, a data portion in a predetermined data file for writing or for alteration; a process for issuing a request for an access required for the writing or the alteration; and a process for writing data to the data portion or changing the data portion upon the receipt of access permission in response to the request for the access that is required in order to perform the writing or the alteration.
[0024] Furthermore, according to the present invention, an access control system comprises: means for storing a policy description including a condition whereby reading of information written by a single source is permitted when format conversion is possible; means for, upon the receipt of a predetermined access request that matches the policy description, determining whether a function to establish the condition for the format conversion is included, and for, when it is ascertained that the function is included, calling and executing the function to establish the condition; and means for, when the function to establish the condition is executed, permitting an access in response to the access request. With this arrangement, the access can be permitted with transcoding serving as a condition.
[0025] Further, according to the present invention, an access control system comprises: means for storing a policy description including a condition whereby reading of information is permitted when an electronic watermark is to be embedded in a document to be accessed; means for, upon the receipt of a predetermined access request that matches the policy description, determining whether a function for embedding an electronic watermark to establish the condition is included, and for, when it is ascertained that the function is included, calling and executing the function to establish the condition; and means for, when the function to establish the condition is executed, permitting an access in response to the access request. With this arrangement, the access can be permitted under a condition for embedding of an electronic watermark serving as one mode of transcoding. It should be noted that the same process can be performed for the encoding of a document as another mode for transcoding.
[0026] Furthermore, according to the present invention, an access control system comprises: means for storing a policy description including a condition whereby accessing of a target document is permitted when an access history is to be written to the target document; means for, upon the receipt of a predetermined access request that matches the policy description, determining whether a function for writing the access history to the target document to establish the condition is included, and for, when it is ascertained that the function is included, calling and executing the function to establish the condition; and means for, when the function to establish the condition is executed, permitting an access in response to the access request. With this arrangement, the access can be permitted under a condition where an access history is written to the document.
[0027] The function for writing the access history to the document further comprises: means for recurrently issuing requests to access a document to write the access history. With this arrangement, while the recurrent accesses of the document to write the access history can be an evaluation target for access permission, the security can be improved. The target for the writing of the access history can be the document to be accessed, or a part of another document.
[0028] In addition, according to the present invention, an access control system comprises: means for storing a policy description including a condition whereby accessing of a target document is permitted when a time stamp of an access is to be written as an access history to the target document; means for, upon the receipt of a predetermined access request that matches the policy description, determining whether a function for writing the time stamp as the access history to the target document to establish the condition is included, and for, when it is ascertained that the function is included, calling and executing the function to establish the condition; and means for, when the function to establish the condition is executed, permitting an access in response to the access request. With this arrangement, the access permission is strictly granted under a time condition.
[0029] According to the present invention, an access control system comprises: a resource document in which a policy description is stored that is associated with data stored in a data file; policy evaluation means for receiving an external request for accessing the data file, for extracting, from the resource document, the policy description that is associated with target data for the access request, and for evaluating the policy description to determine whether or not the access request is to be permitted; and enforcement function verification means for performing another process to determine whether the condition can be evaluated or can be established. Operations required to evaluate or establish a condition that can not be evaluated using only the information owned by the policy evaluation means are the data form conversion of a data file to be accessed, and the operation for maintaining the access history of the data file to be accessed. That is, only when these operations can be executed, can an access request be granted for which this condition is the policy description.
[0030] The subject matter which is regarded as the invention is particularly pointed out and distinctly claimed in the claims at the conclusion of the specification. The foregoing and other objects, features, and advantages of the invention are apparent from the following detailed description taken in conjunction with the accompanying drawings in which:
[0031]
[0032]
[0033]
[0034]
[0035]
[0036]
[0037]
[0038]
[0039]
[0040]
[0041]
[0042]
[0043]
[0044]
[0045]
[0046]
[0047]
[0048]
[0049]
[0050]
[0051]
[0052]
[0053]
[0054]
[0055] The preferred embodiment of the present invention will now be described in detail while referring to the accompanying drawings.
[0056] As an overview of the present invention, the results of a policy evaluation performed in the access control are represented not by a conventional binary decision of Yes or No, but by a multi-valued decision using Boolean algebra, and an intermediate value is interpreted as, “Yes, if this condition is established.” Thus, a frame is provided that can generally represent the policy evaluation process and the enforcement of a condition to carry out the policy. For this, the policy description for access control is extended into the If-then rule, and the partial evaluation method is employed to evaluate a logical language. The If portion is used for checking the condition and for an actual instruction. Therefore, the policy description can be simplified and rendered declarative, and the matching of the overall policy can be determined within the frame of the logical language.
[0057]
[0058] A user who desires to access data, or a document stored in the data management server
[0059] Then, the user issues an access request for desired data to the access control sub-system
[0060] When access permission is granted by the access control sub-system
[0061]
[0062]
[0063]
[0064] The processing sequence in
[0065] Upon receiving the access request
[0066] When a condition included in the policy description
[0067] Available at the enforcement function verification module
[0068] When an appropriate enforcement module
[0069] However, when, as a result of an evaluation, the enforcement module
[0070] In the processing performed by the enforcement module
[0071] Further, when in order to establish an external condition the enforcement module
[0072] The functions of the individual modules will now be described in detail.
[0073]
[0074] In
[0075] Then, a rule that matches all the parameters (Subject, Object and Operation) in the access request is searched for in the access control policy description that is stored in the resource document
[0076] Here, “matching” means that the values of Subject, Object and Operation are matched. For example, when the Subject in the access evaluation request parameter is “amano,” the rule whereby user ID “amano” and group name TRL, which includes “amano,” are described is extracted from the access control policy rules.
[0077] During the search of the access control policy rule, environment data that are stored in the resource document
[0078] In the rule examination process, when a plurality of policy rules are matched at step
[0079] The condition portions of the policy rules that are processed at step
[0080] The results obtained at step
[0081] When there are conditions that can not be evaluated, an external condition is prepared under the terms of which access permitted determinations can be made for the conditions that could not be evaluated, and program control is shifted to the enforcement function verification module
[0082] When program control is shifted to the enforcement function verification module
[0083]
[0084] While referring to
[0085] Multiple conditions that are input as external conditions are extracted one by one (step
[0086] If an entry that satisfies the condition is not included in even one of the conditions that constitute the external condition, the access inhibited data string
[0087] If an entry that satisfies the condition is detected for all the conditions that constitute the external condition, i.e., if all the parameters for the external condition are examined, program control shifts to the processing performed by the enforcement module
[0088]
[0089] The writing/change target detection means
[0090] In the processing handled by the enforcement module
[0091]
[0092] When access is inhibited by the policy evaluation module
[0093] When access is permitted by the policy evaluation module
[0094] When all the conversions included in the enforcement instruction
[0095] A specific example application of the embodiment will now be described.
[0096] An explanation will be given for an example wherein the embodiment is employed for the transcoding of data. The transcoding of data is a process during which the format of information written by a single source is converted in accordance with the security level of an access request source and the capabilities of a communication channel and a display device, and the obtained information is transmitted. In this example, a policy is described whereby when a reading request is issued to prepare written information based on XML (names representing the definitions of individual fields are written using XML tags), reading is permitted using an HTML form that is not as re-usable. The policy rule is written, for example, as follows.
[0097] acl(*, role(employee), doc(http://trl.ibm.com/xmlform/X), read(Form))≦transcode (X, xml, Form).
[0098] Assume that an access request is issued to obtain a travel expense application form via HTML. This access request is written as follows.
[0099] ?-acl(amano, role(employee)
[0100] doc(http://trl.ibm.com/xmlform/travelExpenseAccount.xml), read(html)).
[0101] In this case, role(employee) is matched as Subject, both in the policy description and the access request, and Object in the access request is
[0102] doc(http://trl.ibm.com/xmlform/travelExpenseAccount.xml) and is included in Object in the policy description, doc(http://trl.ibm.com/xmlform/X). However, since Condition ‘transcode(X, xml, Form)’ is provided for Operation ‘read(html)’, the evaluation obtained by the policy evaluation module
[0103] transcode(travelExpenseAccount.xml, xml, html)
[0104] Therefore, if the access control system
[0105] An example wherein the above embodiment is employed to insert an electronic watermark into a document will now be described. This process can be a modification of the transcoding process. Specifically, a condition is prepared whereby access is permitted if the ID of a user who has submitted an access request is embedded in an image/X as a policy description. The rule that includes this condition is written as follows.
[0106] acl(user(ID), role(subscriber),
[0107] doc(http://trl.ibm.com/image/X), read)≦embed(X, ID).
[0108] When a detailed enforcement procedure, such as a complicated electronic watermarking process, can not be written directly, the XSL processor
[0109] An explanation will now be given for an example for which the embodiment is used for the writing of a data operation in a log file. For the access control system it is important that auditability be ensured. For this, it is convenient to provide a configuration that maintains a log (history) for an operation for which specific data are used. In this example, a case wherein a log is required is described as a policy, and this policy is enforced. The policy description is as follows.
[0110] acl(user(ID), role(issuer),
[0111] doc(http://trl.ibm.com/xmlform/X), write(*))≦status(log(ID, issuer, X, write, T)).
[0112] Assume that the following access request is issued for this policy description.
[0113] ?-acl(amano, role(issuer)
[0114] doc(http://trl.ibm.com/xmlform/travelExpenseAccount.xml#linp utfield), write(“cost=$100”)).
[0115] In this case, role(issuer) is matched as Subject both in the policy description and in the access request, and Object in the access request is doc(http://trl.ibm.com/xmlform/travelExpenseAccount.xml#linp utfield) and is included in Object in the policy description, doc(http://trl.ibm.com/xmlform/X). However, since Condition ‘status(log(ID, issuer, X, write, T)’ is provided for Operation “write(“cost=$100”),” it is assumed that the following rules are provided for “status.”
[0116] status(log(Subj, Role, Obj, Op, T))≦log(Subj, Role, Op, T).
[0117] status(log(Subj, Role, Obj, Op, T))≦makelog(Subj, Role, Op, T).
[0118] Since the status data “log” is not yet written, the first rule of “status” fails. The second rule is employed, and access is permitted under a condition makelog(..).
[0119] Upon the receipt of the “makelog” request, the enforcement module
[0120] ?-acl (sys1, role (system)
[0121] doc(http://trl.ibm.com/xmlform/travelExpenseAccount.xml#log) , write(log(amano, issuer,
[0122] travelExpenseAccount.xml#issuerField, write(“cost=$100”))).
[0123] The access permission or inhibition provided in response to the access request
[0124] The actual process for writing a log is described as a conversion rule between XML documents, as well as in transcoding. For example, the description (written in accordance with instructions for writing the XSL conversion rule) shown in
[0125] Following this, an explanation will be given for an example wherein the embodiment controls access by applying the constraints imposed by a time condition. When bidding or an auction takes place on the Internet, the granting of access permission in accordance with the condition, “This information may be read after a specific date at a specific time,” must be strictly controlled. An explanation will be given to describe a policy that establishes the time at which access is permitted. This policy is called access permission under a time condition (Temporal Authorization). The policy description for such access permission is conventionally written as follows.
[0126] acl(AnyUserID, role(employee),
[0127] doc(http://announce/bonus.xml), read):-get#time(T), T>“1999/06/03.”
[0128] This means that “a user filling the ‘employee’ role has the ‘read’ right for ‘http://announce/bonus.xml’ after Jun. 3rd, 1999.” In this case, the system term “get#time” obtains the current time, and if the current time is later than Jun. 3rd, 1999, the condition is established and the ‘employee’ can be granted the ‘read’ right for the ‘bonus.xml’.
[0129] When access permission is controlled under this condition, however, the security of the access control system depends on the value held by the system clock of the server. For example, if a system manager should intentionally change the system clock of the server that controls the access, the “employee” would be able to “read” the “bonus.xml” at a time whereat he or she does not have the “read” right. Even when “read” accesses are maintained in a log, if the value held by the system clock is used to determine the access time, an access that is illegal relative to the time-limited access permission control can not be detected. Further, it tends to be assumed that access control at the OS level is performed in accordance with the system clock of the server. However, for granting the above permission, the assumption of the access under the time condition at the OS level is not required.
[0130] In the example, whether or not the above embodiment is used for access permission under a time condition, the policy description for access permission is written as follows.
[0131] acl(user(ID), role(employee),
[0132] doc(http://announce/bonus.xml), read) :- status(timestamp(S, T)), verify#signature(S), T>“1999/06/03.”
[0133] In accordance with the policy description, the access control system
[0134] First, the policy evaluation module
[0135] status(timestamp(S, T)) :- timestamp(S, T).
[0136] status(timestamp(S, T)) :-get#timestamp(S, T), makelog(timestamp(S, T)).
[0137] Since the time stamp data “timestamp(S, T)” have not yet been written to the resource document
[0138] The enforcement function verification module
[0139] The enforcement module
[0140] Process for get#timestamp(S, T)
[0141] The time stamp processor performs the process for get#timestamp. The following enforcement program is written to the time stamp processor.
[0142] get#timestamp(S, T) :- get#trust(timestamp, C), get#timestamp(C, T, S).
[0143] get#trust/2 is a term for extracting the “trust” description from the data file
[0144] trust(timestamp, “http://www.surety.com”).
[0145] This means that for the document “surety” is trusted as the “timestamp.” As a result of the search of the document
[0146] Process for makelog(timestamp(S, T))
[0147] For “makelog” the process is performed by the log processor. The log processor issues the access request
[0148] acl(sysl, role(system), doc(http://announce/bonus.xml#log), write)
[0149] Whether the log can be written is determined by again evaluating the policy description. When the access control system
[0150] Process for verify#signature(S)
[0151] The process for “verify#signature” is performed by a signature processor. The signature value of the time stamp is examined, and if it is Valid, “true” (correct signature) is returned, while if it is Invalid, “false” (incorrect signature) is returned. It should be noted that the signature value of Surety is Valid.
[0152] Process for T>“1999/06/03”
[0153] The formula expression is performed by the form processor. T is the value of the time held by the time stamp, i.e., 1999/06/04. Since T>“1999/06/03” is established, “true” (correct form) is returned.
[0154] Through the above processing, the enforcement instructions
[0155] doc(http://announce/bonus.xml), read), which are requested by the policy evaluation module
[0156] An explanation will now be given for the resolving, under a time condition, of an access permission problem that was first described. When in the above example access is permitted, the value of the time stamp is always added to the log area of the original document. The value of the time stamp indicates that the data was generated at a predetermined time, and the presence of the time stamp value in the log area indicates that the current time is always later than the time stamp time. Therefore, if the system manager changes the system clock value of the policy evaluation module
[0157] As is described above, according to the access control provided by the present invention, upon the receipt of an access request, not only can whether or not an access should be permitted be determined, but also access permission under a condition whereby an access is permitted if a specific condition is established can also be evaluated. Further, when it is requested that a condition that is to be evaluated for access permission under a condition establish a different condition, the different condition can also be currently evaluated.
[0158] The present invention can be included in an article of manufacture (e.g., one or more computer program products) having, for instance, computer usable media. The media has embodied therein, for instance, computer readable program code means for providing and facilitating the capabilities of the present invention. The article of manufacture can be included as a part of a computer system or sold separately.
[0159] Additionally, at least one program storage device readable by a machine, tangibly embodying at least one program of instructions executable by the machine to perform the capabilities of the present invention can be provided.
[0160] The flow diagrams depicted herein are just examples. There may be many variations to these diagrams or the steps (or operations) described therein without departing from the spirit of the invention. For instance, the steps may be performed in a differing order, or steps may be added, deleted or modified. All of these variations are considered a part of the claimed invention.
[0161] Although preferred embodiments have been depicted and described in detail herein, it will be apparent to those skilled in the relevant art that various modifications, additions, substitutions and the like can be made without departing from the spirit of the invention and these are therefore considered to be within the scope of the invention as defined in the following claims.