The present invention generally relates to secured web syndication of privileged information, applications and application's data. More particularly, the invention relates to a method and system for allowing authorized users to access privileged information, applications and their data by means of conventional web syndication tools.
Many Web sites offer nowadays the ability to aggregate information and applications from different providers into a single personalized web page. These aggregation sites typically define a set of specifications to which syndicated applications must conform and provide services to application developers to ease the development of conforming applications. Examples of some current popular aggregation sites are iGoogle (http://www.google.com/ig), NetVibes (http://www.netvibes.com) and Microsoft Live (http://www.live.com).
1. Application provisioning (11)—this service enables users to easily add syndicated applications 16 to their personalized web pages 17 and remove such syndicated applications 16 from it. Adding a syndicated application 16 to a personalized web page 17 usually involves following a URL (Universal Resource Locator) that conforms to URL specifications defined by the aggregation site provider. The URL includes information concerning the location wherein files describing the application (i.e., metadata, such as application name, description, author, version, date published, etc.) can be found. This URL is sometimes termed an ‘add-to URL’. Removing a syndicated application 16 from the personalized web page 17 is typically accomplished through the user interface provided in the personalized page 17 itself.
2. Data persistence (12)—this service enables syndicated applications 16 to store data across sessions of a web browser 15, during which syndicated applications 16 were accessed. The data persistence services 12 stores data per user on the aggregation site's servers 10.
3. Data retrieval (13)—this service enables syndicated applications 16 to request resources from the Web through the aggregation site's servers 10. This is especially useful in the case of syndicated applications 16 that run within the web browser 17, such as, for example, applications implemented in JavaScript or Flash. The access of such syndicated applications 16 to external resources (outside of their origin domain) is typically prevented due to security restrictions enforced by the default configuration of all major Web browsers (the ‘same origin policy’). Data retrieved by data retrieval services 13 of aggregation site 10 are typically cached in the aggregation site server 10, such that subsequent requests for the same data may be served by accessing the cache of the aggregation site server 10 directly.
Aggregation site servers 10 also provide many additional services, such as for example, services for controlling the size of the area in which syndicated applications 16 are displayed in the personalized web pages 17, services for controlling the titles of syndicated applications 16, and services for opening pop-up windows, and many more.
In order to keep the personalized web pages 17 personal, aggregation site servers 10 also perform user authentication. This is usually achieved by requesting the user to provide identifiers, typically in the form of user name and password. Most aggregation site servers 10 store a persistent cookie (not shown) on the user's web browser 15 in order to avoid requiring user authentication at the start of every session.
Aggregation sites are becoming popular Web destinations due to the fact that they allow users to easily build a personalized web page that contains the information that is most relevant to the users, and the syndicated applications that are most useful to them. Typically, this personalized web page then becomes the source for much of the information the users consume on a daily basis, such as news headlines, weather forecasts and sports scores, as well as the starting point from which they access other Web sites.
Applications syndicated on aggregation sites are very well suited for providing personalized access to information and functionality, but due to some features of aggregation sites, syndicated applications do not provide a good solution when a high level of security is required. A good example of an application that requires a high level of security is a syndicated application that provides access to a user's bank account. Some of the reasons for which syndicated applications are not considered appropriate when a high level of security is required are:
1. The level of authentication provided by the aggregation site servers 10 is insufficient since:
A secured web syndication scheme is described and claimed in co-pending U.S. patent application Ser. No. 11/896,740 of the same assignee hereof, the content of which is incorporated herein by reference. In this application modified web feeds and dedicated web servers are used for implementing a modified web syndication scheme allowing authenticated users to access privileged content by means of conventional web syndication clients.
The methods described above have not yet provided satisfactory solutions for allowing authorized users secured access to privileged content, applications and application's data over data networks by means of conventional web syndication.
It is therefore an object of the present invention to provide a system and method for providing authorized users secured access to privileged content and to syndicated applications designed for handling privileged content.
It is another object of the present invention to provide a uniform method for developing, deploying and running syndicated applications independent of the details of the aggregation site.
Other objects and advantages of the invention will become apparent as the description proceeds.
The present invention provides a system and method for secure application syndication, and for securely accessing privileged content by means of syndicated applications, by conventional web aggregation means.
The term aggregation site is used herein to refer to aggregators of syndicated data and application, such as, but not limited to, personalized web pages, RSS aggregators and social networking sites. The term aggregation site server is used herein to refer to a sever capable of maintaining syndicated data and syndicated applications and allowing users to access the same over a data network (Such as iGoogle, NetVibes, Facebook, My Yahoo).
The term privileged content (also referred to herein as privileged data or information) is used herein to refer to classified information which may be accessed by authorized individuals only. The privileged content may comprise, but is not limited to, private, sensitive, confidential, and/or proprietary information.
The term secured network refers to a data network comprising security infrastructures (e.g., firewall) capable of preventing access of unauthorized users to the network resources. The security infrastructures preferably comprise means (e.g., Single sign on and authentication systems such as, but not limited to, Kerberos, and user directories such as, but not limited to, Active Directory) for authenticating users operating within the network and users attempting to access said network from external networks.
The term metadata used herein refers to data used for describing data items, such as, for example, title, author, version and date, of a content or application.
The term syndicated application used herein to refer to an application that is designed to be accessed within the context of an aggregation site. The aggregation site is typically provided by a party other than the syndicated application provider, and may aggregate syndicated applications from multiple providers.
The term application wrapper is used herein to refer to a file or set of files that describe a syndicated application and conform to the specifications defined by a specific aggregation site provider. The application wrapper contains information such as the application name and description, date published, author name etc. The application wrapper also contains a network address (URL in the WWW context) that references the syndicated application code.
The inventors of the present invention developed a new syndication system allowing secure syndication of applications in conventional web aggregators of authorized users, and allowing secured and controlled access to privileged content by means of the syndicated applications. The system of the invention advantageously employs conventional web syndication servers and aggregators thereby allowing authorized users to securely add applications and access privileged content via their favorable web aggregation sites (e.g., personalized web pages) along with other non-privileged content syndicated therein.
In general, the secured application syndication of the invention utilizes existing web clients (e.g., web browsers) and servers for securely adding a syndicated application to a web syndication site of an authorized user, wherein the syndicated application is provided over a secured connection by an application server maintained within a secure network responsive to identifiers and/or referencing data obtained in an application wrapper, wherein said application wrapper is provided by a provisioning server capable of generating and providing such application wrappers in response to user's requests containing unique identifiers referencing the requested applications and the users requesting the applications, which requests are received by the provisioning server via the aggregation site servers used by the users.
Preferably, the application server is maintained within a secured network of the application provider. Optionally, the application syndication process is initiated by the application server by providing the web client of the users addressing data comprising a link (i.e., network address) to the provisioning server, an identifier associated with the requested syndicated application, and optionally data referencing the aggregation site to which the syndicated application should be added. Preferably, the addressing data is provided in a form of an add-to URL. Advantageously, the secured network of the application provider further comprises information systems accessible by the syndicated applications provided by the application provider over the secured data connection.
The application syndication and/or communication of privileged data in the system of the invention is preferably performed after performing server, web client and user authentications. The server may be authenticated by the web client by means of SSL and digital certificates. The server may be authenticated by the user by means of an authentication phrase. Preferably, the user is authenticated by the application server by means of user name and password.
The system may comprise a personalized web client generated by a secured provisioning application (e.g., web application such as a secure banking application or a special purpose secure client provisioning application) by requesting a client identifier and/or key (e.g., cryptographic key), by the secured provisioning application, from the application server, and upon receipt of the client identifier and/or key generating the personalized web client by the provisioning application.
The authentication of the personalized web client by the application server may comprise execution of a challenge-response protocol by the server and the client, employing the client's key as the shared secret, which may be initiated by the client sending its client identifier to the application server.
Preferably, the application server comprises: the syndicated applications; means for authenticating the users and the user's clients; data persistence means for persisting data across aggregation site sessions; retrieval means for allowing the syndicated applications to request network resources through the application provider's servers; cache memory for storing data which has been previously requested by syndicated applications; serving means for serving incoming requests for data; data collecting means capable of periodically and/or continuously retrieving (privileged or non-privileged) data from the information systems; data transformation means for providing the data retrieved from the information systems in a proper data representation (e.g., RSS, JSON, XML); and optionally data consistency means for verifying that the data items stored in the cache is updated with the last changes made in the information systems. Advantageously, the data collecting means may be implemented by data adapters (e.g., MQSeries, RDBMS).
In one aspect the present invention is directed to a syndication system for securely adding syndicated applications to conventional syndication aggregation sites and servers being accessible by user's client applications, comprising: an application server adapted to provide said syndicated applications to said client applications of authenticated users, one or more secured communication links between said client applications and said application server, and a provisioning server capable of generating and providing said syndication aggregation sites an application wrapper responsive to a request from user's client application, wherein said request and said application wrapper comprise unique identifiers referencing the requested application and the user requesting the applications. Advantageously, the application server resides within a secured network.
The syndication system may further comprise one or more information systems residing within the secured network and capable of being accessed by the syndicated applications via the application server.
The application server may comprise the syndicated applications, means for authenticating the users and the user's client applications, data persistence means for persisting data across aggregation site sessions, retrieval means for allowing the syndicated applications to request network resources through said application server, cache memory for storing data which has been previously requested by syndicated applications, serving means for serving incoming requests for data, and data collecting means (e.g., data adapters) capable of periodically and/or continuously retrieving privileged, or non-privileged, data from the information systems.
Optionally, the application server may further comprise transformation means for providing the data retrieved from the information systems in a proper data representation, and/or data consistency means for verifying that the data items stored in the cache are updated with the last changes made in the information systems.
In another aspect the present invention is directed to a method for securely adding a syndicated application to user's aggregation site maintained in an aggregation site server and being accessible by a user client application, comprising: providing said client application addressing data (e.g., add-to URL) comprising a link (network address) to a provisioning server and identifiers associated with said user and with said syndicated application; providing said aggregation site server a request to add said syndicated application, wherein said request comprises said addressing data and said identifiers; forwarding said request to said provisioning server; upon receipt of said request by said provisioning sever generating an application wrapper comprising said identifiers and addressing data (e.g., network address) referencing a location of said syndicated application in an application server; providing said application wrapper to said aggregation site server; and determining whether said user is an authorized user, and if so adding said application wrapper to said aggregation site, thereby allowing said client application to fetch said syndicated application over a secured link connecting it to said application server, according to the data contained in said application wrapper.
Preferably, the addressing data is provided by the application server.
Optionally, the request further comprises data referencing the aggregation site to which the syndicated application should be added.
Preferably, the application server resides within a secured network. Advantageously the secured network further comprises information systems accessible by the syndicated applications provided by the application provider over the secured data connection.
Preferably, the communication between the client application and the application provider is performed after authenticating the client application, the application server, and the user. The server authentication may be performed by the client application, for example, by means of SSL and digital certificates. The server authentication may be performed by the user, for example, by means of an authentication phrase. The user may be authenticated by the application server by means of user name and password.
Optionally, the client application is a personalized client generated by a secured provisioning application by means of a client identifier and/or key provided by the application server. Advantageously, the authentication of the personalized client by the application server may comprise execution of a challenge-response protocol by the server and the client, employing the key as the shared secret.
The present invention is illustrated by way of example in the accompanying drawings, in which similar references consistently indicate similar elements, and in which:
The present invention provides a system and method that enables access to privileged application data, and secure provisioning of syndicated applications adapted to handle such privileged data, by means of conventional web-technologies, such as, for example, Web 2.0 technologies. The goals of the invention are accomplished while maintaining the security, scalability and reliability required in many organizations, for example, enterprise systems. As demonstrated in
With reference to
As exemplified in
In determining when to perform retrieval, the system 70 takes the following user-defined parameters into account:
Polling frequency limits—users can define limits on the number of requests sent to a backend system 79 over a unit of time. Frequency limits are set both at the adapter (78) level and at the data collector (81) level. Different polling frequency limits may be set for different time intervals, for example, a certain limit may be set for Sundays between 10 PM and midnight, and a different limit may be set for weekdays during work hours, etc.
Update hints—users may be able to define when data from a data collector 81 or adapter 78 is typically updated. The system 70 uses this information to decide when it is most beneficial to retrieve data. For instance, many databases are updated once a day, usually during off hours, by a batch process. A user can define that data for a certain data collector 81 updates daily, for example, at 3:00 AM. The system will then schedule retrieval for that data collector daily just after 3:00 AM, minimizing the load generated on the backend system 79 and maximizing the time in which the retrieved data is up to date.
System 70 is designed to meet the following goals:
In order to achieve the above goals, the system architecture 70 adheres to the following principles:
Adapters 78 are used to manage the communication with backend systems 79 in which the privileged data is stored (e.g., enterprise information system). Adapters 78 can be defined for serving a specific syndicated application 72 (e.g. SAP adapter or a Siebel adapter) or can be generic, capable of supporting a widely used technology (e.g. RDBMS adapter or Web Services adapter).
Adapters 78 can be either synchronous or asynchronous. Synchronous adapters periodically poll backend systems 79 for data, pulling relevant information as it becomes available. An example of such an adapter is an RDBMS adapter that is adapted to periodically execute SQL queries on a backend database to retrieve data. Asynchronous adapters 78 subscribe to data streams from backend systems 79 and then have notifications pushed to them by the backend system 79. An example of an asynchronous adapter 78 is an MQSeries adapter which subscribes to topics and then processes messages that are pushed from the MQSeries backend.
Adapters 78 are responsible for managing the life cycle of the connections with backend systems 79. Determining what to retrieve and when to retrieve is the responsibility of the integration layer 77 and retrieve logic 76. System 70 may include a host of built in adapters 78, and it preferably defines a simple interface that adapters 78 must implement, allowing third parties to easily develop new adapters 78.
As shown if
The integration layer 77 is responsible for representing (transforming) the data retrieved from backend systems 79. It implements a uniform model for all incoming data, regardless of the origin system. Data is modeled as data fields that are grouped together in data items. A data field represents a single data ‘atom’ that has a specific type, display name, constraints on possible values and so on. A data item represents a grouping of data fields into a record that generally represents an entity from the problem domain of the origin system such as a customer in a CRM system (24 in
Retrieve logic 76 uses adapters 78 in conjunction with the metadata defined in the integration layer 77 and the limits and hints defined for retrieval (as discussed hereinabove) to optimize data retrieval from backend systems 79 while adhering to user defined limits. Retrieve logic 76 also takes into account data usage patterns, giving priority to data that is accessed more frequently, and has the capability of retrieving only the data required by users, based on user defined parameters. For instance, in a scenario wherein system 70 provides access to stock quote information from a backend trading system, instead of retrieving and caching information for all stocks, retrieve logic 76 can use the stock ticker symbol as a parameter and retrieve quotes only for those stocks that have actually been requested by users.
The system stores data it retrieves from backed information systems 79 in a data item cache (in cache 75). The data item cache provides a uniform representation of all retrieved information, regardless of the source backend system 79, and the specific content of the data items. The cache 75 also enables decoupling between retrieval of data from syndicated applications 72 and access to data by clients. When a client requests data from system 70, the system can serve the data from the cache 75 and avoid generating unnecessary load on the backend information systems 79.
In situations wherein compliance considerations or corporate policy disallow the caching of some or all of the retrieved data, system 70 may be adapted to support a direct-access mode in which data is retrieved and processed on demand, and no data is cached within the system.
The serving component 74 is responsible for serving incoming requests for data. Client requests are generally incoming HTTP requests. Based on the URL the serving component 74 determines the data that should be returned and the representation of the requested data. For instance, a request for a data item representing an opportunity record originating from a bank's CRM system may be accessed through a URL such as exemplified in
A URL may also point to a set of data items. This is typically done by specifying a set of parameters that determine what subset of the data items the application server should return. For example, such URL may be in the form shown in
Serving requests, as is the case for all requests from system 70, are authenticated. System 70 uses the user identity associated with the request to apply access control restrictions to the underlying data as will be described hereinbelow, as well as to make the returned data user aware by filtering through only those data items relevant to the requesting user, based on the underlying metadata definitions.
In addition to providing clients with access to backend data, the serving component 74 also keeps track of the access statistics. Access statistics are used by retrieve logic 76 to prioritize data for retrieval.
Every access to system 70 is authenticated. System 70 does not manage a user directory by itself, but instead uses existing user (e.g., enterprise) directories and single sign on systems to authenticate users. Regardless of the specific authentication method used, every incoming request is associated with a user identity and additional user information from the user directory such as the names of groups the user belongs to and roles the user has within the organization.
Various components of system 70 may use authentication information to control access to data, carry out aggregations of data items associated with a user, collect usage statistics etc.
Syndicated applications 72 are the primary method for end users to interact with system 70. System 70 may come bundled with several applications 72, and may provide tools and APIs to allow third parties to develop new applications 72. The system's syndicated applications 72 allow viewing data items such as sales opportunities from a CRM system 24, executing transactions such as authorizing purchase requisitions in an ERP system 23 and much more. The system secure RSS Reader 31 depicted in
System 70 may include a consistency verifying component (e.g., in the integration layer 77) for executing operations on backend systems 79, which will be referred to hereinafter as ‘actions’ (e.g., Approval of a purchase requisition, update of reported work hours, change of status of a customer service request etc.). Since the data in the cache 75 may not match the state of the data in the backend systems 79 when such action takes place, it is critical to verify consistency of the cached data with the data in the backend systems 79 before executing such actions. Furthermore, the consistency verification and the action execution must occur within the scope of a single isolated transaction (i.e., a transaction that is not affected by any other concomitant process in the backend system) to ensure that the data associated with the action to be carried out was not changed in the backend system before action execution.
Application developers can use a system Software Development Kit to develop new syndicated applications 72. Using the SDK, application developers can quickly implement new ways to view existing privileged data or combine information from different backend systems 79 in new and useful ways that, without system 70 of the invention, would require long and expensive integration projects.
A typical implementation of the system involves retrieving privileged data via multiple syndicated applications and making it securely available to users by way of various access methods both from within the network of the organization to which the users belongs and from the Internet. As a result, security is a major consideration in the invention's system design.
Authentication services are preferably used to ensure that actors in the system are indeed who they claim to be. Authentication preferably involves authenticating the system server, authenticating the client used to access the system and authenticating the user making the access. Server authentication allows the client and the user to ascertain they are communicating with the system. Client authentication allows the server to ascertain that it is serving a known and certified client. User authentication allows the server to ascertain that it is serving a known user and to associate that user with appropriate privileges and optionally, with the client instance.
The authentication processes described above occur in sequence, and different authentication methods may be used for each process. At the end of the process, the system server is assured of the client's and user's identity and both the client and the user are assured of the server's identity.
In cases wherein there is a high risk of attacks that attempt to impersonate client 67, server 68 employs a client authentication mechanism. This mechanism may be required, for example, when the client 67 used for accessing privileged content stored in backend systems 79 is a desktop or homepage gadget (a mini application, usually written in Javascript, running in a Web browser or a gadget-specific runtime environment). Accessing the source code of such applications and modifying it is relatively simple, thus increasing the risk of attempts to impersonate client 67.
The preferred method for client authentication is client certificates, but in many cases, the complexity of secure certificate distribution and management outweighs the security benefits achieved. In order to authenticate clients 67 without digital certificates, server 68 preferably issues a unique identifier to each client 67 instance during the provisioning process (initiated from a secure provisioning application as described with reference to
The diagram shown in
(P1) Client Request: In this step, the user 65 requests to download a client 68 from the secured provisioning application 69.
(P2) Client Identifier and Key Request: The provisioning application 69 requests a client identifier and a key (to be used as a shared secret) for the client instance (68) it is provisioning.
(P3) Client Identifier and Key: server 67 returns the requested client identifier and key to the provisioning application 69.
(P4) Personalized Client: The provisioning application 69 generates a personalized client instance 68 with the identifier and key it received and returns it to the user 65. This step finalizes the provisioning stage.
The client authentication steps after completing the provisioning stage may be performed as follows:
(A1) Client Identifier: client 68 sends the client identifier to server 67.
(A2) Challenge: the server 67 sends a random challenge to the client 68.
(A3) Response: client 68 calculates a cryptographic hash function of a combination of the challenge and the key and sends the result to the server 67.
(A4) Verify Response: server 67 verifies that the response sent from client 68 is indeed the correct hash value. This step finalizes the client authentication phase.
(A5) User Authentication Request: server 67 proceeds to user authentication (described with reference to
In most cases, user authentication is performed by requesting a user name and password from user 65, over a secure connection (64 in
While user name and password authentication is the most common user authentication mechanism, other mechanisms can be supported. By integrating with external authentication systems server 67 can support authentication methods such as digital certificates, one time passwords, hardware tokens, biometrics and many others.
An application server 4, running in a secure environment 7 (e.g., behind the application provider's firewall) provides the syndicated applications 16 with the services they require. Analogous to the services provided by the aggregation site server 10, the application server 4, provides application provisioning 11a, data persistence 12a and data retrieval 13a services. The application server 4 also facilitates secure user authentication by integrating with the authentication infrastructure of application provider 3.
Secure application provisioning provides the application provider 3 with control over where syndicated applications 16 are installed and by whom. Additionally, by using an external application provisioning server 8, accessible from the aggregation site servers 10, the application provider 3 avoids the need to allow aggregation site services (11, 12 and 13) to access resources within the application provider's secure network 7.
The goal of the provisioning process of the invention, inter alia, is to add an application wrapper to the user's personalized web page 17. The application wrapper (not shown) includes public information about the requested syndicated application, such as, for example, the application's title and author. The wrapper structure is specific to the aggregation site (17). The wrapper causes the site to render an ‘inline frame’ (an HTML element that causes a web browser to render a nested frame within a web page that contains an html document different and separate from the document displayed in the web page. The inline frame source attribute contains the URL of the nested document.) sourced from the application server 4. The requested syndicated application is then loaded by the browser 15 from the application server 4 into the inline frame over secure connection 5.
The secure provisioning process of the invention also serves in associating a unique, high entropy identifier with the provisioned syndicated application instance. This identifier is associated with the identity of the user to whom the application is provisioned, so that attempts of other users to use the same application instance will fail. This identifier is stored both in the application wrapper and in the aggregation service's persistence mechanism 12. The syndicated application 16 compares the values stored in each of these locations every time it is executed to verify that the provisioned application instance is running within the intended aggregation environment.
In step 102 the client (e.g., web browser 15) requests the resource identified by the URL from the application provisioning server 8. In step 103 the application provisioning server 8 generates the appropriate application wrapper and redirects the client (15) to aggregation site server 10 with an Add-to URL formatted according to the specifications defined by the target aggregation site and pointing to the application wrapper as the target application. In step 104 the client (15) requests the resource identified by the URL from the aggregation site server 10. In step 105 the aggregation site server 10 requests the application wrapper from the application provisioning server 8, wherein said request contains the application instance identifier.
Next, in step 106 the application provisioning server 8 returns the appropriate application wrapper. The instance identifier is stored within the application wrapper and appears on all requests for the syndicated application 16.
In steps 107 and 108 the aggregation site server 10 authenticates the user, if the user is not yet authenticated, and in steps 109 and 110 the aggregation site server 10 requests the user's confirmation to add the syndicated application to the user's profile. If the user confirms to add the syndicated application, in step 111 the aggregation site adds the syndicated application to the user's profile, otherwise the application provisioning fails as the control is passed to step 112. After step 111 the user is able to use the syndicated application 16 by means of the application wrapper maintained in the aggregation site server 10, by addressing the requested application based on the code in the application wrapper and accordingly securely downloading the requested application from application server 4 over secure connection 5.
The secure data persistence service 12a (
The secure data retrieval service 13a allows syndicated applications 16 to retrieve data from sources within the application provider's secure network 7 as well as public Web resources. The application server 4 is integrated with the application provider's information systems 6 and provides a query interface that allows syndicated applications 16 to request data from the information systems 6 in a uniform way. To retrieve Web resources, the syndicated application 16 specifies the target URL in the retrieval request. Data retrieval services 13a are provided over an encrypted connection 5 and only after the user has been securely authenticated.
Users may access a syndicated application 16 only after being securely authenticated by the application provider 3. Because the application provider's authentication infrastructure is used, the syndicated application 16 benefits from any security features in the provider's authentication process such as password change policy, password entropy rules and multi factor authentication. This authentication is independent of authentication carried out by the aggregation site server 10, which is typically required by the aggregation site server 10 for personalization, but does not affect the security of the syndicated application 16.
If the resources where the syndicated application 16 resides are available to the user, in step 122 the security mechanisms governing access to those resources verify that the user is authenticated.
If the user is not authenticated, the aforementioned mechanisms authenticate the user in step 123. This authentication may occur completely outside the context of the syndication system of the invention as long as the user's authentication state and the user's identity can be securely transferred between the authentication mechanisms and the application server 4.
In step 124 the application server 4 verifies that the authenticated user is the user associated with the syndicated application instance identifier. If the authenticated user is not the one associated with the instance identifier, in step 125 the user is denied access to the application. If the authenticated user is associated with the instance identifier, in step 126 the user is successfully authenticated and may access the secure syndicated application.
A basic capability of the system of the invention, on which many features are based, is the capability to assign a unique URL to privileged data entities (e.g., enterprise data). Conveniently, the system assigns a URL to all privileged data items that it is configured to retrieve. The URL of a privileged content item uniquely identifies the item, such as exemplified in
Any user can request privileged data items, but only users having appropriate access privileges can access the requested items. Other non-authorized users receive an appropriate error message whenever attempting to access such privileged content.
The system of the invention may also assign URLs to sets of privileged data items. Such sets are defined by assigning values to parameters. For instance, a user can request to access items in the opportunities table wherein the projected revenue is above a certain threshold.
The secured syndication system of the invention is preferably adapted to support multiple representations of privileged content. These include HTML, RSS, JSON and XML. Based on the user's request received in the system, the content is transferred to the user in the appropriate format. For example, a request for the HTML representation of an opportunity from a bank's CRM system may be in the form of a URL referencing a HTML file 42, as exemplified in
An additional benefit of assigning URLs to the privileged data items is the resulting ability to store the URLs in bookmarking systems, tag the URLs and share the URLs by simple existing mechanisms such as email or instant messaging. The system of the invention may be adapted to keep track, internally, of the data items accessed by users of the system and can provide information regarding user's most commonly accessed data items, what users of a similar profile (e.g. members of the same department) access, what additional information may be of interest to a user based on the data already accessed by the user, and other users' usage information etc.
The system of the invention may further allow assigning tags to items, rating items, and may support searching and sorting based on these values. Any item or set of items can be tagged or rated, providing user generated metadata that can significantly reduce the time it takes to find the information the user is looking for.
The system of the invention may be further adapted to provide users with the information most relevant to them. This may be advantageously achieved by employing RSS feeds wherein the data in the feed depends on the identity of the user accessing the feed. For example, two sales managers accessing a ‘My Opportunities’ feed containing opportunity information originating from a CRM system (24 in
The mechanism underlying this functionality uses information retrieved from a user directory regarding the groups a user belongs to (e.g., such as in enterprises—teams, departments etc.) and information from an information system regarding ownership of data items (e.g. the identity of the sales executive assigned to an account) to determine what items to include in the returned data. The implementation of these features will be further described hereinbelow.
A major consideration when accessing secure privileged content (e.g., enterprise data) is access control. It is critical that users gain access only to data items they are authorized to access by their organization's security policies. In most large organizations, access control rules are not centrally managed. Rather, they are implemented separately by each enterprise information system. In some cases, the systems' access control logic applies to users defined in a central user directory, while in other cases, the information system manages its own separate user database. Within these constraints, the system of the invention implements a mechanism that integrates information from central user directories and the organization's information systems and integrates this information in a manner that allows it to enforce the same access control constraints the enterprise application system implements without explicitly duplicating the access control logic.
At the most basic level, the system of the invention implements access control by associating user principals with data items the system retrieves. User principals are identities the user is associated with such as user identifiers, group identifiers and role identifiers. When a user requests access to a data item, the system checks the principals associated with that data item against the principals associated with the user in the user management system (a user directory, user information specific to the origin system, or a combination thereof). In the simplest scenario, if at least one of the principals associated with the data item appears in the user's list of principals, the system allows access to the data item. Otherwise, the system denies access. The system can also implement more complex logic requiring multiple matches and requiring specific principals to appear or to match.
Associating principals with retrieved data items can be as simple as defining one of the item's fields as the principal, but may also be very complicated and require interaction with multiple systems and implementation of system-specific logic. A typical use case could be to implement access control for customer data in a CRM system. As part of the customer data, the CRM system includes the user name of the sales representative assigned to the customer. The corporate security policy mandates that only the sales representative and the representative's manager are allowed to access the customer's information. The hierarchy of the sales organization is described in the corporate user directory.
An exemplary customer database is shown in
A simplified representation of the data item as it appears in the system's cache is exemplified in
Cross site scripting is an attack that attempts to inject malicious scripts into a context where they would be trusted by the browser and executed. When displaying data retrieved from enterprise applications, cross site scripting may occur, for instance, if the raw data retrieved from enterprise information systems contains malicious scripts. If this data were to be naively rendered in an environment that supports the script's language (e.g. a Web browser), the environment would execute the malicious code.
To thwart cross site scripting attacks, the system of the invention processes the data received from the enterprise system and removes elements that could potentially be interpreted as malicious scripts. Specifically, for data that is to be rendered in a Web browser, the system strips all HTML tags except for a short list of tags that are considered safe such as <b> indicating bold text, <i> indicating italics and <br> indicating a line break. The system also strips all attributes of the allowed tags. As a second layer of protection, the system escapes all text that remains between the safe tags after stripping, so that even if malicious code somehow leaked through the stripping process, it would be treated as literal text rather than as code by the execution environment.
For instance, the title of a feed containing a malicious script may be as shown in
A somewhat more complex example may be attempting to avoid stripping by escaping the element delimiters. An attempt to do this is exemplified in
The above examples and description have of course been provided only for the purpose of illustration, and are not intended to limit the invention in any way. As will be appreciated by the skilled person, the invention can be carried out in a great variety of ways, employing more than one technique from those described above, all without exceeding the scope of the invention.
This application is based upon and claims the benefit of priority from the prior U.S. Provisional Patent Application Ser. No. 60/887,623, filed on Feb. 1, 2007, the entire content of which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
60887623 | Feb 2007 | US |