1. Field of the Invention
The present invention relates to security systems for data and, more particularly, to security systems that protect data in an inter/intra enterprise environment.
2. Description of Related Art
The Internet is the fastest growing telecommunications medium in history. This growth and the easy access it affords have significantly enhanced the opportunity to use advanced information technology for both the public and private sectors. It provides unprecedented opportunities for interaction and data sharing among businesses and individuals. However, the advantages provided by the Internet come with a significantly greater element of risk to the confidentiality and integrity of information. The Internet is an open, public and international network of interconnected computers and electronic devices. Without proper security means, an unauthorized person or machine may intercept information traveling across the Internet and even gain access to proprietary information stored in computers that interconnect to the Internet.
There are many efforts in progress aimed at protecting proprietary information traveling across the Internet and controlling access to computers carrying the proprietary information. Cryptography allows people to carry over the confidence found in the physical world to the electronic world, thus allowing people to do business electronically without worries of deceit and deception. Every day millions of people interact electronically, whether it is through e-mail, e-commerce (business conducted over the Internet), ATM machines, or cellular phones. The perpetual increase of information transmitted electronically has led to an increased reliance on cryptography.
One of the ongoing efforts in protecting the proprietary information traveling across the Internet is to use one or more cryptographic techniques to secure a private communication session between two communicating computers on the Internet. The cryptographic techniques provide a way to transmit information across an unsecure communication channel without disclosing the contents of the information to anyone eavesdropping on the communication channel. Using an encryption process in a cryptographic technique, one party can protect the contents of the data in transit from access by an unauthorized third party, yet the intended party can read the encrypted data after using a corresponding decryption process.
A firewall is another security measure that protects the resources of a private network from users of other networks. However, it has been reported that many unauthorized accesses to proprietary information occur from the inside, as opposed to from the outside. An example of someone gaining unauthorized access from the inside is when restricted or proprietary information is accessed by someone within an organization who is not supposed to do so. Due to the open nature of networks, contractual information, customer data, executive communications, product specifications, and a host of other confidential and proprietary intellectual property remain available and vulnerable to improper access and usage by unauthorized users within or outside a supposedly protected perimeter.
Many businesses and organizations have been looking for effective ways to protect their proprietary information. Typically, businesses and organizations have deployed firewalls, Virtual Private Networks (VPNs), and Intrusion Detection Systems (IDS) to provide protection. Unfortunately, these various security means have been proven insufficient to reliably protect proprietary information residing on private networks. For example, depending on passwords to access sensitive documents from within often causes security breaches when the password of a few characters long is leaked or detected. Consequently, various cryptographic means are deployed to provide restricted access to electronic data in security systems.
As previously noted, security systems can operate to restrict access to data (e.g., files). Typically, the data is provided in an electronic file and stored in an encrypted fashion so that only authorized users can gain access to such files. The security system operates in accordance with security system information. The security system information can, for example, pertain to adding or dropping a user from the security system. Conventionally, upon receiving a request to add or drop a user, a system administrator would communicate with the security system to implement the requested changes, assuming the system administrator approved the changes. Unfortunately, however, a user of the security system may request to add or drop a user to the security system while the administrator is busy, away from her office, or otherwise unavailable. In such cases, the requested change to add or drop the user to the security system cannot be approved and, as a result, cannot be implemented. Consequently, the user seeking the change to the security system information is often significantly delayed and frustrated while awaiting approval of a system administrator.
Therefore, there is a need to provide more effective ways for security systems to permit changes to be approved.
The invention pertains to a system and method for providing a file security system with an approval process to implement security changes. The approval process can be substantially automated as well as configurable and/or flexible. The approval process can make use of a set of approvers that can approve or deny a security change. Different security changes can require the approval of different approvers. The approvers can also be arranged into groups of approvers, and such groups can make use of a hierarchical arrangement.
The invention can be implemented in numerous ways, including as a method, system, apparatus, and computer readable medium. Several embodiments of the invention are discussed below.
As a method for approving a security change for a file security system that secures electronic files, one embodiment of the invention includes at least the acts of: receiving a requested security change from a requestor; identifying a plurality of approvers to approve or disapprove of the requested security change; notifying the approvers of an approval request for the requested security change; determining whether the requested security change is approved based on responses from the approvers to the approval request; and performing the requested security change when it is determined that the requested security change has been approved.
As a file security system that restricts access to secured electronic documents, one embodiment of the invention includes at least: an access server that restricts access to the secured electronic documents; and an approval manager operatively connected to the access server. The approval manager operates a security change approval process to determine whether a requested security change is approved.
As a computer readable medium including at least computer program code for approving a security change for a file security system that secures electronic files, one embodiment of the invention includes at least: computer program code for notifying a plurality of approvers of an approval request for the requested security change; computer program code for determining whether the requested security change is approved based on responses from the approvers to the approval request; and computer program code for performing the requested security change when it is determined that the requested security change has been approved.
Other objects, features, and advantages of the present invention will become apparent upon examining the following detailed description of an embodiment thereof, taken in conjunction with the attached drawings.
The present invention will be readily understood by the following detailed description in conjunction with the accompanying drawings, wherein like reference numerals designate like structural elements, and in which:
The invention pertains to a system and method for providing a file security system with an approval process to implement security changes. The approval process can be substantially automated as well as configurable and/or flexible. The approval process can make use of a set of approvers that can approve or deny a security change. Different security changes can require the approval of different approvers. The approvers can also be arranged into groups of approvers, and such groups can make use of a hierarchical arrangement.
A file security system (or document security system) serves to limit access to files (documents) to authorized users. Often, an organization, such as a company, would use a file security system to limit access to its files (documents). For example, users of a group might be able to access files (documents) pertaining to the group, whereas other users not within the group would not be able to access such files (documents). Such access, when permitted, would allow a user of the group to retrieve a copy of the file (document) via a data network.
Secured files are files that require one or more keys, passwords, access privileges, etc. to gain access to their content. According to one aspect of the invention, the security is provided through encryption and access rules. The files, for example, can pertain to documents, multimedia files, data, executable code, images and text. In general, a secured file can only be accessed by authenticated users with appropriate access rights or privileges. In one embodiment, each secured file is provided with a header portion and a data portion, where the header portion contains or points to security information. The security information is used to determine whether access to associated data portions of secured files is permitted.
In the following description, numerous specific details are set forth in order to provide a thorough understanding of the invention. However, it will become obvious to those skilled in the art that the invention may be practiced without these specific details. The description and representation herein are the common meanings used by those experienced or skilled in the art to most effectively convey the substance of their work to others skilled in the art. In other instances, well-known methods, procedures, components, and circuitry have not been described in detail to avoid unnecessarily obscuring aspects of the present invention.
Reference herein to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment can be included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment, nor are separate or alternative embodiments mutually exclusive of other embodiments. Further, the order of blocks in process flowcharts or diagrams representing one or more embodiments of the invention do not inherently indicate any particular order nor imply any limitations to the invention.
Embodiments of the present invention are discussed herein with reference to
The computer system 100 can further include an external access server 112. The external access server 112 can couple to the file security system 102 so as to enable remote users to have limited access to electronic files secured by the file security system. The external access server 112 can also couple to a network 114. A plurality of external users, namely, user E-A 116 and user E-B 118, can communicate with the external access server 112 via the network 114.
By interacting with the access server 202, authorized users are able to gain access to electronic files that are secured by the file security system 200. The approval manager 208 serves to operate an approval process that is used to determine whether a requested security change to be made is approved. The type of requested security change can vary, but examples include adding, modifying or deleting a user with respect to the file security system 200. Other examples of requested security changes include alterations to access restrictions on secured files (e.g., who has access to a file or when/how the file is retained). When the approval manager 208 determines that the requested security change is approved, then the access server 202 can implement the requested security change. On the other hand, when the approval manager 208 determines that the requested security change has not been approved, then the access server 202 does not perform the requested security change. The approval process that is managed by the approval manager 208 is largely automated, though one or more approvers are utilized as part of the approval process. In other words, the approval manager 208 or the approval process, can also be referred to as a security approval proxy. The approval process is advantageously not dependent upon one or a few security administrators to enable a file security system to invoke requested security changes. Instead, certain users of the file security system can be deemed “approvers” and participate in the approval process in a substantially automated manner. The specifics of the approval process can vary with implementation.
The security proxy process 300 begins with a decision 302 that determines whether a security change request has been received. When the decision 302 determines that a security change request has not yet been received, the security proxy process 300 awaits such a request. The security proxy process 300 continues once a security change request is received. In other words, the security proxy process 300 can be invoked when a security change request is received.
In any case, after a security change request has been received, an approval group for the requested security change is identified 304. The approval group includes one or more approvers for the file security system. Typically, the approvers are users of the file security systems that are chosen to participate in the approval process. The approval group is then notified 306 of an approval request for the requested security change. The approval request asks the users within the approval group to either approve or deny the requested security change. After the approval group is notified 306 of the approval request, a decision 308 determines whether at least one response to the approval request has been received from the approval group. When the decision 308 determines that a response has not yet been received, the security proxy process 300 awaits such responses. In one embodiment, the decision 308 would cause the security proxy process 300 to await a response from at least a predetermined number of the members of the approval group. In an alternative embodiment, the decision 308 would cause the security proxy process 300 to wait for a response for a limited amount of time, thus denying the requested security change if a suitable number of responses are not received in a timely manner.
After the decision 308 determines that a responses has been received (or a limited amount of time has been exceeded), then the security proxy process 300 determines 310 whether the requested security change is approved based on the responses. Next, a decision 312 determines whether the requested security change has been approved. When the decision 312 determines that the requested security change has been approved by the approval group, then the requested security change can be performed 314. Here, the requested security change is implemented as requested by the requestor. On the other hand, when the decision 312 determines that that the requested security change was not approved by the approval group, then the requested security change is not performed. Hence, following the decision 312 when the requested security change is not performed (as well as following the block 314 when the requested security change has been performed), the security proxy process 300 is complete and ends.
The security change approval process 400 begins with a decision 402 that determines whether a security change request has been received. When the decision 402 determines that a security change request has not yet been received, the security change approval process 400 awaits such a request. Once the decision 402 determines that a security change request has been received, the security change approval process 400 continues. In other words, the security change approval process 400 can be invoked once a security change request has been received. After a security change request has been received, a decision 404 determines whether the requestor is authorized to make the security change that is being requested.
When the decision 404 determines that the requestor is authorized to make the security change, then the requested security change can be implemented 406. In this case, the requested security change does not require a security approval proxy. As a result, the requestor himself can cause the requested security change to be implemented 406. For example, in one implementation, the requested security change that does not require a security approval proxy is a change that is minor or low-level. Following the block 406, the requestor is notified 408 that the security change has been made. Following the block 408 the security change approval process 400 is complete and ends with the requested security change having been made.
On the other hand, when the decision 404 determines that the requestor is not authorized to make the security change, then a decision 410 determines whether the requester desires to seek approval for the security change. Here, it is assumed that the security change approval process 400 has, for this requested security change, one or more approvers that can be summoned to approve or deny the requested security change. The requester can then be queried as to whether they desire to seek approval for the security change, knowing that they themselves are not authorized to make the change. When the decision 410 determines that the requestor does not want to seek approval for the security change, then the security change approval process 400 is complete and ends.
Alternatively, when the decision 410 determines that the requestor does desire to seek approval for the requested security change, then an approval manager is invoked 412 to seek approval. As an example, the approval manager can be implemented by the approval manager 208 illustrated in
Next, a decision 414 determines whether an approval decision has been made. Here, the approval decision would be made by the approval manager. When the decision 414 determines that the approval manager has not yet made an approval decision, the security change approval process 400 can wait for an approval decision. Once the decision 414 determines that an approval decision has been made, a decision 416 determines whether the approval has been granted. When the decision 416 determines that the approval has been granted, then the security change approval process 400 proceeds to the blocks 406 and 408 where the requested security change can be implemented and the requestor notified. On the other hand, when the decision 416 determines that approval has not been granted (approval denied), then the requestor is notified 418 that the requested security change has been denied. In this case, the requested security change is not implemented. Following the block 418, the security change approval process 400 is complete and ends.
Fundamentally, approval of security changes can be determined by approvers. These approvers can be arranged into approver sets and the approver sets can be arranged into approver groups. Further, not all of the approvers within a set need to unanimously agree as to the approval decision; instead, only a quorum of the members of an approver set need to agree. Additionally, the nature of the processing of the one or more approvers, approver sets or approver groups can be sequential or in parallel. Moreover, approver groups can be arranged in a hierarchy, such that multiple groups from different levels can be required in order to make an approval decision on whether certain security changes can be made.
The approval set process 500 initially obtains 502 an approver set. The approver set includes one or more members, referred to as “approvers.” Next, a decision 504 determines whether sequential notifications are to be utilized. In this embodiment, the notification to approvers can be achieved sequentially or in parallel, depending on implementation or configuration.
When the decision 504 determines that sequential notifications are not to be utilized, then the approval set process 500 performs parallel notifications. Hence, approval requests are sent 506 to all approvers of the approver set. In one implementation, the approval requests are electronic mail messages that are transmitted to the approvers.
Next, a decision 508 determines whether one or more responses have been received to the approval requests. When the decision 508 determines that no responses have been received, then a decision 510 determines whether a time-out has occurred. When the decision 510 determines that a time-out has occurred (e.g., meaning that adequate numbers of responses have not been received in a timely manner), then approval by the approver set is deemed denied 512. Alternatively, when the decision 510 determines that a time-out has not occurred, then the approval set process 500 returns to repeat the decision 508.
Once the decision 508 determines that one or more responses to the approval request have been received, a decision 514 determines whether approval by a quorum of approvers is no longer possible. For example, if an approver set has five approvers and requires a quorum of three, then if responses from three approvers have already denied approval, then approval by a quorum of approvers is no longer possible. When the decision 514 determines that approval by a quorum of the approvers is no longer possible, then approval by the approver set is denied 512. On the other hand, when the decision 514 determines that approval by a quorum of the approvers is still possible, then a decision 516 determines whether approval by a quorum has been achieved. When the decision 516 determines that approval by a quorum has not been achieved, the approval set process 500 returns to repeat the decision 508 and subsequent blocks so that additional responses can be similarly processed. Alternatively, when the decision 516 determines that approval by a quorum has been achieved, then approval by the approval set is deemed granted 518.
On the other hand, when the decision 504 determines that sequential notifications are to be utilized, then the notifications are sent to the approvers in a sequential fashion. In this regard, a first approver is selected 520 from the approver set. Then, an approval request is sent 522 to the selected approver. Then, a decision 524 determines whether a response has been received from the selected approver. When the decision 524 determines that a response has not yet been received, the approval set process 500 can await such a response (or can time-out or potentially skip the selected approver).
Once the decision 524 determines that a response has been received, a decision 526 determines whether approval by a quorum of the approvers of the approver set is no longer possible. When the decision 526 determines that approval by a quorum of the approvers is no longer possible, then the approval by the approver set is deemed denied 512. Alternatively, when the decision 526 determines that approval by a quorum of the approvers is still possible, then a decision 528 determines whether approval by a quorum of the approvers of the approver set has been achieved. When the decision 528 determines that approval by a quorum has been achieved, approval by the approver set is deemed granted 518.
On the other hand, when the decision 528 determines that approval by a quorum of the approvers of the approver set has not been achieved, a decision 530 determines whether there are more approvers of the approver set to be consulted. When the decision 530 determines that there are more approvers of the approver set to be consulted, the approval set process 500 returns to repeat the decision 520 where a next approver is selected and then similarly processed. Once the decision 530 determines that there are no more approvers to be processed, then the approval by the approver set is deemed denied 512 because approval of a quorum of approvers was not achieved.
The approval of a requested security change can utilize multiple approval sets in order to make an approval decision. Typically, though not necessarily, each set of an approval group would need to approve the requested security change. An approval group can include one or more approval sets.
The approval group process 600 initially identifies 602 one or more applicable approver sets. Here, the applicable approver sets are one or more approver sets that are associated with an approval group being processed. Next, a first approver set is selected 604. Once the approver set is selected, approval set processing is performed 606 for the selected approver set. In one embodiment, the approval set processing being performed 606 is the approval set process 500 discussed above with respect to
Next, a decision 608 determines whether approval has been granted by the approver set. When the decision 608 determines that approval has not been granted by the approver set, then the approval decision is set 610 to “denied.” On the other hand, when the decision 608 determines that approval has been granted by the approver set, then a decision 612 determines whether there are additional approver sets for the given approval group to be processed. When the decision 612 determines that there are more approver sets to be processed, then a next approver set is selected 604 and similarly processed. Once the decision 612 determines that there are no more approver sets to be processed, the approval decision is set 614 to “granted.”
If the approval decision processing makes use of multiple approval groups, these approval groups can have a hierarchy. The approval groups can be associated with the level within the file security system that the requested security change pertains. For example, a minor or low-level security change may only need approval by a single approval group, but a significant or high-level security change may require approval from a series of approval groups arranged in a hierarchy.
The approval hierarchy process 700 initially identifies 702 a user group associated with the requested security change. For example, if a requester desired to add a user to an “engineering group,” the requested security change would be associated with the user group referred to as “engineering group.” A decision 704 then determines whether there are approvers defined for the group. The approvers might be one or more or one or more sets of approvers. In any case, when the decision 704 determines that there are approvers defined for the group, then an approval group process is performed 706 for the group. In one implementation, the approval group process can be associated with the approval group process 600 illustrated in
Alternatively, when the decision 708 determines that the approval group has approved the requested security change, then a decision 712 determines whether multi-level approvals are required. Here, the decision 712 determines whether there is an additional level of approval that is still required in order to make the approval decision. When the decision 712 determines that there is another approval level to be processed, then the approval hierarchy process 700 performs a decision 716 that determines whether there is a parent group to the group being processed. Similarly, the decision 716 is performed following the decision 704 when the present group does not have any approvers defined for that group.
When the decision 716 determines that there is a parent group, then the parent group is selected 718. Following the block 718, the approval hierarchy process 700 returns to repeat the decision 704 and subsequent operations so that the newly selected group can be similarly processed.
Alternatively, when the decision 716 determines that there is not a parent group, then a decision 720 determines whether at least one group has been processed. When the decision 720 determines that at least one group has not been processed, then a decision 722 determines whether a default group is present. When the decision 722 determines that there is a default group, then the default group is selected 724. Following the block 724, the approval hierarchy process 700 returns to repeat the decision 704 and subsequent operations so that the newly selected group can be similarly processed.
On the other hand, when the decision 722 determines that there is no default group, then the approval decision is set 726 to “denied” as in this condition, the approval hierarchy process 700 would have an error given that no approver group has been able to be processed.
In addition, when the decision 712 determines that there are no more additional approval levels required to be processed, then an approval decision is set 714 to “granted.” Here, the one or more groups associated with the requested security change to be made have each approved the requested security change and thus the approval decision is set 714 to “granted.” Following the decision 720 when it is determined that least one group has been processed, the approval decision is also set 714 to “granted.”
As noted above, approvers can receive notification of requests to approve or deny requested security changes. These notifications can be delivered as electronic mail messages. In one embodiment, the electronic mail messages can contain a hyperlink or instructions to redirect the approver to a web server. For example, the web server can be a secure web server and require the approver to first log in, and then respond to a prompt to approve or deny a requested security change. In another embodiment, the approvers can reply to electronic mail messages (which used to provide the notifications) so as to provide their decision on whether the requested security change should be approved or denied. The notification can contain information on the specific security being requested, and the response might append thereto an approval and/or denial indication. In one embodiment, the electronic mail notifications and responses can use a markup language to facilitate presentation of appropriate information to approvers as well as to facilitate parsing of the responses by a computer. For example, the markup language can be eXtensible Markup Language (XML). Additionally, a reply message might also include a digital signature of the associated approver so as to validate that the reply message is authenticate and from the approver. Still further, these various electronic mail messages can also be encrypted to secure their contents.
The invention is preferably implemented by software or a combination of hardware and software, but can also be implemented in hardware. The invention can also be embodied as computer readable code on a computer readable medium. The computer readable medium is any data storage device that can store data which can thereafter be read by a computer system. Examples of the computer readable medium include read-only memory, random-access memory, CD-ROMs, DVDs, magnetic tape, optical data storage devices, and carrier waves. The computer readable media can also be distributed over network-coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
The various embodiments, implementations and features of the invention noted above can be combined in various ways or used separately. Those skilled in the art will understand from the description that the invention can be equally applied to or used in other various different settings with respect to various combinations, embodiments, implementations or features provided in the description herein.
The advantages of the invention are numerous. Different embodiments or implementations may yield one or more of the following advantages. One advantage of the invention is that file security systems are able to prevent bottlenecks that occur with conventional system administrator approvals. Another advantage of the invention is that security changes can be approved in a largely automated manner. Still another advantage of the invention is that a security proxy can manage the approval process for requested security changes. Yet another advantage of the invention is that the approval process is flexible (and possibly hierarchical) so as to be capable of being mapped to a wide range of different organizational structures.
The foregoing description of embodiments is illustrative of various aspects/embodiments of the present invention. Various modifications to the present invention can be made to the preferred embodiments by those skilled in the art without departing from the true spirit and scope of the invention as defined by the appended claims. Accordingly, the scope of the present invention is defined by the appended claims rather than the foregoing description of embodiments.
This application is related to: (i) U. S. patent application Ser. No. ______ [attorney docket no. SSL1P020], filed Sep. 30, 2003, and entitled “METHOD AND SYSTEM FOR SECURING DIGITAL ASSETS USING PROCESS-DRIVEN SECURITY POLICIES,” which is hereby incorporated by reference for all purposes; (ii) U. S. patent application Ser. No. ______, [attorney docket no. SSL1P021], filed Sep. 30, 2003, and entitled “METHOD AND APPARATUS FOR TRANSITIONING BETWEEN STATES OF SECURITY POLICIES USED TO SECURE ELECTRONIC DOCUMENTS,” which is hereby incorporated by reference for all purposes; (iii) U.S. patent application Ser. No. 10/262,218, filed Sep. 30, 2002, and entitled “DOCUMENT SECURITY SYSTEM THAT PERMITS EXTERNAL USERS TO GAIN ACCESS TO SECURED FILES,” which is hereby incorporated by reference for all purposes; (iv) U.S. patent application Ser. No. 10/075,194, filed Feb. 12, 2002, and entitled “SYSTEM AND METHOD FOR PROVIDING MULTI-LOCATION ACCESS MANAGEMENT TO SECURED ITEMS,” which is hereby incorporated by reference for all purposes; (v) U.S. patent application Ser. No.: 10/159,537, filed May 5, 2002, and entitled “METHOD AND APPARATUS FOR SECURING DIGITAL ASSETS,” which is hereby incorporated herein by reference; and (vi) U.S. patent application Ser. No.: 10/127,109, filed Apr. 22, 2002, and entitled “EVALUATION OF ACCESS RIGHTS TO SECURED DIGITAL ASSETS,” which is hereby incorporated herein by reference.