This invention relates generally to cloud-based applications and, more specifically, to a system and method for restoring extracted data to a cloud-based application.
In the digital world we live in, it is essential for both corporate entities and individuals to have reliable, consistent backup system. One problem facing backup and restore systems, however, is the scenario in which a data model changes after extracting data from the backup system, such that the extracted data would be incompatible with a restoration to a cloud-based application. For example, a user may have added a new mandatory field to the extracted data or changed a field name such that the data model of the extracted data is no longer compatible with the original data model. Therefore, there is a need for a system and method to transform the extracted data to be compatible with a restoration to the cloud-based application and to execute a restoration routine to restore the transformed data to the cloud-based application. Similarly, there is a need for an efficient, user-friendly user interface for generating instructions for such a restoration flow.
The present disclosure describes a system, method, and computer program for restoring extracted data to a cloud-based application. The method is performed by a computer system that includes servers, storage systems, networks, operating systems, and databases.
The present invention solves the technical problem of how to resolve compatibility issues between extracted data and a cloud-based application in order to restore the extracted data to the cloud-based application, especially for the scenario where the data model changed after the data was extracted from the cloud-based application. This solution makes use of a restoration flow entered by a user via a user interface, where the restoration flow may include one or more of a pre-restoration routine, a restoration routine, and a post-restoration routine. The system executes the pre-restoration routine to transform the extracted data to be compatible with the data model in the cloud-based application, followed by the restoration routine to restore the transformed data to the cloud-based application. If the restoration flow also includes a post-restoration routine, the system will then execute the post-restoration routine after the restoration routine to further transform the data restored to the cloud-based application.
In one embodiment, a method for restoring extracted data to a cloud-based application comprises the following steps:
The present disclosure describes a system, method, and computer program for restoring extracted data to a cloud-based application. The method is performed by a computer system that includes servers, storage systems, networks, operating systems, and databases (“the system”).
Example implementations of the method are described in more detail with respect to
1. Method for Restoring Extracted Data to a Cloud-based Application
The system provides a user interface that enables a user (e.g., a customer) to enter a restoration flow for restoring the extracted data to the cloud-based application (step 130). A restoration flow is a set of ordered restoration routines. The set may include one or more routines, where the types of routines may include a pre-restoration routine, a restoration routine, and a post-restoration routine. The system receives a restoration flow from a user that includes a pre-restoration routine and a restoration routine (step 140). In one embodiment, providing a user interface for entering the restoration flow includes providing template code for pre-restoration and post-restoration routines. The pre-restoration routine specifies one or more data transformations to render the extracted data compatible with the restoration to the cloud-based application. The system executes the pre-restoration routine to transform the extracted data to be compatible with a restoration to the cloud-based application (step 150). The system executes the restoration routine to restore the transformed data to the cloud-based application (step 160).
In certain embodiments, the restoration flow also includes a post-restoration routine for making further transformations to the data after the restoration routine is executed. If the restoration flow includes a post-restoration routine, the system executes the post-restoration routine after the restoration routine to further transform the restored data in the cloud-based application (step 170). In certain embodiments, the post-restoration routine undoes the transformations made in the pre-restoration routine.
In certain embodiments, the data in the cloud-based application is associated with a data model that changed after the extracting step, and where the pre-restoration routine renders a corresponding data model for the extracted data compatible with the data model changes to the data in the cloud-based application. In certain embodiments, the extracted data includes metadata that defines the corresponding data model for the extracted data, and where transforming the extracted data in the pre-restoration routine comprises modifying said metadata. In certain embodiments, the data model changes include a new mandatory field, and the pre-restoration routine adds the new mandatory field to the corresponding data model for the extracted data. In certain embodiments, the data model changes include a field name change, and the pre-restoration routine makes the field name change to the corresponding data model for the extracted data. In certain embodiments, the data model changes include values that are no longer compatible, and the pre-restoration routine exchanges the values for compatible values in the corresponding data model for the extracted data.
In certain embodiments, a limitation to an API for the cloud-based application requires the extracted data to be altered prior to restoring the extracted data to the cloud-based application, and the pre-restoration routine alters the extracted data to be compatible with the API.
2. Example Use Case for Post-Backup Data Model Change
3. Example Use Case for Backup Data Value State Incompatible with Restore API
4. Example System Architecture
The backup platform 435 hosts a backup for each entity 430a, 430b, 430c. Each backup 430a, 430b, 430c includes the metadata and extracted data records that corresponds to the metadata and data records for each entity in the multi-tenant SaaS environment 450a, 450b, 450c. In one embodiment, both the multi-tenant SaaS environment 470 and the backup platform 435 do not provide a separate database for each entity. Hence, while the data records are illustrated separately using database symbols with respect to each entity in both the multi-tenant SaaS environment 470 and the backup platform 435, the database(s) is(are) often shared between entities on their respective servers. A customer can make API calls to the backup 430a, 430b, 430c via API interface 480.
The restoration flow UI 485 provides the user interface that enables a customer to enter the restoration flow process. The restoration flow storage 487 stores the restoration flow. The restoration flow execution 490 executes the routines in the restoration flow. The database reader 495 reads data from the backup database(s).
5. Example Screenshots of User Interface for a User Creating a Restoration Flow
As seen in
6. General
The methods described with respect to
As will be understood by those familiar with the art, the invention may be embodied in other specific forms without departing from the spirit or essential characteristics thereof. Accordingly, the above disclosure is intended to be illustrative, but not limiting, of the scope of the invention, which is set forth in the following claims.
Number | Name | Date | Kind |
---|---|---|---|
6642946 | Janes et al. | Nov 2003 | B1 |
8255320 | Seal et al. | Aug 2012 | B1 |
9268587 | Kruglick | Feb 2016 | B2 |
9330301 | Ozog | May 2016 | B1 |
9769131 | Hartley et al. | Sep 2017 | B1 |
10664494 | Ding | May 2020 | B2 |
11055123 | Bin et al. | Jul 2021 | B1 |
11609774 | Bin et al. | Mar 2023 | B2 |
20080049942 | Sprunk et al. | Feb 2008 | A1 |
20120117558 | Futty et al. | May 2012 | A1 |
20120324242 | Kirsch | Dec 2012 | A1 |
20130227703 | Sotos | Aug 2013 | A1 |
20130283060 | Kulkarni et al. | Oct 2013 | A1 |
20130297769 | Chang et al. | Nov 2013 | A1 |
20140040182 | Gilder et al. | Feb 2014 | A1 |
20140040196 | Wijayaratne | Feb 2014 | A1 |
20140040197 | Wijayaratne | Feb 2014 | A1 |
20140101438 | Elovici et al. | Apr 2014 | A1 |
20140143661 | Carreno-Fuentes et al. | May 2014 | A1 |
20140278534 | Romeo | Sep 2014 | A1 |
20160019233 | Wijayaratne | Jan 2016 | A1 |
20160147999 | Fontanetta et al. | May 2016 | A1 |
20160308855 | Lacey et al. | Oct 2016 | A1 |
20170025040 | Maturana et al. | Jan 2017 | A1 |
20170048252 | Straub et al. | Feb 2017 | A1 |
20170091293 | Cummings et al. | Mar 2017 | A1 |
20170249656 | Gantner et al. | Aug 2017 | A1 |
20180081905 | Kamath et al. | Mar 2018 | A1 |
20180089270 | Qiu et al. | Mar 2018 | A1 |
20180150476 | Koos | May 2018 | A1 |
20180176117 | Gudetee et al. | Jun 2018 | A1 |
20190007206 | Surla et al. | Jan 2019 | A1 |
20190034509 | Ding | Jan 2019 | A1 |
20190042988 | Brown et al. | Feb 2019 | A1 |
20190050925 | Hodge et al. | Feb 2019 | A1 |
20200067772 | Tomkins et al. | Feb 2020 | A1 |
20200073854 | Wijayaratne | Mar 2020 | A1 |
20200082890 | Karr et al. | Mar 2020 | A1 |
20200127937 | Busick et al. | Apr 2020 | A1 |
20200159700 | Wijayaratne | May 2020 | A1 |
20210049029 | Kumble et al. | Feb 2021 | A1 |
20210067324 | Valente et al. | Mar 2021 | A1 |
20210255991 | Koos | Aug 2021 | A1 |
20210255992 | Wijayaratne | Aug 2021 | A1 |
20220067115 | Zheng et al. | Mar 2022 | A1 |
20220107826 | Bin et al. | Apr 2022 | A1 |
20220129804 | Dooley et al. | Apr 2022 | A1 |
20220148084 | Baker | May 2022 | A1 |
20220188334 | Chen | Jun 2022 | A1 |
20220207489 | Gupta et al. | Jun 2022 | A1 |
20230010219 | Howley et al. | Jan 2023 | A1 |
20230082010 | Clifford et al. | Mar 2023 | A1 |
20230145349 | Watari | May 2023 | A1 |
20230315694 | Koos | Oct 2023 | A1 |
20230325360 | Wijayaratne | Oct 2023 | A1 |
Number | Date | Country |
---|---|---|
2022081408 | Apr 2022 | WO |