×

Intelligent client architecture computer system and method

  • US 8,156,078 B2
  • Filed: 04/10/2009
  • Issued: 04/10/2012
  • Est. Priority Date: 10/31/2003
  • Status: Active Grant
First Claim
Patent Images

1. A method of implementing synchronized distributed objects comprising:

  • a local computing device requests data from a remote computing device to be used in a transaction;

    the local computing device checks local resources for the data required;

    upon failing to locate the required data locally, the local computing device formats a request for the required data to the remote computing device;

    the local computing device sends the formatted request to the remote computing device;

    the remote computing device receives the formatted request and unpacks the formatted request to remove formatting elements needed for transport;

    the remote computing device interprets the formatted request from the local computing device by comparing the formatted request to an object model on the remote computing device;

    the remote computing device resolves the formatted request to a set of data access instructions that operate on database management software;

    the database management software retrieves the requested data;

    the remote computing device registers interest in the retrieved data by the local computing device that requested the data;

    the remote computing device packages the retrieved data for transport to the local computing device;

    the remote computing device delivers the retrieved data to the local computing device;

    the local computing device receives the retrieved data and unpacks the formatted request to remove formatting elements needed for transport;

    the local computing device adds the retrieved data to a local data storage resources device;

    the local computing device copies the retrieved data and delivers the retrieved data to the transaction;

    the local computing device stores the retrieved data in a transaction data cache used to support the transaction, the transaction data cache being separate from a main local data cache and separate from a main local data mass storage area;

    the local computing device registers the data as used by the transaction;

    the local data storage resources device is updated to reflect changes made at the remote computing device by other users or by automated processes;

    the local computing device operates the transaction, thereby accumulating changes in the data stored in the transaction data cache;

    the changes in the data stored in the transaction data cache are compared against a log of data changes to the local data storage resources device after retrieving remote data;

    the local computing device detects a local data collision conflict based upon the comparison of the data stored in the transaction data cache and the local data storage resources device;

    the local computing device notifies the transaction that the local data collision conflict occurred;

    the transaction resolves the local data collision conflict in an application-specific manner;

    the local computing device formats the resolved local data collision conflict for transport to the remote computing device;

    the local computing device transports the resolved local data collision conflict to the remote computing device for remote data conflict checking and long-term persistence;

    the remote computing device receives the resolved local data collision conflict and unpacks formatting elements added for transport;

    the remote computing device compares the resolved local data collision conflict to data items changed by the other users or by the automated processes;

    the remote computing device stores the data items changed by the other users or by the automated processes as queued data changes;

    the remote computing device detects a remote data change collision conflict based upon the comparison of the resolved local data collision conflict and the queued data changes;

    the remote computing device notifies the local computing device that the remote data change collision conflict occurred;

    the local computing device forwards the notification to the transaction for resolution in the application-specific manner and sends a message to the remote computing device indicating resolution of the remote data change collision conflict;

    the remote computing device then detects a remote database collision conflict based upon comparison of the results of the resolved local data collision conflict and a persistent data store on the remote computing device;

    the remote computing device notifies the local computing device that the remote database collision conflict occurred;

    the local computing device forwards the notification to the transaction for resolution in the application-specific manner and sends a message to the remote computing device indicating resolution of the remote database collision conflict;

    the remote computing device updates the persistent data store on the remote computing device;

    the remote computing device checks a registration table to determine other computing devices that must be notified of the resolution of the remote database collision conflict performed by the local computing device and the remote computing device;

    the remote computing device transmits the results of the resolution of the remote database collision conflict to the local computing device and other computing devices affected by the remote database collision conflict;

    the local computing device and the other computing devices update the main local data cache based upon the resolution of the remote database collision conflict; and

    the local computing device purges data from the transaction data cache.

View all claims
  • 1 Assignment
Timeline View
Assignment View
    ×
    ×