Embodiments of the subject matter described herein relate generally to computer systems configured to support on-demand applications, and more particularly, embodiments of the subject matter relate to methods and systems for communicating data provided by users or other external systems between an application server and a client via a proxy.
Modern software development is evolving away from the client-server model toward network-based processing systems that provide access to data and services via the Internet or other networks. In contrast to traditional systems that host networked applications on dedicated server hardware, a “cloud” computing model allows applications to be provided over the network “as a service” or “on-demand” by an infrastructure provider. The infrastructure provider typically abstracts the underlying hardware and other resources used to deliver a customer-developed application so that the customer no longer needs to operate and support dedicated server hardware. The cloud computing model can often provide substantial cost savings to the customer over the life of the application because the customer no longer needs to provide dedicated network infrastructure, electrical and temperature controls, physical security and other logistics in support of dedicated server hardware.
Multi-tenant cloud-based architectures have been developed to improve collaboration, integration, and community-based cooperation between customer tenants without sacrificing data security. Generally speaking, multi-tenancy refers to a system where a single hardware and software platform simultaneously supports multiple user groups (also referred to as “organizations” or “tenants”) from a common data storage element (also referred to as a “multi-tenant database”). The multi-tenant design provides a number of advantages over conventional server virtualization systems. First, the multi-tenant platform operator can often make improvements to the platform based upon collective information from the entire tenant community. Additionally, because all users in the multi-tenant environment execute applications within a common processing space, it is relatively easy to grant or deny access to specific sets of data for any user within the multi-tenant platform, thereby improving collaboration and integration between applications and the data managed by the various applications. The multi-tenant architecture therefore allows convenient and cost effective sharing of similar application features between multiple sets of users.
In practice, multi-tenant systems may service any number of users and/or tenants in any number of jurisdictions. In this regard, an individual jurisdiction may impose legal restrictions on what data is allowed to be transmitted and/or stored outside that jurisdiction or the manner in which that data is to be transmitted and/or stored. For example, a jurisdiction may require certain types of data (e.g., personal identification numbers and/or other personal information) be cryptographically obscured if that data is to be transmitted outside the jurisdiction. However, this data modification may impair the ability of the multi-tenant platform operator to adequately perform security-related operations or other data management functionality that would otherwise be performed on unencrypted data, which, in turn, could create vulnerabilities within the multi-tenant system.
A more complete understanding of the subject matter may be derived by referring to the detailed description and claims when considered in conjunction with the following figures, wherein like reference numbers refer to similar elements throughout the figures.
Embodiments of the subject matter described herein generally relate to communicating data between an application server and a client device via a proxy. In the exemplary embodiments described herein, the application server and the client device communicate via a proxy server that supports a firewall application that encrypts at least some input data received from the client device. For example, the firewall application may encrypt certain types of data to comply with data residency rules or other restrictions specific to the client device or the jurisdiction where the client device and/or the proxy server resides. As described in greater detail below, authentication protocols are established between the application server and the proxy server so that the application server can authenticate data as being received from a proxy server that performs encryption and securely encode the received data for one or more post-decryption actions in a manner that prevents any potentially malicious code and/or script contained within the input data from interfering with the proxy server and/or the client device performing the post-decryption action(s) on the input data. In one or more embodiments, the application server updates the virtual application provided to the client device in response to the received input data but bypasses performing one or more actions that would otherwise be performed on the request in response to authenticating the request as being received from the proxy server. In this regard, the application server encodes the encrypted data for the bypassed action(s) using an encoding authentication protocol established with the proxy server and provides the encoded encrypted data to the proxy server.
The proxy server decodes the encoded encrypted data in a manner that is influenced by the encoding authentication protocol to recognize or otherwise identify the post-decryption action(s), decrypts the encrypted data, and then performs the post-decryption action(s) on the decrypted data and provides the result to the client device. In this manner, the proxy server performs any actions that were bypassed by the application server on the decrypted data, such as, a security action normally performed by the application server that may not function properly when performed on encrypted (or partially encrypted) data. For example, if the input data includes malicious code and/or script, after encryption, the malicious code and/or script may be obscured from the application server, and as a result, the application server may not be able to detect and disable the malicious code and/or script.
In one or more embodiments, the application server is part of a multi-tenant system and provides instances of the virtual application to multiple different tenants supported by a multi-tenant database coupled to the application server. However, it should be noted that although the subject matter may be described herein in the context of a multi-tenant implementation, the subject matter is not intended to be limited to multi-tenant systems unless clearly indicated by the context.
As used herein, encrypting or variants thereof should be understood as referring to the process of obscuring or otherwise transforming data and/or information using one or more algorithms and/or keys such that the original data and/or information is effectively unreadable to any entity that does not have knowledge of the algorithms and/or keys. Thus, encrypted data is data that has been transformed from its original state to obscure it from third-parties. Conversely, encoding or variants thereof should be understood as referring to the process of coding or otherwise marking data and/or information using an encoding scheme (or markup language) to obtain one or more code segments containing the data and/or information in accordance with the encoding scheme (or markup language), wherein the one or more code segments are readable and/or executable by any entity having knowledge of the encoding scheme (or markup language).
Turning now to
As illustrated in
In the illustrated embodiment of
The client device 106 generally represents an electronic device that is utilized by a user to access the virtual application 104 and input and/or receive data pertaining to the virtual application 104. In practice, the client device 106 can be realized as any sort of personal computer, mobile telephone, tablet or other network-enabled electronic device. In an exemplary embodiment, the client device 106 includes a display device, such as a monitor, screen, or another conventional electronic display, capable of graphically presenting data and/or information provided by the virtual application 104 (including data retrieved from the database 110) along with a user input device, such as a keyboard, a mouse, a touchscreen, or the like, capable of receiving input data and/or other information from the user of the client device 106, as described in greater detail below. In an exemplary embodiment, the user manipulates the client device 106 to execute a web browser application 116 and contact the application server 102 via the proxy server 108 using a networking protocol, such as the hypertext transport protocol (HTTP) or the like, to request access to the virtual application 104, wherein the application server 102 authenticates the user and generates the virtual application 104 at run time based upon information provided by the user of the client device 106 and/or data associated with the user (or the user's tenant) maintained by the database 110. As described below, the virtual application 104 includes code, data and/or other dynamic web content provided to the client device 106 that can be parsed, executed or otherwise presented by the browser application 116 running on the client device 106.
Still referring to
In exemplary embodiments, the client device 106 and/or the browser application 116 is configured to establish a connection 120 with the proxy server 108 and/or the firewall application 118 over the network 114 to request access to the application server 102 and/or the virtual application 104. In response, the proxy server 108 and/or firewall application 118 establishes the connection 122 with the application server 102 over the network 112 to receive and provide the requested code, data, and or other information pertaining to the virtual application 104 to the browser application 116. It should be appreciated that, in practice, the firewall application 118 may perform various traffic management and/or monitoring, caching, filtering, and other routing operations, such as, for example, transport (e.g., layer 4) and/or network (e.g., layer 3) layer firewall functionality (e.g., IP-based and/or port-based filtering, logic, or the like).
In exemplary embodiments, the firewall application 118 provides application level firewall functionality (e.g., layer 5+), for example, by performing operations on traffic specific to the virtual application 104 based on the logic and/or other information provided by the virtual application 104 and/or the browser application 116, as described in greater detail below in the context of
Referring to
Additionally, in exemplary embodiments, the applications 104, 118 establish a server encoding authentication protocol that is utilized by the firewall application 118 and/or the proxy server 108 to authenticate, identify, or otherwise distinguish the post-decryption action(s) to be performed. In this regard, the server encoding authentication protocol indicates the manner in which the application server 102 and/or virtual application 104 will mark or otherwise sign data communicated to the firewall application 118 and/or the proxy server 108 for post-decryption action(s) by the firewall application 118 and/or the proxy server 108. Thus, the server encoding authentication protocol allows the firewall application 118 and/or the proxy server 108 to recognize, distinguish, or otherwise identify the post-decryption action(s) encoded by the application server 102 and/or virtual application 104 from other data and/or requests received by the firewall application 118 and/or the proxy server 108. For example, in one embodiment, the application server 102 and/or virtual application 104 may utilize its own unique identifier to mark or otherwise sign the encoding for a post-decryption action in a manner that allows the firewall application 118 to distinguish the post-decryption action marked by the server 102 from the remainder of the data that the post-decryption action is intended to be performed on. In this regard, the application server 102 provides its unique identifier to the firewall application 118, which, in turn, utilizes the identifier to recognize the post-decryption action(s) marked by the application server 102 in a manner that allows the firewall application 118 to perform the post-decryption action(s) on the data marked for the post-decryption action(s). In this manner, the browser application 116 may be protected from inadvertently executing code or script that could potentially be injected within the data by a malicious third-party entity attempting to compromise the application domain restrictions on the client device 106 (e.g., cross-site scripting or the like) when the browser application 116 fails to recognize the identifier for the application server 102 within the code or script injected within the data by a malicious third-party entity. In another embodiment, the virtual application 104 may provide the firewall application 118 with a hashing algorithm, a conversion algorithm, cryptographic keys, or some other means for securely obscuring the data that is encoded for post-decryption action(s) by the virtual application 104. In this regard, the virtual application 104 may hash or otherwise convert the data being encoded to a different representation (e.g., from string to hexadecimal) in a manner that prevents potentially malicious code from falsely indicating post-decryption action(s) to be executed by firewall application 118 and/or the proxy server 108, as described in greater detail below. It should be noted that there are numerous potential protocols that may be utilized (either individually or in combination) to mark, sign, or otherwise data in a manner that prevents code within the data from being confused as originating from an authenticated application server, and the subject matter described herein is not intended to be limited to any particular protocol.
In an exemplary embodiment, the proxy firewall process 200 continues by receiving data input by a user of a client device, encrypting at least a portion of the input data, and providing the encrypted data along with authentication information to the application server for further processing (tasks 204, 206, 208). For example, after establishing the authentication protocols, the firewall application 118 provides data, code and/or other information received from the application server 102 that corresponds to the virtual application 104 to the browser application 116 for execution and/or presentation by the client device 106. The data, code and/or other information received from the application server 102 may be executed or otherwise processed by the browser application 116 to present a display corresponding to the virtual application 104. The display corresponding to the virtual application 104 may include data and/or other information associated with the user obtained from the database 110 along with text boxes, data input fields, or other graphical user interface (GUI) elements for receiving data from the user. Subsequently, the user may manipulate a user input device associated with the client device 106 to input or otherwise provide data and/or information to the virtual application 104 for further processing and/or storing in the database 110. Once the data has been input by the user, the browser application 116 transmits the user input data to the firewall application 118 and/or proxy server 108 for transmission to the application server 102.
In exemplary embodiments, the firewall application 118 utilizes one or more cryptographic keys and/or algorithms to encrypt the user input data before transmitting it to the application server 102. In accordance with one or more embodiments, the firewall application 118 performs one or more algorithms to analyze the user input data to determine if any portions of the user input data are to be encrypted. In this regard, the virtual application 104 may provide the firewall application 118 with context information and/or other logic that may be utilized to identify the type(s) of user input data provided by the user, wherein the firewall application 118 determines if any of the types of received user input data should be encrypted, based on, for example, data residency rules, regulations or other restrictions provided for the jurisdiction where the proxy server 108 and/or the client device 106 resides. For example, the proxy server 108 and/or the client device 106 may reside in a jurisdiction where a user's government issued personal identification number (e.g., a Social Security number or the like) cannot be electronically transmitted and/or stored outside the jurisdiction without being encrypted, and the virtual application 104 may identify a particular data input field as corresponding to the government issued personal identification number, wherein the firewall application 118 identifies and encrypts received user input data corresponding to the user's government issued personal identification number. The firewall application 118 continues by adding or otherwise appending the unique identifier or other authentication information corresponding to the firewall application 118 and/or the proxy server 108 to the encrypted user input data before transmitting the encrypted user input data to the application server 102. For example, the firewall application 118 may construct a message that contains the encrypted user input data and has a message header that includes the unique identifier associated with the firewall application 118 and/or proxy server 108.
As described in greater detail below in the context of
Still referring to
In exemplary embodiments, the proxy firewall process 200 continues by decoding the encoded data received from the application server based on the server encoding authentication protocol, decrypting the encrypted data, performing the identified post-decryption action(s) on the decrypted data, and providing the result of the post-decryption action to the client device for subsequent execution and/or presentation (tasks 212, 214, 216, 218). In this regard, based on the server encoding authentication protocol, the firewall application 118 and/or proxy server 108 identifies the desired post-decryption action(s) and the data that the post-decryption action(s) is to be performed on. For example, when the application server 102 marks the post-decryption action with a unique identifier or another signature associated with the application server 102, the firewall application 118 parses the encoded data received from the application server 102 to identify or otherwise distinguish between the portion of the received data that corresponds to the encrypted user input data and the encoding for the desired post-decryption action(s). For example, the firewall application 118 may parse the data received from the application server 102 and utilize the unique identifier associated with the application server 102 to identify the operators for the post-decryption action and the portion of the received data between the operators as the encrypted user input data that the post-decryption action is to be performed on. In another embodiment, when the application server 102 obscures the encrypted user input data as the parameter of the post-decryption function, the firewall application 118 identifies the encoding for the post-decryption function, decodes the remainder of the received data based on the server encoding authentication protocol, and identifies the result of the decoding as the encrypted user input data. For example, the firewall application 118 may identify the operators for the desired post-decryption action and decode the portion of the received data between the operators based on the server encoding authentication protocol (e.g., by converting the parameter from hexadecimal representation to a string representation) to obtain the encrypted user input data.
After decoding the encoded encrypted data and identifying or otherwise distinguishing the post-decryption action(s) from the remaining data, the firewall application 118 decrypts the portion of the received data identified as the encrypted data, performs the identified post-decryption action on the decrypted user input data, and then provides the result of the post-decryption action to the browser application 116 for execution and/or presentation by the client device 106. By virtue of the authentication protocols between the servers 102, 108, the identified post-decryption action(s) are performed on any potentially malicious code and/or script contained within the original user input, so that the firewall application 118 can escape, discard, or otherwise prevent the malicious code and/or script from being provided to and/or executed by the client device 106, as described in greater detail below. In exemplary embodiments, the loop defined by tasks 204, 206, 208, 210, 212, 214, 216 and 218 repeats while the virtual application 104 is being provided to the client device 106 during operation of the application system 100 to prevent cross-site scripting or other malicious attacks on the application system 100.
Referring to
After establishing authentication protocols with a firewall application on a proxy server, the secure encoding process 300 continues by generating an instance of a virtual application that is accessed by or otherwise provided to a client device via the proxy server (task 304). As described above, after authenticating the user of the client device 106 and establishing authentication protocols with the firewall application 118 on the proxy server 108, the application server 102 obtains data and/or information from the database 110 that is associated with the request from the user, generates an instance of the virtual application 104 based at least in part on the obtained data, and provides the code, script, data and/or other information pertaining to the instance of the virtual application 104 to the browser application 116 via the firewall application 118 for execution and/or presentation by the client device 106.
In an exemplary embodiment, the secure encoding process 300 continues by receiving user input data from the firewall application on the proxy server, authenticating the received data as being from the firewall application on the proxy server, and further processing the encrypted data without performing one or more action(s) that would otherwise be performed on the encrypted data in response to authenticating the data as being from the firewall application on the proxy server (tasks 306, 308, 310). For example, as described above, the virtual application 104 presented within the browser application 116 may include text boxes, data input fields, or other GUI elements for receiving data from the user, wherein the user manipulates a user input device associated with the client device 106 to input or otherwise provide data and/or information to the virtual application 104 for further processing and/or storing in the database 110. The browser application 116 may encode the user input data based on the logic and/or context of the virtual application 104 and provides the encoded user input data to the firewall application 118, wherein the firewall application 118 performs one or more algorithms using the logic and/or context of the virtual application 104 and one or more cryptography rules (e.g., data residency rules, regulations or other restrictions applicable to the client device 106 and/or the proxy server 108) to analyze the user input data, determine whether any portion of the user input data should be encrypted (e.g., to comply with data residency regulations or other legal restrictions), and encrypt portions of the user input data that should be encrypted. After encrypting the user input data, the firewall application 118 transmits the encrypted user input data to the application server 102 in accordance with the proxy authentication protocol, for example, by constructing a message including a header that includes the unique identifier assigned to the proxy server 108 to identify the message as containing encrypted user input data from the firewall application 118. The application server 102 and/or virtual application 104 receives the message from the firewall application 118 and analyzes the message header to determine whether the message header includes an identifier associated with a proxy server in the application system 100.
When the application server 102 and/or virtual application 104 authenticates the received data and/or message as being from a application 118 on a server 108 that performs encryption, the application server 102 and/or virtual application 104 performs processing on the received data and/or message to update the virtual application 104 in accordance with the logic and/or context of the virtual application 104 while bypassing one or more actions in response to authenticating the data as being from the firewall application 118 on the proxy server 108. For example, the application server 102 and/or virtual application 104 may store the encrypted user input data in the database 110 or manipulate the presentation of the encrypted user input data within the virtual application 104 without performing security actions or other analysis of the content of the received data and/or message that are not intended to be applied to encrypted data. In this manner, the application server 102 may integrate the received input data into the virtual application 104 without decrypting the data or otherwise analyzing the contents of the received input data that is authenticated as being from an encrypting firewall application 118 on a proxy server 108. For example, for unencrypted data, the application server 102 and/or virtual application 104 may parse the data to detect malicious code and/or script that should be escaped to prevent execution by the client device 106 as if the code and/or script were being provided by the virtual application 104 (e.g., cross-site scripting). However, when the encrypted data includes malicious code and/or script, the malicious code and/or script is also encrypted, thereby preventing it from being detected and escaped by the application server 102 and/or virtual application 104. Thus, the application server 102 performs one or more actions to generate updated code, script, data and/or other dynamic web content for the virtual application 104 that integrates or is otherwise influenced by the authenticated encrypted user input data without performing one or more security actions to analyze the contents of the authenticated data.
Still referring to
After the application server 102 and/or virtual application 104 securely encodes the authenticated data previously received from the firewall application 118 and/or proxy server 108, the application server 102 and/or virtual application 104 transmits the encoded encrypted data to the proxy server 108 for subsequent processing by the firewall application 118. As described above, in addition to other data traffic management actions that may be performed by the firewall application 118, the firewall application 118 identifies the encrypted data and the desired post-decryption action(s) based on the server encoding authentication protocol established with the application server 102, decrypts the encrypted data, and performs the desired post-decryption action(s) on the decrypted data before providing the data to the client device 106 for execution and/or presentation by the browser application 116. In this manner, if the encrypted user input data includes malicious code and/or script, the firewall application 118 performs action(s) on the decrypted user input data indicated by the application server 102 and/or virtual application 104 to detect or otherwise identify the malicious code and/or script and perform one or more remedial actions (e.g., escaping the decrypted data) to prevent execution of the malicious code and/or script by the client device 106.
In an exemplary embodiment, after the servers 102, 108 establish the authentication protocols to be used during subsequent operation of the application system 100, a user of the client device 106 manipulates the browser application 116 to communicate, to the proxy server 108, a request 404 to access the application server 102. In an exemplary embodiment, the request transmitted by the client device 106 includes user information (e.g., a user name, a password, and the like) associated with the user of the client device 106 that is utilized by the application server 102 to authenticate the user before providing data and/or services to the user. In response to the request from the client device 106, the firewall application 118 on the proxy server 108 provides 406 the user information to the application server 102, wherein the application server 102 authenticates the user based on the user information, obtains 408 data from the database 110 that is associated with the user (or the user's tenant) or other data corresponding to the request, and generates an instance of a virtual application 104 based at least in part on the data obtained from the database 110. As described above, the virtual application 104 is provided to the user of the client device 106 via the proxy server 108 by the application server 102 transmitting 410 code, data and/or other dynamic web content to the proxy server 108, which, in turn, is transmitted 412 by the proxy server 108 to the client device 106 and executed by the browser application 116 on the client device 106 to present GUI elements, data, and/or other information pertaining to the virtual application 104 on the client device 106 within the browser application 116.
As described above, the user of the client device 106 manipulates a user input device to input or otherwise provide data and/or information to the virtual application 104 for further processing and/or storing in the database 110. After the user finishes providing the input data, the browser application 116 encodes the user input data based on the logic and/or context of the virtual application 104 and transmits 414 the user input data to the firewall application 118, which performs one or more algorithms using the logic and/or context of the virtual application 104 and one or more data residency rules to identify portions of the user input data that should be encrypted. The firewall application 118 encrypts those portions of the user input data and transmits 416 the encrypted user input data to the application server 102 by constructing a message containing the encrypted user input data and a header that includes the unique identifier or other authentication information assigned to the proxy server 108. The application server 102 receives the message from the firewall application 118, analyzes the message header, and after authenticating the data as encrypted user input data received from the firewall application 118 on the proxy server 108, the application server 102 stores, manipulates, or otherwise processes 418 the encrypted user input data based on the logic and/or context of the virtual application 104 by performing one or more actions to update the virtual application 104 in response to the authenticated input data while bypassing one or more actions that would otherwise be performed on the encrypted user input data if it were not authenticated as being from the proxy server 108. For example, the server 102 may store the received user input data in the database 110 and/or obtain additional data from the database 110 to generate updated web content incorporating the authenticated user input data for subsequent display on the client device 106.
After performing one or more actions on the authenticated user input data, the application server 102 encodes the authenticated user input data for the bypassed action(s) before transmitting 420 the encoded encrypted user input data to the proxy server 108. As described above, in one embodiment, the application server 102 uses a unique identifier or other signature mechanism to encode the data in a manner that allows the firewall application 118 to identify or otherwise distinguish code and/or script generated by the application server 102 from potentially malicious code and/or script generated by a third party, for example, by adding the unique identifier associated with the application server 102 (“uniqueid”) before the encoding operators for the bypassed action (e.g., “uniqueidSTART_HTMLESCAPE ENCRYPTED_USER_INPUT uniqueidEND_HTMLESCAPE”). In another embodiment, the application server 102 performs a conversion algorithm to convert the authenticated user input data to a different representation before encoding the authenticated encrypted user input data for the bypassed action, such as, for example, a string to hexadecimal conversion algorithm (e.g., “START_HTMLESCAPE 454e435259505445445f555345525f494e505554 END_HTMLESCAPE”).
As described above, the firewall application 118 on the proxy server 108 receives the encoded encrypted data from the application server 102, decodes the encoded encrypted data based on the server encoding authentication protocol to identify the encrypted data and the desired post-decryption action(s), decrypts the encrypted data, then performs the identified post-decryption action(s) on the decrypted data. In this regard, if the decrypted data includes potentially malicious code and/or script that has been encrypted, the firewall application 118 performs the action(s) bypassed by the server 102 after decryption to detect the code and/or script and prevent the code and/or script from being subsequently executed by the client device 106. For example, if the bypassed action is an escape HTML function, the firewall application 118 parses the decrypted data for any HTML code and/or script and escapes the data rather than providing the decrypted data to the client device 106. When the firewall application 118 finishes performing the post-decryption action(s) on the decrypted data, the firewall application 118 transmits 422 the result to the client device 106 for execution and/or display by the browser application 116.
Referring now to
The illustrated multi-tenant system 500 of
As used herein, a “tenant” or an “organization” should be understood as referring to a group of one or more users that shares access to common subset of the data within the multi-tenant database 530. In this regard, each tenant includes one or more users associated with, assigned to, or otherwise belonging to that respective tenant. To put it another way, each respective user within the multi-tenant system 500 is associated with, assigned to, or otherwise belongs to a particular tenant of the plurality of tenants supported by the multi-tenant system 500. Tenants may represent customers, customer departments, business or legal organizations, and/or any other entities that maintain data for particular sets of users within the multi-tenant system 500. Although multiple tenants may share access to the server 502 and the database 530, the particular data and services provided from the server 502 to each tenant can be securely isolated from those provided to other tenants. The multi-tenant architecture therefore allows different sets of users to share functionality and hardware resources without necessarily sharing any of the data 532 belonging to or otherwise associated with other tenants.
The multi-tenant database 530 is any sort of repository or other data storage system capable of storing and managing the data 532 associated with any number of tenants. The database 530 may be implemented using any type of conventional database server hardware. In various embodiments, the database 530 shares processing hardware 504 with the server 502. In other embodiments, the database 530 is implemented using separate physical and/or virtual database server hardware that communicates with the server 502 to perform the various functions described herein. In an exemplary embodiment, the database 530 includes a database management system or other equivalent software capable of determining an optimal query plan for retrieving and providing a particular subset of the data 532 to an instance of virtual application 528 in response to a query initiated or otherwise provided by a virtual application 528. The multi-tenant database 530 may alternatively be referred to herein as an on-demand database, in that the multi-tenant database 530 provides (or is available to provide) data at run-time to on-demand virtual applications 528 generated by the application platform 510.
In practice, the data 532 may be organized and formatted in any manner to support the application platform 510. In various embodiments, the data 532 is suitably organized into a relatively small number of large data tables to maintain a semi-amorphous “heap”-type format. The data 532 can then be organized as needed for a particular virtual application 528. In various embodiments, conventional data relationships are established using any number of pivot tables 534 that establish indexing, uniqueness, relationships between entities, and/or other aspects of conventional database organization as desired. Further data manipulation and report formatting is generally performed at run-time using a variety of metadata constructs. Metadata within a universal data directory (UDD) 536, for example, can be used to describe any number of forms, reports, workflows, user access privileges, business logic and other constructs that are common to multiple tenants. Tenant-specific formatting, functions and other constructs may be maintained as tenant-specific metadata 538 for each tenant, as desired. Rather than forcing the data 532 into an inflexible global structure that is common to all tenants and applications, the database 530 is organized to be relatively amorphous, with the pivot tables 534 and the metadata 538 providing additional structure on an as-needed basis. To that end, the application platform 510 suitably uses the pivot tables 534 and/or the metadata 538 to generate “virtual” components of the virtual applications 528 to logically obtain, process, and present the relatively amorphous data 532 from the database 530.
The server 502 is implemented using one or more actual and/or virtual computing systems that collectively provide the dynamic application platform 510 for generating the virtual applications 528. For example, the server 502 may be implemented using a cluster of actual and/or virtual servers operating in conjunction with each other, typically in association with conventional network communications, cluster management, load balancing and other features as appropriate. The server 502 operates with any sort of conventional processing hardware 504, such as a processor 505, memory 506, input/output features 507 and the like. The input/output features 507 generally represent the interface(s) to networks (e.g., to the network 545, or any other local area, wide area or other network), mass storage, display devices, data entry devices and/or the like. The processor 505 may be implemented using any suitable processing system, such as one or more processors, controllers, microprocessors, microcontrollers, processing cores and/or other computing resources spread across any number of distributed or integrated systems, including any number of “cloud-based” or other virtual systems. The memory 506 represents any non-transitory short or long term storage or other computer-readable media capable of storing programming instructions for execution on the processor 505, including any sort of random access memory (RAM), read only memory (ROM), flash memory, magnetic or optical mass storage, and/or the like. The computer-executable programming instructions, when read and executed by the server 502 and/or processor 505, cause the server 502 and/or processor 505 to create, generate, or otherwise facilitate the application platform 510 and/or virtual applications 528 and perform one or more additional tasks, operations, functions, and/or processes described herein. It should be noted that the memory 506 represents one suitable implementation of such computer-readable media, and alternatively or additionally, the server 502 could receive and cooperate with external computer-readable media that is realized as a portable or mobile component or platform, e.g., a portable hard drive, a USB flash drive, an optical disc, or the like.
The application platform 510 is any sort of software application or other data processing engine that generates the virtual applications 528 that provide data and/or services to the client devices 540. In a typical embodiment, the application platform 510 gains access to processing resources, communications interfaces and other features of the processing hardware 504 using any sort of conventional or proprietary operating system 508. The virtual applications 528 are typically generated at run-time in response to input received from the client devices 540. For the illustrated embodiment, the application platform 510 includes a bulk data processing engine 512, a query generator 514, a search engine 516 that provides text indexing and other search functionality, and a runtime application generator 520. Each of these features may be implemented as a separate process or other module, and many equivalent embodiments could include different and/or additional features, components or other modules as desired.
The runtime application generator 520 dynamically builds and executes the virtual applications 528 in response to specific requests received from the client devices 540. The virtual applications 528 are typically constructed in accordance with the tenant-specific metadata 538, which describes the particular tables, reports, interfaces and/or other features of the particular application 528. In various embodiments, each virtual application 528 generates dynamic web content that can be served to a browser or other client program 542 associated with its client device 540, as appropriate.
The runtime application generator 520 suitably interacts with the query generator 514 to efficiently obtain multi-tenant data 532 from the database 530 as needed in response to input queries initiated or otherwise provided by users of the client devices 540. In a typical embodiment, the query generator 514 considers the identity of the user requesting a particular function (along with the user's associated tenant), and then builds and executes queries to the database 530 using system-wide metadata 536, tenant specific metadata 538, pivot tables 534, and/or any other available resources. The query generator 514 in this example therefore maintains security of the common database 530 by ensuring that queries are consistent with access privileges granted to the user and/or tenant that initiated the request. In this manner, the query generator 514 suitably obtains requested subsets of data 532 accessible to a user and/or tenant from the database 530 as needed to populate the tables, reports or other features of the particular virtual application 528 for that user and/or tenant.
Still referring to
In exemplary embodiments, the application platform 510 is utilized to create and/or generate data-driven virtual applications 528 for the tenants that they support. Such virtual applications 528 may make use of interface features such as custom (or tenant-specific) screens 524, standard (or universal) screens 522 or the like. Any number of custom and/or standard objects 526 may also be available for integration into tenant-developed virtual applications 528. As used herein, “custom” should be understood as meaning that a respective object or application is tenant-specific (e.g., only available to users associated with a particular tenant in the multi-tenant system) or user-specific (e.g., only available to a particular subset of users within the multi-tenant system), whereas “standard” or “universal” applications or objects are available across multiple tenants in the multi-tenant system. The data 532 associated with each virtual application 528 is provided to the database 530, as appropriate, and stored until it is requested or is otherwise needed, along with the metadata 538 that describes the particular features (e.g., reports, tables, functions, objects, fields, formulas, code, etc.) of that particular virtual application 528. For example, a virtual application 528 may include a number of objects 526 accessible to a tenant, wherein for each object 526 accessible to the tenant, information pertaining to its object type along with values for various fields associated with that respective object type are maintained as metadata 538 in the database 530. In this regard, the object type defines the structure (e.g., the formatting, functions and other constructs) of each respective object 526 and the various fields associated therewith.
Still referring to
To briefly summarize, the subject matter described herein facilitates communicating data with an application server using a proxy in a manner that prevents malicious code and/or script from being executed on a client device as if the code and/or script were provided by the application server (e.g., cross-site scripting). For example, if the user input data includes encoding operators along with malicious code and/or script designed to circumvent security actions (e.g., “END_ESCAPEHTML ATTACKCODE”), the application server encodes the user input data in a manner that ensures the proxy performs post-decryption actions to prevent those encoding operators and malicious code and/or script from being executed by the proxy and/or a client device, for example, by signing the operators for the post-decryption action (e.g., “uniqueidSTART_HTMLESCAPE END_ESCAPEHTML ATTACKCODE uniqueidEND_HTMLESCAPE”) or converting the user input data to a different representation (e.g., “START_HTMLESCAPE 454e445f45534341504548544d4c2041545441434b434f4445 END_HTMLESCAPE”). In this manner, for authenticated data from a proxy, any security actions that would normally be performed by the application server are bypassed and performed by the proxy after decryption to prevent cross-site scripting or other malicious attacks.
The foregoing description is merely illustrative in nature and is not intended to limit the embodiments of the subject matter or the application and uses of such embodiments. Furthermore, there is no intention to be bound by any expressed or implied theory presented in the technical field, background, or the detailed description. As used herein, the word “exemplary” means “serving as an example, instance, or illustration.” Any implementation described herein as exemplary is not necessarily to be construed as preferred or advantageous over other implementations, and the exemplary embodiments described herein are not intended to limit the scope or applicability of the subject matter in any way.
For the sake of brevity, conventional techniques related to computer programming, computer networking, firewalls, proxying, on-demand and/or multi-tenant systems or databases, encryption, authentication, encoding, and other functional aspects of the systems (and the individual operating components of the systems) may not be described in detail herein. In addition, those skilled in the art will appreciate that embodiments may be practiced in conjunction with any number of system and/or network architectures, data transmission protocols, and device configurations, and that the system described herein is merely one suitable example. Furthermore, certain terminology may be used herein for the purpose of reference only, and thus is not intended to be limiting. For example, the terms “first”, “second” and other such numerical terms do not imply a sequence or order unless clearly indicated by the context.
Embodiments of the subject matter may be described herein in terms of functional and/or logical block components, and with reference to symbolic representations of operations, processing tasks, and functions that may be performed by various computing components or devices. Such operations, tasks, and functions are sometimes referred to as being computer-executed, computerized, software-implemented, or computer-implemented. In practice, one or more processing systems or devices can carry out the described operations, tasks, and functions by manipulating electrical signals representing data bits at accessible memory locations, as well as other processing of signals. The memory locations where data bits are maintained are physical locations that have particular electrical, magnetic, optical, or organic properties corresponding to the data bits. It should be appreciated that the various block components shown in the figures may be realized by any number of hardware, software, and/or firmware components configured to perform the specified functions. For example, an embodiment of a system or a component may employ various integrated circuit components, e.g., memory elements, digital signal processing elements, logic elements, look-up tables, or the like, which may carry out a variety of functions under the control of one or more microprocessors or other control devices. When implemented in software or firmware, various elements of the systems described herein are essentially the code segments or instructions that perform the various tasks. The program or code segments can be stored in a processor-readable medium or transmitted by a computer data signal embodied in a carrier wave over a transmission medium or communication path. The “processor-readable medium” or “machine-readable medium” may include any non-transitory medium that can store or transfer information. Examples of the processor-readable medium include an electronic circuit, a semiconductor memory device, a ROM, a flash memory, an erasable ROM (EROM), a floppy diskette, a CD-ROM, an optical disk, a hard disk, a fiber optic medium, a radio frequency (RF) link, or the like. The computer data signal may include any signal that can propagate over a transmission medium such as electronic network channels, optical fibers, air, electromagnetic paths, or RF links. The code segments may be downloaded via computer networks such as the Internet, an intranet, a LAN, or the like. In this regard, the subject matter described herein can be implemented in the context of any computer-implemented system and/or in connection with two or more separate and distinct computer-implemented systems that cooperate and communicate with one another. In one or more exemplary embodiments, the subject matter described herein is implemented in conjunction with a virtual customer relationship management (CRM) application in a multi-tenant environment.
While at least one exemplary embodiment has been presented in the foregoing detailed description, it should be appreciated that a vast number of variations exist. It should also be appreciated that the exemplary embodiment or embodiments described herein are not intended to limit the scope, applicability, or configuration of the claimed subject matter in any way. Rather, the foregoing detailed description will provide those skilled in the art with a convenient road map for implementing the described embodiment or embodiments. It should be understood that various changes can be made in the function and arrangement of elements without departing from the scope defined by the claims, which includes known equivalents and foreseeable equivalents at the time of filing this patent application. Accordingly, details of the exemplary embodiments or other limitations described above should not be read into the claims absent a clear intention to the contrary.
This application claims the benefit of U.S. provisional patent application Ser. No. 61/544,388, filed Oct. 7, 2011, the entire content of which is incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
5577188 | Zhu | Nov 1996 | A |
5608872 | Schwartz et al. | Mar 1997 | A |
5649104 | Carleton et al. | Jul 1997 | A |
5715450 | Ambrose et al. | Feb 1998 | A |
5761419 | Schwartz et al. | Jun 1998 | A |
5819038 | Carleton et al. | Oct 1998 | A |
5821937 | Tonelli et al. | Oct 1998 | A |
5831610 | Tonelli et al. | Nov 1998 | A |
5873096 | Lim et al. | Feb 1999 | A |
5918159 | Fomukong et al. | Jun 1999 | A |
5963953 | Cram et al. | Oct 1999 | A |
6092083 | Brodersen et al. | Jul 2000 | A |
6161149 | Achacoso et al. | Dec 2000 | A |
6169534 | Raffel et al. | Jan 2001 | B1 |
6178425 | Brodersen et al. | Jan 2001 | B1 |
6189011 | Lim et al. | Feb 2001 | B1 |
6216135 | Brodersen et al. | Apr 2001 | B1 |
6233617 | Rothwein et al. | May 2001 | B1 |
6266669 | Brodersen et al. | Jul 2001 | B1 |
6295530 | Ritchie et al. | Sep 2001 | B1 |
6324568 | Diec et al. | Nov 2001 | B1 |
6324693 | Brodersen et al. | Nov 2001 | B1 |
6336137 | Lee et al. | Jan 2002 | B1 |
D454139 | Feldcamp et al. | Mar 2002 | S |
6367077 | Brodersen et al. | Apr 2002 | B1 |
6393605 | Loomans | May 2002 | B1 |
6405220 | Brodersen et al. | Jun 2002 | B1 |
6434550 | Warner et al. | Aug 2002 | B1 |
6446089 | Brodersen et al. | Sep 2002 | B1 |
6480850 | Veldhuisen | Nov 2002 | B1 |
6535909 | Rust | Mar 2003 | B1 |
6549908 | Loomans | Apr 2003 | B1 |
6553563 | Ambrose et al. | Apr 2003 | B2 |
6560461 | Fomukong et al. | May 2003 | B1 |
6574635 | Stauber et al. | Jun 2003 | B2 |
6577726 | Huang et al. | Jun 2003 | B1 |
6601087 | Zhu et al. | Jul 2003 | B1 |
6604117 | Lim et al. | Aug 2003 | B2 |
6604128 | Diec | Aug 2003 | B2 |
6609150 | Lee et al. | Aug 2003 | B2 |
6621834 | Scherpbier et al. | Sep 2003 | B1 |
6654032 | Zhu et al. | Nov 2003 | B1 |
6665648 | Brodersen et al. | Dec 2003 | B2 |
6665655 | Warner et al. | Dec 2003 | B1 |
6684438 | Brodersen et al. | Feb 2004 | B2 |
6711565 | Subramaniam et al. | Mar 2004 | B1 |
6724399 | Katchour et al. | Apr 2004 | B1 |
6728702 | Subramaniam et al. | Apr 2004 | B1 |
6728960 | Loomans | Apr 2004 | B1 |
6732095 | Warshavsky et al. | May 2004 | B1 |
6732100 | Brodersen et al. | May 2004 | B1 |
6732111 | Brodersen et al. | May 2004 | B2 |
6754681 | Brodersen et al. | Jun 2004 | B2 |
6763351 | Subramaniam et al. | Jul 2004 | B1 |
6763501 | Zhu et al. | Jul 2004 | B1 |
6768904 | Kim | Jul 2004 | B2 |
6772229 | Achacoso et al. | Aug 2004 | B1 |
6782383 | Subramaniam et al. | Aug 2004 | B2 |
6804330 | Jones et al. | Oct 2004 | B1 |
6826565 | Ritchie et al. | Nov 2004 | B2 |
6826582 | Chatterjee et al. | Nov 2004 | B1 |
6826745 | Coker | Nov 2004 | B2 |
6829655 | Huang et al. | Dec 2004 | B1 |
6842748 | Warner et al. | Jan 2005 | B1 |
6850895 | Brodersen et al. | Feb 2005 | B2 |
6850949 | Warner et al. | Feb 2005 | B2 |
7062502 | Kesler | Jun 2006 | B1 |
7069231 | Cinarkaya et al. | Jun 2006 | B1 |
7069497 | Desai | Jun 2006 | B1 |
7140044 | Redlich | Nov 2006 | B2 |
7181758 | Chan | Feb 2007 | B1 |
7289976 | Kihneman et al. | Oct 2007 | B2 |
7340411 | Cook | Mar 2008 | B2 |
7356482 | Frankland et al. | Apr 2008 | B2 |
7401094 | Kesler | Jul 2008 | B1 |
7412455 | Dillon | Aug 2008 | B2 |
7508789 | Chan | Mar 2009 | B2 |
7603483 | Psounis et al. | Oct 2009 | B2 |
7620655 | Larsson et al. | Nov 2009 | B2 |
7698160 | Beaven et al. | Apr 2010 | B2 |
7725530 | Sah et al. | May 2010 | B2 |
7779475 | Jakobson et al. | Aug 2010 | B2 |
7851004 | Hirao et al. | Dec 2010 | B2 |
8014943 | Jakobson | Sep 2011 | B2 |
8015495 | Achacoso et al. | Sep 2011 | B2 |
8032297 | Jakobson | Oct 2011 | B2 |
8032764 | Shankar et al. | Oct 2011 | B2 |
8073850 | Hubbard et al. | Dec 2011 | B1 |
8082301 | Ahlgren et al. | Dec 2011 | B2 |
8095413 | Beaven | Jan 2012 | B1 |
8095594 | Beaven et al. | Jan 2012 | B2 |
8209308 | Rueben et al. | Jun 2012 | B2 |
8209333 | Hubbard et al. | Jun 2012 | B2 |
8275836 | Beaven et al. | Sep 2012 | B2 |
8347093 | Ahmed | Jan 2013 | B1 |
8457545 | Chan | Jun 2013 | B2 |
8484111 | Frankland et al. | Jul 2013 | B2 |
8490025 | Jakobson et al. | Jul 2013 | B2 |
8504945 | Jakobson et al. | Aug 2013 | B2 |
8510045 | Rueben et al. | Aug 2013 | B2 |
8510664 | Rueben et al. | Aug 2013 | B2 |
8566301 | Rueben et al. | Oct 2013 | B2 |
8646103 | Jakobson et al. | Feb 2014 | B2 |
8756275 | Jakobson | Jun 2014 | B2 |
8769004 | Jakobson | Jul 2014 | B2 |
8769017 | Jakobson | Jul 2014 | B2 |
8826443 | Raman | Sep 2014 | B1 |
8856869 | Brinskelle | Oct 2014 | B1 |
20010044791 | Richter et al. | Nov 2001 | A1 |
20020072951 | Lee et al. | Jun 2002 | A1 |
20020082892 | Raffel | Jun 2002 | A1 |
20020112167 | Boneh et al. | Aug 2002 | A1 |
20020129352 | Brodersen et al. | Sep 2002 | A1 |
20020140731 | Subramanian et al. | Oct 2002 | A1 |
20020143997 | Huang et al. | Oct 2002 | A1 |
20020162090 | Parnell et al. | Oct 2002 | A1 |
20020165742 | Robbins | Nov 2002 | A1 |
20030004971 | Gong | Jan 2003 | A1 |
20030018705 | Chen et al. | Jan 2003 | A1 |
20030018830 | Chen et al. | Jan 2003 | A1 |
20030028380 | Freeland et al. | Feb 2003 | A1 |
20030066031 | Laane et al. | Apr 2003 | A1 |
20030066032 | Ramachandran et al. | Apr 2003 | A1 |
20030069936 | Warner et al. | Apr 2003 | A1 |
20030070000 | Coker et al. | Apr 2003 | A1 |
20030070004 | Mukundan et al. | Apr 2003 | A1 |
20030070005 | Mukundan et al. | Apr 2003 | A1 |
20030074418 | Coker et al. | Apr 2003 | A1 |
20030120675 | Stauber et al. | Jun 2003 | A1 |
20030131259 | Barton et al. | Jul 2003 | A1 |
20030151633 | George et al. | Aug 2003 | A1 |
20030159136 | Huang et al. | Aug 2003 | A1 |
20030187921 | Diec et al. | Oct 2003 | A1 |
20030189600 | Gune et al. | Oct 2003 | A1 |
20030191799 | Araujo et al. | Oct 2003 | A1 |
20030204427 | Gune et al. | Oct 2003 | A1 |
20030204741 | Schoen et al. | Oct 2003 | A1 |
20030206192 | Chen et al. | Nov 2003 | A1 |
20030225730 | Warner et al. | Dec 2003 | A1 |
20040001092 | Rothwein et al. | Jan 2004 | A1 |
20040010489 | Rio et al. | Jan 2004 | A1 |
20040015981 | Coker et al. | Jan 2004 | A1 |
20040027388 | Berg et al. | Feb 2004 | A1 |
20040128001 | Levin et al. | Jul 2004 | A1 |
20040186860 | Lee et al. | Sep 2004 | A1 |
20040193510 | Catahan et al. | Sep 2004 | A1 |
20040199489 | Barnes-Leon et al. | Oct 2004 | A1 |
20040199536 | Barnes Leon et al. | Oct 2004 | A1 |
20040199543 | Braud et al. | Oct 2004 | A1 |
20040249854 | Barnes-Leon et al. | Dec 2004 | A1 |
20040260534 | Pak et al. | Dec 2004 | A1 |
20040260659 | Chan et al. | Dec 2004 | A1 |
20040268299 | Lei et al. | Dec 2004 | A1 |
20050050555 | Exley et al. | Mar 2005 | A1 |
20050091098 | Brodersen et al. | Apr 2005 | A1 |
20060021019 | Hinton et al. | Jan 2006 | A1 |
20060036551 | Oliveira et al. | Feb 2006 | A1 |
20060062362 | Davis | Mar 2006 | A1 |
20070239528 | Xie et al. | Oct 2007 | A1 |
20080082662 | Dandliker et al. | Apr 2008 | A1 |
20080126794 | Wang et al. | May 2008 | A1 |
20080147554 | Stevens | Jun 2008 | A1 |
20080235508 | Ran et al. | Sep 2008 | A1 |
20080249972 | Dillon | Oct 2008 | A1 |
20080307529 | Choi | Dec 2008 | A1 |
20090013399 | Cottrell et al. | Jan 2009 | A1 |
20090063415 | Chatfield et al. | Mar 2009 | A1 |
20090100342 | Jakobson | Apr 2009 | A1 |
20090113537 | Woo | Apr 2009 | A1 |
20090119579 | Fellenstein | May 2009 | A1 |
20090177744 | Marlow et al. | Jul 2009 | A1 |
20090178144 | Redlich et al. | Jul 2009 | A1 |
20090326791 | Horvitz et al. | Dec 2009 | A1 |
20100031023 | Dodd | Feb 2010 | A1 |
20100031299 | Harrang et al. | Feb 2010 | A1 |
20100125602 | Eisinger et al. | May 2010 | A1 |
20100319061 | Hatakeyama | Dec 2010 | A1 |
20100332837 | Osterwalder | Dec 2010 | A1 |
20110161656 | Rao | Jun 2011 | A1 |
20110209196 | Kennedy | Aug 2011 | A1 |
20110218958 | Warshavsky et al. | Sep 2011 | A1 |
20110238482 | Carney et al. | Sep 2011 | A1 |
20110247051 | Bulumulla et al. | Oct 2011 | A1 |
20110321148 | Gluck | Dec 2011 | A1 |
20110321150 | Gluck | Dec 2011 | A1 |
20110321151 | Gluck | Dec 2011 | A1 |
20120005720 | McGloin | Jan 2012 | A1 |
20120042218 | Cinarkaya et al. | Feb 2012 | A1 |
20120233137 | Jakobson et al. | Sep 2012 | A1 |
20120246739 | Mebed | Sep 2012 | A1 |
20120290407 | Hubbard et al. | Nov 2012 | A1 |
20120304265 | Richter et al. | Nov 2012 | A1 |
20120324526 | Meyer et al. | Dec 2012 | A1 |
20130046995 | Movshovitz | Feb 2013 | A1 |
20130067225 | Shochet | Mar 2013 | A1 |
20130091210 | Rajakarunanayake et al. | Apr 2013 | A1 |
20130173642 | Oliver | Jul 2013 | A1 |
20130212497 | Zelenko et al. | Aug 2013 | A1 |
20130247216 | Cinarkaya et al. | Sep 2013 | A1 |
20140126718 | Movshovitz | May 2014 | A1 |
20140188804 | Gokhale et al. | Jul 2014 | A1 |
Entry |
---|
Do, Jeong-Min et al., “Attribute based Proxy Re-Encryption for Data Confidentiality in Cloud Computing Environments”, 2011 First ACIS/JNU International Conference on Computers, Networks, Systems, and Industrial Engineering, pp. 248-251. |
Miklau, Gerome et al., “Controlling Access to Published Data Using Cryptography”, Proceedings of the 29th VLDB Conference, Berlin, Germany, 2003, 12 pages. |
U.S. Appl. No. 14/266,525, First Action Interview Office Action mailed Jan. 21, 2016, 8 pages. |
Number | Date | Country | |
---|---|---|---|
20130091350 A1 | Apr 2013 | US |
Number | Date | Country | |
---|---|---|---|
61544388 | Oct 2011 | US |