The present application claims priority from Indian Patent Application no. 201611028348 filed on 19 Aug. 2016, the entirety of which is hereby incorporated by reference.
The present invention in general relates to the hybrid deployment of an application. More particularly, the present invention relates to a method and system for controlling a functionality of an application in a hybrid deployment.
Generally, software service providers build software based on the requirement of their customers. These software maybe deployed in cloud datacentre or local datacentre of the customer. Software deployed in cloud datacentre may be used to service multiple customers from the same deployment using multi tenancy techniques. However, the software is required to be customized and differentiated based on the geographic conditions, individual needs and on the like.
Typically, there are multiple conventional models for building and deploying the software. One of the examples of conventional models may be building a single software from a single code base and the same deployment is used to service multiple customers. Other conventional model may be a software built by extending the single code based and customizing based on the customer requirements, deployed separately for each customer.
The conventional models used for building and deployment of the software are either very complex leading to increase in cost. At same time, deploying such a complex software further leads to increase in issues with ownership of the software.
Moreover in certain circumstances, during the development of the software it is unknown whether the software is going to be used from cloud datacentre and/or local datacentre or both. This may be due to restricted internet access or security or regulatory reasons of the customer. Hence, conventional models fail to facilitate developing of a software that could be deployed and accessed from cloud datacentre and/or local datacentre or both.
Before the present a method and system for controlling a functionality of an application in a hybrid deployment, are described, it is to be understood that this application is not limited to the particular systems, and methodologies described, as there can be multiple possible embodiments which are not expressly illustrated in the present disclosures. It is also to be understood that the terminology used in the description is for the purpose of describing the particular implementations or versions or embodiments only, and is not intended to limit the scope of the present application. This summary is provided to introduce aspects related to a method and system for controlling a functionality of an application in a hybrid deployment. This summary is not intended to identify essential features of the claimed subject matter nor is it intended for use in determining or limiting the scope of the claimed subject matter.
In one implementation, a method for controlling a functionality of an application in a hybrid deployment is disclosed. In one aspect, the method may comprise receiving an application developed utilizing an application archetype. The application archetype enables abstraction of one or more complexities of developing the application. The application archetype comprises of one or more of build and package feature, a multi tenancy feature, a data access feature, a customization feature, a security feature, a user interface feature and a synchronization feature. The application is developed by a developer. Further the method may comprise, deploying the application in a hybrid deployment. The hybrid deployment comprises a cloud datacentre deployment and a local datacentre deployment. Further the method may comprise, obtaining a primary configuration data associated with the cloud datacentre deployment and a secondary configuration data associated with the local datacentre deployment. The primary configuration data and the secondary configuration data is obtained dynamically at runtime from one or more users of the application. The primary configuration data and secondary configuration data comprises one or more of functionality, a write operation and a data synchronization. Further the method may comprise, storing, the primary configuration data and the secondary configuration data as a metadata in the application archetype. Further, the method may comprise, controlling one or more functionality of the application, at runtime, based on metadata.
In one implementation, a system for controlling a functionality of an application in a hybrid deployment is disclosed. In one aspect, the system comprises a memory and a processor coupled to the memory. Further, the processor may be capable of executing instructions in the memory to perform one or more steps. In the aspect, the system may comprise receiving an application developed utilizing an application archetype. The application archetype enables abstraction of one or more complexities of developing the application. The application archetype comprises one or more of a build and package feature, a multi tenancy feature, a data access feature, a customization feature, a security feature, a user interface feature and a synchronization feature. The application is developed by a developer. Further, the system may comprise, deploying the application in a hybrid deployment, wherein the hybrid deployment comprises a cloud datacentre deployment and a local datacentre deployment. Further the system may comprise, obtaining a primary configuration data associated with the cloud datacentre and a secondary configuration data associated with the local datacentre deployment. The primary configuration data and the secondary configuration data is obtained dynamically at runtime from one or more users of the application that comprises one or more of functionality, a write operation and a data synchronization. Further the system may comprise, storing, the primary configuration data and the secondary configuration data as a metadata in the application archetype. Further the system may comprise, controlling one or more functionality of the application, at runtime based on metadata.
In yet another implementation, non-transitory computer readable medium embodying a program executable in a computing device for controlling a functionality of an application in a hybrid deployment is disclosed. In one aspect, the program may comprise a program code for receiving an application developed utilizing an application archetype. Further, the application archetype may enables abstraction of one or more complexities of developing the application. The application archetype comprises one or more of a build and package feature; a multi tenancy feature, a data access feature, a customization feature, a security feature, a user interface feature and a synchronization feature. The application is developed by a developer. The program may comprise a program code for deploying the application in a hybrid deployment. The hybrid deployment comprises a cloud datacentre deployment and a local datacentre deployment. The program may comprise a program code for obtaining a primary configuration data associated with the cloud datacentre deployment and a secondary configuration data associated with the local datacentre deployment. The primary configuration data and the secondary configuration data may be obtained dynamically at runtime from one or more users of the application. The configuration data comprises one or more of functionality, a write operation and a data synchronization. The program may comprise a program code for storing the primary configuration data and the secondary configuration data as a metadata in the application archetype. Further, the program may comprise a program code for controlling one or more functionality of the application, at runtime, based on metadata.
The foregoing detailed description of embodiments is better understood when read in conjunction with the appended drawings. For the purpose of illustrating of the present subject matter, an example of construction of the present subject matter is provided as figures; however, the invention is not limited to the specific method and system disclosed in the document and the figures.
The present subject matter is described detail with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The same numbers are used throughout the drawings to refer various features of the present subject matter.
Some embodiments of this disclosure, illustrating all its features, will now be discussed in detail. The words “comprising,” “having,” “containing,” and “including,” and other forms thereof, are intended to be equivalent in meaning and be open ended in that an item or items following any one of these words is not meant to be an exhaustive listing of such item or items, or meant to be limited to only the listed item or items. It must also be noted that as used herein and in the appended claims, the singular forms “a,” “an,” and “the” include plural references unless the context clearly dictates otherwise. Although any systems and methods for controlling a functionality of an application in a hybrid deployment, similar or equivalent to those described herein can be used in the practice or testing of embodiments of the present disclosure, the exemplary, systems and methods for controlling a functionality of an application in a hybrid deployment are now described. The disclosed embodiments for controlling a functionality of an application in a hybrid deployment are merely examples of the disclosure, which may be embodied in various forms.
Various modifications to the embodiment will be readily apparent to those skilled in the art and the generic principles herein may be applied to other embodiments for controlling a functionality of an application in a hybrid deployment. However, one of ordinary skill in the art will readily recognize that the present disclosure for controlling a functionality of an application in a hybrid deployment is not intended to be limited to the embodiments described, but is to be accorded the widest scope consistent with the principles and features described herein.
In an implementation, systems and methods for controlling a functionality of an application in a hybrid deployment, is disclosed. In the implementation, an application developed utilizing an application archetype is received. The application archetype may be a set of pre-built functionalities available for use to the application developer. The application developer may develop the business specific functionalities using archetype and on top of the common cross cutting functionalities provided by the archetype. Commonly considered functionalities of an application development that determine the software to be developed are multi-tenancy, data access, controlling read-write operation for data, controlling data synchronization, configuration and customization for the customer like workflows, reports, security authentication and packaging. The application archetype is used to build single software with an option to selectively be accessed by the user from cloud datacentre or local datacentre.
In the implementation, upon receiving the application, the application is deployed in a hybrid deployment. Further, the hybrid deployment comprises a cloud datacentre deployment and a local datacentre deployment. Subsequent to deployment, primary configuration data associated with the cloud datacentre deployment and secondary configuration data associated with the local datacentre deployment is obtained and stored as metadata. Further, the primary configuration and the secondary configuration data may be configured at runtime after the application is deployed and updated according to one or more users of the application such as onboarded customer requirements. The application archetype manages the primary configuration and the secondary configuration data based on per customer and per deployment model. The primary configuration data and the secondary configuration data may include but not limited to extensions—new fields at runtime, field validations, rules, workflows, reports, user interface (UI) layout and themes, authentication for users of the customer, list of functionalities accessible to the user in cloud datacentre and/or local datacentre.
Further to storing the primary configuration data and the secondary configuration data as metadata in the application archetype, the user may access the functionality from cloud datacentre and/or local datacentre. If the functionality is enabled for the user for the current mode of deployment—cloud datacentre or local datacentre the user may continue to access the functionality else the access would be denied to the user. Thus, controlling the functionality of an application in a hybrid deployment of an application.
In one implementation, the synchronization of the data may be triggered by the application archetype based on the functionality configuration stored as metadata. Additionally, write operation for a user may be based on the functionality configuration stored as metadata.
While aspects of described system and method for controlling hybrid deployment of an application may be implemented in any number of different computing systems, environments, and/or configurations, the embodiments are described in the context of the following exemplary system.
Referring now to
In one implementation, the system (102) may be implemented in a cloud-based environment in which the user may operate individual computing systems configured to execute remotely located applications. In another embodiment, the system (102) may also be implemented on customer devices, hereinafter referred to as a customer device (104). It may be understood that the system implemented on the customer device supports a plurality of browsers and all viewports. It will also be understood that the system (102) may be accessed by multiple users of the customer through one or more user devices 104-1, 104-2 . . . and 104-N, collectively referred to as user devices (104) hereinafter, or applications residing on the user devices (104). Examples of the user devices (104) may include, but are not limited to, such as a laptop computer, a desktop computer, a notebook, a workstation, a main frame computer, a server, a network server, a cloud-based computing environment and the like. The user devices (104) are communicatively coupled to the system (102) through a network (106).
In one implementation, the network (106) may be a wireless network, a wired network or a combination thereof. The network (106) can be implemented as one of the different types of networks, such as intranet, local area network (LAN), wide area network (WAN), the Internet, and the like. The network (106) may either be a dedicated network or a shared network. The shared network represents an association of the different types of networks that use a variety of protocols, for example, Hypertext Transfer Protocol (HTTP), Transmission Control Protocol/Internet Protocol (TCP/IP), Wireless Application Protocol (WAP), and the like, to communicate with one another. Further the network (106) may include a variety of network devices, including routers, bridges, servers, computing devices, storage devices, and the like.
Referring now to
Referring now to
The I/O interface 304 may include a variety of software and hardware interfaces, for example, a web interface, a graphical user interface, and the like. The I/O interface (304) may allow the system (102) to interact with a user directly or through the user devices (104). Further, the I/O interface (304) may enable the system (102) to communicate with other computing devices, such as web servers and external data servers (not shown). The I/O interface (304) can facilitate multiple communications within a wide variety of networks and protocol types, including wired networks, for example, LAN, cable, etc., and wireless networks, such as WLAN, cellular, or satellite. The I/O interface (304) may include one or more ports for connecting a number of devices to one another or to another server.
The memory (306) may include any computer-readable medium known in the art including, for example, volatile memory, such as static random access memory (SRAM) and dynamic random access memory (DRAM), and/or non-volatile memory, such as read only memory (ROM), erasable programmable ROM, flash memories, hard disks, optical disks, and magnetic tapes. The memory (306) may include modules (308) and data (310).
The modules (308) include routines, programs, objects, components, data structures, etc., which perform particular tasks, functions or implement particular abstract data types. In one implementation, the modules (308) may include a receiving module (312), a deploying module (314), an obtaining module (316), a storing module (318), a controlling module (320), and other modules (322). The other modules (322) may include programs or coded instructions that supplement applications and functions of the system (102).
The data (310), amongst other things, serves as a repository for storing data processed, received, and generated by one or more of the modules (308). The data (310) may also include a system database (324), and other data (326). The system database (324) is configured to store the primary configuration data associated with the cloud datacentre deployment and secondary configuration data associated with the local datacentre deployment.
In one implementation, the receiving module (312) may receive an application developed utilizing an application archetype. An application so obtained may be understood as application that allows an user to perform associated tasks and activities.
In one embodiment, the application archetype may be understood as an application development template with a set of pre-built functionalities available for use to an application developer. The application developer may use the application archetype to develop application that may be deployed both in cloud datacentre and local datacentre and can be accessed by the user either from cloud datacentre and local datacentre. The application archetype may comprise of build and package functionalities. In one embodiment, single application archetype maybe used to build a single software application. The application archetype may provide output of two artefacts one for cloud datacentre deployment and one for local datacentre deployment. In one implementation, the cloud datacentre artefact packaging may add the implementations meant only for the cloud datacentre and remove the implementations meant for local datacentre. In other implementation, the local datacentre artefact packaging may add the implementations meant for the local datacentre and remove the implementations meant only for cloud datacentre. Further, the packaging may add all the resources or the resources associated with the functionality applicable for individual deployment.
In one embodiment, the application archetype may allow the application developer to register the list of functionalities developed using the archetype and the set of resources associated with that functionality. The application archetype enables the application to identify the functionality to be enabled in cloud datacentre and in local datacentre.
In one embodiment, the application archetype may expose Application Program Interface (API) to access data from the database. In one implementation available API may be one or more of DataAccess.create (data), DataAccess.get (data_id), DataAccess.get (filter), DataAccess.update (data), DataAccess.delete (data_id), DataAccess.execute (query). Further, the API may validate the data, data isolation per customer and determine whether the application is required to be deployed one for cloud datacentre or for local datacentre. Implementation for cloud datacentre or for local datacentre may be stubbed during packaging.
In another implementation, for every functionality several resources may be added to the application that may constitute a single functionality, where such functionality may not be limited to domain/data models, menus, business services, UI resources and access permission. In one implementation, the developer may define the functionality by defining the resources being utilized by functionality through an xml configuration. In an exemplary embodiment, the functionality of ‘Add User’ maybe considered to understand the configuration and customization of the customer. ‘Add User’ user interface may capture basic information like username, first name, last name etc. The functionality through an XML configuration maybe as:
In a further exemplary embodiment, the functionality of ‘Add User’ maybe configured to capture any additional information required by the customer. The customer may add a new field such as ‘mobile number’ to be captured additional to the existing information that maybe further stored as metadata for the entity ‘User’ for the customer and for the deployment model. Thus, if the customer attempts to add a user, the application may check using the metadata API for any additional fields configured for the customer and the mode of deployment i.e. cloud datacentre or local datacentre. If there are any additional fields, the fields maybe shown on the user interface. Upon receiving the valid inputs from the user, the application may utilize the data access API to save the user information along with the additional field information captured for the user. In one implementation, the customization maybe extended to other fields like workflows, rules, reports etc.
In another embodiment, the application archetype may further contain features or facets such as multi tenancy, data access, configuration, customization, user interface, menus, synchronization and authentication. In one example, multi tenancy maybe understood as an architecture in which a single instance of an application may run on a server and serve multiple customers.
In further embodiment, the application archetype enables abstraction of one or more complexities of developing the software. The application developer is abstracted from developing a separate application for cloud datacentre and local datacentre. In one example, application archetype my abstract the complexities of the application developer by gathering and storing the customizations of the customer along with the variations between the cloud datacentre and the local datacentre as metadata. The metadata stores configurations for each customer and for each deployment model. The customer may after deployment of a hybrid application configure how the application should behave for the users in cloud datacentre and in local datacentre.
In further implementation, the user authentication functionality maybe based on the customer configurations. These configurations may be different between cloud datacentre deployment and local datacentre deployment. To provide authentication each user may be associated to a set of roles aggregating permissions to execute application functionalities. Each application functionality may be mapped to a single or a set of permissions, thus allowing users with the permission to access the application functionality or the resources associated with the functionality. In one example, each user of the application maybe identified uniquely using the username and the customer to which the user is associated with. Further, each customer may have their own authentication mechanism where such authentication maybe token based or active directory or Security Assertion Markup Language (SAML) based identity provider or oauth authentication. The customer configuration maybe different between cloud deployment and datacentre deployment. The one or more users may be associated with the customer.
Further, the receiving module (312) may receive an application developed utilizing an application archetype that may be used to build a single application. In the implementation, upon receiving, the receiving module (312) may store the received information in system database (324).
In one implementation, the deploying module (314) may deploy the application in a hybrid deployment. The hybrid deployment may comprise of a cloud datacentre deployment and a local datacentre deployment.
In one implementation, the application may be deployed in cloud datacentre only. In another implementation, the application maybe deployed in local datacentre only. Further, in another implementation wherein no preference is received from the customer the application is deployed in the cloud datacentre and when the request is provided the local deployment may be initiated.
In one implementation, the functionality to be enabled in cloud data centre and the local datacentre maybe based on the application developed utilizing the application archetype. The selective enablement of the functionalities maybe through a set of configurations specified at runtime made during the deployment of the application for a customer. Further, in one example, same application maybe hosted for multiple customers.
In one implementation, the obtaining module (316) may obtain primary configuration data associated with the cloud datacentre deployment and the secondary configuration data associated with the local datacentre deployment. The primary configuration data and secondary configuration data are obtained dynamically at runtime that may comprise one or more of functionality, write operation and data synchronization. The customizations of the customer may include but not limited to field extensions, field validations, rules, workflows, reports, user interface layouts and themes, user authentication and the functionalities accessible in cloud datacentre and local datacentre to the one or more users associated with a customer. Further the customizations may become the metadata API related to the customer.
In one embodiment, the customizations of the customer obtained at runtime maybe modified according to the requirement of the customer. These customizations maybe stored as metadata in system database (326).
During onboarding of the customer the obtaining module (316) allows the customer to customize the application based on a deployment mode. The deployment mode may be cloud datacentre or local datacentre or both. The well-defined API related to the customer may manage the customizations of the customer as a metadata to be enabled to identify whether the deployment is for cloud datacentre or local datacentre. The application archetype manages the customizations based on per customer and per deployment model.
In one implementation, the obtaining module (316) prompts the customer to list the one or more of a functionality to be enabled. In one implementation, the application may be enabled in cloud datacentre. In another implementation, the application may be enabled in local centre. In further implementation, the application may be enabled in both cloud datacentre and local datacentre. The functionality to be enabled may be one or more of but not limited to user management, password policy management, department management, role management, user interface customization, workflow customization and report customization. In one implementation, the information obtained from the customer may be stored as a customization metadata. In an example, the customer may be facilitated to list functionality to be enabled in the following manner:
In one implementation, the customer may selectively choose whether the data may be written in cloud datacentre or local datacentre or both for an identified user of the customer. The module provides the ability to choose the data access API to manage data. Once the application is deployed, the customer may be prompted to choose the data access for all user roles.
In one implementation, the application archetype may provide an ability to control and synchronize the data between cloud datacentre and the local datacentre. In one example, data synchronized to local datacentre may only belong to the customer for whom local datacentre deployment is opted. For other customer's data may not be synchronized.
In one implementation, the customer may selectively choose a data synchronization frequency for cloud datacentre and local datacentre. The synchronization may be based on frequency and the data transfer for synchronization. Further, the synchronization may be based on push from cloud, push from datacentre or pull from the datacentre. In one example, the customer during onboarding maybe prompted for synchronization of data of all data models. Further, the information regarding the synchronization of data is stored as metadata for the customer and per deployment model. Such information may be as below:
In one implementation, the user based on the role access the application from the cloud datacentre or local datacentre or both. In a condition, that the user may access the application from both the cloud datacentre and local datacentre, then different role may be assigned to the user to access the application from cloud datacentre and different role may be assigned to the user to access the application from local datacentre.
In one implementation, the storing module (320) may store the primary configuration data and the secondary configuration data as a metadata in the application archetype. The application customizations for a customer are stored as metadata in system database (324).
In one implementation, the controlling module (322) may control one or more functionality of the application based on the metadata, at runtime. In one exemplary implementation, the user may attempt to access the application from a cloud datacentre. On receiving the user login and the Uniform Resource Locator (URL) the controlling module (320) may determine a deployment type of the application. The deployment type comprises of the cloud datacentre deployment and the local datacentre deployment. Upon checking by the controlling module (320), the controlling module (320) may determine the access to the user for a functionality and/or a write operation based on the metadata stored. The user may access the functionality and/or the write operation if the user has access as stored in the metadata. In one exemplary implementation, the user may not have the access to the functionality and/or the write operation, the access to the user may be denied. In the manner as above the hybrid deployment of the application may be enabled by controlling the functionality of the application.
Exemplary embodiments for controlling a functionality of an application in a hybrid deployment as discussed above may provide certain advantages. Though not required to practice aspects of the disclosure, these advantages may include those provided by the following features.
Some embodiments of the system and the method control hybrid deployment of an application by abstracting one or more complexities of developing the application.
Some embodiments of the system and the method enable hybrid deployment of an application that may selectively be accessed by the user from cloud datacentre or local datacentre.
Some embodiments of the system and the method enable selective controlling of write operations on data between cloud datacentre and local datacentre.
Some embodiments of the system and the method enable selective synchronization of data between cloud datacentre and local datacentre.
Some embodiments of the system and the method enable customization between cloud datacentre and local datacentre using metadata.
Some embodiments of the system and the method enable controlling of the functionalities available in cloud datacentre and local datacentre.
Some embodiments of the system and the method enable controlling the user access between the cloud datacentre and local datacentre.
Some embodiments of the system and the method abstract the complexities of the application developer by storing the changes between the customers and also the changes between cloud datacentre and the local datacentre as metadata which maybe be configured at runtime after the application is deployed and customized as per the requirements of the customer being onboarded.
Some embodiments of the system and the method enable multiple customers to be hosted on same application providing ability to customize the application at runtime after deployment.
Referring now to
The order in which the method (400) is described is not intended to be construed as a limitation, and any number of the described method blocks can be combined in any order to implement the method (400) or alternate methods. Additionally, individual blocks may be deleted from the method (400) without departing from the spirit and scope of the subject matter described herein. Furthermore, the method (400) can be implemented in any suitable hardware, software, firmware, or combination thereof. However, for ease of explanation, in the embodiments described below, the method (400) may be considered to be implemented in the above described system (102).
At block (402), an application developed utilizing an application archetype is received. In one example, the application archetype may comprise build and package feature. The application archetype enables abstraction of one or more complexities of developing the application. In one embodiment, the receiving module (312) may receive an application developed utilizing an application archetype and stores the application and the application archetype in system database (324).
At block (404), the primary application in the cloud datacentre and the secondary application in the local datacentre are deployed. In one embodiment, the deploying module (314) is configured to deploy the primary application in the cloud datacentre and the secondary application in the local datacentre and stores the primary application in the cloud datacentre and the secondary application in the local datacentre in system database (324).
At block (406), a primary configuration data associated with the primary application and the secondary configuration data associated with the secondary application is obtained. In one example, configuration data may comprise one or more of but not limited to user management, password policy management, department management, role management, customization of user interface, customization of workflows, and customization of reports. In one embodiment, the obtaining module (316) is configured to obtain a primary configuration data associated with the primary application and the secondary configuration data associated with the secondary application and store the configuration data in system database (324).
At block (408), the primary configuration data associated with the primary application and the secondary configuration data as a metadata is stored in the application archetype. In one embodiment, the storing module (318) is configured to store the primary configuration data associated with the primary application and the secondary configuration data as a metadata in the application archetype and store the configuration data in system database (326).
At block (410), one or more functionality of the application based on metadata, is controlled. In one embodiment, the controlling module (322) is configured to obtain one or more functionality of the application based on metadata and enable a hybrid deployment of an application.
Exemplary embodiments discussed above may provide certain advantages. Though not required to practice aspects of the disclosure, these advantages may include a method and system for controlling a functionality of an application in a hybrid deployment.
Although implementation for methods and systems to enable hybrid deployment of an application has been described, it is to be understood that the appended claims are not necessarily limited to the specific features or methods described. Rather, the specific features and methods are disclosed as examples of implementations to enable hybrid deployment of an application that may selectively be accessed by the user from cloud datacentre or local datacentre.
Number | Date | Country | Kind |
---|---|---|---|
201611028348 | Aug 2016 | IN | national |