This application is related to the following commonly-assigned, co-pending applications, each of which is also incorporated herein by reference in its entirety:
1. U.S. patent application Ser. No. 12/612,807 filed on Nov. 5, 2009, now U.S. Pat. No. 8,065,395 issued on Nov. 22, 2011
2. U.S. patent application Ser. No. 12/612,818 filed on Nov. 5, 2009;
3. U.S. patent application Ser. No. 12/612,834 filed on Nov. 5, 2009;
4. U.S. patent application Ser. No. 12/612,841 filed on Nov. 5, 2009;
5. U.S. patent application Ser. No. 12/612,882 filed on Nov. 5, 2009;
6. U.S. patent application Ser. No. 12/612,903 filed on Nov. 5, 2009;
7. U.S. patent application Ser. No. 12/612,925 filed on Nov. 5, 2009;
8. U.S. patent application Ser. No. 12/613,077 filed on Nov. 5, 2009;
9. U.S. patent application Ser. No. 12/613,098 filed on Nov. 5, 2009;
10. U.S. patent application Ser. No. 12/613,112 filed on Nov. 5, 2009; and 11. U.S. patent application Ser. No. 12/197,833 filed on Aug. 25, 2008, now U.S. Pat. No. 8,036,396 issued on Oct. 11, 2011.
Cloud computing is a type of computing in which dynamically scalable and typically virtualized resources are provided as services via the Internet. As a result, users need not, and typically do not, possess knowledge of, expertise in, or control over the technology and/or infrastructure implemented in the cloud. Cloud computing generally incorporates infrastructure as a service (“IaaS”), platform as a service (“PaaS”), and/or software as a service (“SaaS”). In a typical embodiment, cloud computing services provide common applications online, which applications are accessed using a web browser and the software and data for which are stored on servers comprising the cloud.
Cloud computing customers typically do not own or possess the physical infrastructure that hosts their software platform; rather, the infrastructure is leased in some manner from a third-party provider. Cloud computing customers can avoid capital expenditures by paying a provider for only what they use on a utility, or resources consumed, basis or a subscription, or time-based, basis, for example. Sharing computing power and/or storage capacity among multiple lessees has many advantages, including improved utilization rates and an increase in overall computer usage.
Cloud computing and cloud storage are rapidly redefining the landscape of the enterprise data center. Rather than expanding data center capacity to meet processing and storage needs, modern enterprises are expanding into the cloud to obtain needed computing and storage resources for day to day and burst requirements. In order for cloud computing to be successful from the enterprise point of view, utilizing cloud assets must be as transparent as accessing enterprise assets in the data center. Workflow request processing and routing has become an integral part of the modern enterprise wherein rights and privileges can be maintained on an ad hoc or just in time basis. As an employee needs access to assets a workflow is started in which the appropriate permissions and attestations are obtained so that an auditable decision to allow the user access (or disallow the access) is maintained and the appropriate rights and privileges are granted.
One embodiment is a method for implementing a workflow of a first domain, wherein the workflow is implemented as a series of steps to accomplish a workload and wherein at least one of the steps utilizes a process. The method comprises establishing a mutual trust relationship between the first domain and a second domain; wherein one of the steps is authored by the second domain, the method further comprising associating with the step authored by the second domain a digital attestation for enabling the first domain to verify authorship and non-modification thereof.
To better illustrate the advantages and features of the embodiments, a particular description of several embodiments will be provided with reference to the attached drawings. These drawings, and other embodiments described herein, only illustrate selected aspects of the embodiments and are not intended to limit the scope thereof. Further, despite reference to specific features illustrated in the example embodiments, it will nevertheless be understood that these features are not essential to all embodiments and no limitation of the scope thereof is thereby intended. Any alterations and further modifications in the described embodiments, and any further applications of the principles of the embodiments as described herein are contemplated as would normally occur to one skilled in the art. Furthermore, some items are shown in a simplified form, and inherently include components that are well known in the art. Further still, some items are illustrated as being in direct connection for the sake of simplicity and clarity. Despite the apparent direct connection, it is understood that such illustration does not preclude the existence of intermediate components not otherwise illustrated.
The embodiments described herein provide a mechanism for allowing two or more independent trust domains to participate in a workflow to accomplish some work mechanism where part of the processing and storage may exist in the cloud. The embodiments described herein further provide a mechanism to allow the trust model to extend into the cloud such that the processing and/or storage (hereinafter collectively referred to as “process” or “processes”) required by the workflow can be completely trusted by any of the participating trust environments.
Enterprises using the cloud are represented by virtualization processes and storage shown as workloads 112. These processes are typically started by an enterprise via a cloud portal or API utilized by administrative personnel or processes running at the enterprise or in the cloud. A typical cloud provider may be using standard ITIL practices and may utilize a configuration management database (“CMDB”) 114, which affects the entire cloud infrastructure and which describes the practice and policies used for instantiating virtualized workloads and storage.
In one embodiment, a workflow is designed in a manner well-known in the art and comprises a series of steps that utilize processes to accomplish some workload. Specific types of processes, such as branching, joining, and distributing, for example, are also known in the art. As shown in
In one embodiment, a step that is authored by a separate trust domain, such as the step 202D, has a digital attestation attached to or otherwise associated with it so that the enterprise 204A can verify that the step has indeed been authored by the other trust domain (in this case, the enterprise 204B) and has not been modified. In one embodiment, the steps in the workflow 200 may reference processes that reside in a cloud 206, such as the process 203C. In this case, the workflow 200 must be integrated so that such a process is accessible by all of the trust domains, or enterprises 204A, 204B, that are participating in the workflow. This can be accomplished through use of mechanisms previously disclosed one or more of the above-noted patents previously incorporated by reference; particularly U.S. patent application Ser. No. 12/612,841 filed on Nov. 5, 2009. In brief, access is granted because each process 203A-203C has associated therewith assertions that other trust domains can satisfy because of the knowledge of cryptographic keys or other attestations to which the enterprise has access.
Similarly, storage may be initiated in a portion of the workflow 200 and then moved to the cloud 206 so that other trust domains can have access to that storage to complete the workflow. In this case, the storage is tagged and associated with assertions that require attestations from the other trust domains before those trust domains are granted access. Referring again to
In one embodiment, the step 202D is also moved from the enterprise 204A to either the cloud 206 or to the enterprise 204B via the cloud 206. In the first case, the enterprise 204B processes the step 202D in the cloud 206; in the second case, the step 202D is processed within the trust domain of the enterprise 204B and then the resulting information is shared back to the other trust domains (e.g., the enterprise 204A) either in the cloud 206 or through the cloud 206 or through some secure channel, implementation of which may be as described in one or more of the aforementioned patent applications.
Referring again to
As also illustrated in
It will be recognized that, in an alternative embodiment, a persistent and organized data store, such as an Oracle database, may be deployed in the cloud for use by workflows. This alternative embodiment addresses environments in which a substantial amount of processing and storage assets are resident in the cloud and utilized by workflow processes. In such an embodiment, the step 202D may be unknown to the enterprise 204A and only a reference from the step 202B is part of the workflow 200. In this case, the enterprise 204B has complete control over the step 202D returning the result to the step 202E via some sharing mechanism (such as the storage shown in the cloud or some protocol channel). In this embodiment, the entire workflow 200 may be hosted in the cloud 206, with all trust domains 204A, 204B, having access to the workflow. Each trust domain 204A, 204B, may posses rights to all aspects of the workflow 206 or only certain ones of the steps 202A-202E may be tagged so that a given trust domain may edit only the steps tagged in such a manner as to allow access. In another embodiment, only portions of the workflow 200 are hosted in the cloud 206.
Note that all of the traditional structures of the workflow (such as step timeout and reassignment) are supported by the embodiments described herein. In fact, reassignment may occur across different trust domains because of the way that the trust mechanism is defined across the different trust domains in a manner that will be apparent to one of ordinary skill in the art.
It will be recognized that various ones of the elements and/or modules described herein may be implemented using one or more general purpose computers or portions thereof executing software applications designed to perform the functions described or using one or more special purpose computers or portions thereof configured to perform the functions described. The software applications may comprise computer-executable instructions stored on computer-readable media. Additionally, repositories described herein may be implemented using databases or other appropriate storage media. It will be further recognized that domains described herein comprise appropriate hardware for implementing the functions thereof, including, but not limited to, computers and storage devices.
While the preceding description shows and describes one or more embodiments, it will be understood by those skilled in the art that various changes in form and detail may be made therein without departing from the spirit and scope of the present disclosure. For example, various steps of the described methods may be executed in a different order or executed sequentially, combined, further divided, replaced with alternate steps, or removed entirely. In addition, various functions illustrated in the methods or described elsewhere in the disclosure may be combined to provide additional and/or alternate functions. Therefore, the claims should be interpreted in a broad manner, consistent with the present disclosure.
Number | Name | Date | Kind |
---|---|---|---|
5428738 | Carter et al. | Jun 1995 | A |
5608903 | Prasad et al. | Mar 1997 | A |
5677851 | Kingdon et al. | Oct 1997 | A |
5758344 | Prasad et al. | May 1998 | A |
5784560 | Kingdon et al. | Jul 1998 | A |
5787175 | Carter | Jul 1998 | A |
5832275 | Olds | Nov 1998 | A |
5832487 | Olds et al. | Nov 1998 | A |
5870564 | Jensen et al. | Feb 1999 | A |
5878415 | Olds | Mar 1999 | A |
5878419 | Carter | Mar 1999 | A |
5956718 | Prasad et al. | Sep 1999 | A |
6067572 | Jensen et al. | May 2000 | A |
6108619 | Carter et al. | Aug 2000 | A |
6119230 | Carter | Sep 2000 | A |
6185612 | Jensen et al. | Feb 2001 | B1 |
6219652 | Carter et al. | Apr 2001 | B1 |
6275819 | Carter | Aug 2001 | B1 |
6405199 | Carter et al. | Jun 2002 | B1 |
6459809 | Jensen et al. | Oct 2002 | B1 |
6519610 | Ireland et al. | Feb 2003 | B1 |
6539381 | Prasad et al. | Mar 2003 | B1 |
6601171 | Carter et al. | Jul 2003 | B1 |
6647408 | Ricart et al. | Nov 2003 | B1 |
6650777 | Jensen et al. | Nov 2003 | B1 |
6697497 | Jensen et al. | Feb 2004 | B1 |
6738907 | Carter | May 2004 | B1 |
6742035 | Zayas et al. | May 2004 | B1 |
6742114 | Carter et al. | May 2004 | B1 |
6760843 | Carter | Jul 2004 | B1 |
6772214 | McClain et al. | Aug 2004 | B1 |
6826557 | Carter et al. | Nov 2004 | B1 |
6862606 | Major et al. | Mar 2005 | B1 |
6993508 | Major et al. | Jan 2006 | B1 |
7043555 | McClain et al. | May 2006 | B1 |
7107538 | Hinckley et al. | Sep 2006 | B1 |
7152031 | Jensen et al. | Dec 2006 | B1 |
7177922 | Carter et al. | Feb 2007 | B1 |
7185047 | Bate et al. | Feb 2007 | B1 |
7197451 | Carter et al. | Mar 2007 | B1 |
7286977 | Carter et al. | Oct 2007 | B1 |
7299493 | Burch et al. | Nov 2007 | B1 |
7316027 | Burch et al. | Jan 2008 | B2 |
7334257 | Ebrahimi et al. | Feb 2008 | B1 |
7356819 | Ricart et al. | Apr 2008 | B1 |
7363577 | Kinser et al. | Apr 2008 | B2 |
7376134 | Carter et al. | May 2008 | B2 |
7386514 | Major et al. | Jun 2008 | B2 |
7389225 | Jensen et al. | Jun 2008 | B1 |
7426516 | Ackerman et al. | Sep 2008 | B1 |
7467415 | Carter | Dec 2008 | B2 |
7475008 | Jensen et al. | Jan 2009 | B2 |
7505972 | Wootton et al. | Mar 2009 | B1 |
7506055 | McClain et al. | Mar 2009 | B2 |
7552468 | Burch et al. | Jun 2009 | B2 |
7562011 | Carter et al. | Jul 2009 | B2 |
20080091613 | Gates et al. | Apr 2008 | A1 |
20110066847 | Christensen et al. | Mar 2011 | A1 |
Number | Date | Country | |
---|---|---|---|
20110106926 A1 | May 2011 | US |