Protecting data in insecure cloud storage

US9390281B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9390281-B2
Application numberUS-201314143328-A
CountryUS
Kind codeB2
Filing dateDec 30, 2013
Priority dateDec 30, 2013
Publication dateJul 12, 2016
Grant dateJul 12, 2016

How to read this patent

A practical reading order for non-experts. Skip the full description unless you need deep technical detail.

  1. Title

    What the patent document calls the invention.

  2. Abstract

    A short plain-language summary of the technical disclosure.

  3. Assignees and inventors

    Who owns or filed the patent and who is credited as inventor.

  4. Key dates

    Filing, priority, publication, and grant dates set the timeline.

  5. First independent claim

    The legal scope of protection — read this for what is actually claimed.

  6. CPC / IPC classifications

    Technology tags used to group this patent with similar filings.

  7. Citations and related patents

    Prior art links and similar publications in this corpus.

Abstract

Official abstract text for this publication.

The disclosed embodiments provide a system that processes data. The system includes a first client that encrypts a first set of data, uploads the encrypted first set of data to a volume on a cloud storage system, and creates a commit record of the upload. The system also includes a synchronization server that verifies access to the volume by the first client and includes the commit record in a change set containing a set of commit records associated with the volume. The synchronization server also signs the change set and provides the change set for use in synchronizing the upload with a second client.

First claim

Opening claim text (preview).

What is claimed is: 1. A system for processing data, comprising: a first client configured to: encrypt a first set of data; upload the encrypted first set of data to a volume on a cloud storage system; and create a commit record of the upload, wherein the commit record comprises: a hash-based message authentication code (HMAC) of a path associated with the data; a previous state of the data; a current state of the data; metadata for the data; a digital signature from the first client; and a timestamp; and a synchronization server configured to: verify access to the volume by the first client; include the commit record in a change set comprising a set of commit records associated with the volume; sign the change set; and provide the change set for use in synchronizing the upload with a second client. 2. The system of claim 1 , further comprising: the second client configured to: obtain the signed change set from the synchronization server; verify a set of signatures in the change set; use the commit record from the change set to update a local data state; and use the commit record to add a download of the first set of data to a download queue. 3. The system of claim 2 , wherein the second client is further configured to: obtain the download from the download queue; use a path from the download to download the encrypted first set of data from the volume; decrypt and verify the first set of data; and write the first set of data to a file on a local filesystem. 4. The system of claim 3 , wherein the second client is further configured to: upon detecting an existing version of the file on the local filesystem: open the existing version with exclusive write access; obtain one or more file attributes for the existing version; if the one or more file attributes have not changed, replace the existing version with the first set of data; and if the one or more file attributes have changed, place the download back in the download queue. 5. The system of claim 2 , further comprising: a management server configured to: provide a set of digital certificates for validating a set of keys used by the first client and the synchronization server; and provide an access control policy associated with access to the volume by the first and second clients. 6. The system of claim 5 , wherein the set of keys comprises: a first key used by the first client to encrypt the data; and a second key used by the synchronization server to sign the change set. 7. The system of claim 1 , wherein the synchronization server is further configured to notify the first client of a conflict between the uploaded first set of data and a second set of data in the volume, and wherein the first client is further configured to resolve the conflict. 8. The system of claim 7 , wherein resolving the conflict involves: downloading the second set of data from the cloud storage system to a local filesystem; and renaming the first set of data in the local filesystem. 9. The system of claim 1 , wherein the change set comprises: a set of signed commit records; an identifier for the volume; a change set identifier; a digital signature from the synchronization server; and a timestamp. 10. A computer-implemented method for processing data, comprising: encrypting a first set of data on a first client; uploading the encrypted first set of data from the first client to a volume on a cloud storage system; creating a commit record of the upload, wherein the commit record comprises: a hash-based message authentication code (HMAC) of a path associated with the data; a previous state of the data; a current state of the data; metadata for the data; a digital signature from the first client; and a timestamp; and providing the commit record to a synchronization server, wherein the commit record is used by the synchronization server to synchronize the upload with a second client associated with the volume. 11. The computer-implemented method of claim 10 , further comprising: receiving, at the first client, a notification of a conflict between the uploaded first set of data and a second set of data on the cloud storage system from the synchronization server; and using the first client to resolve the conflict. 12. The computer-implemented method of claim 11 , wherein using the first client to resolve the conflict involves: downloading the second set of data from the cloud storage system to the first client; and renaming the first set of data on the first client. 13. The computer-implemented method of claim 10 , further comprising: obtaining, at the first client, a change set from the synchronization server, wherein the change set comprises one or more commit records from one or more other clients associated with the volume; verifying a set of signatures in the change set; using the one or more commit records to update a local data state on the first client; and using the one or more commit records to add a download of a second set of data to a download queue on the first client. 14. The computer-implemented method of claim 13 , further comprising: obtaining the download from the download queue; using a path from the download to download the second set of data from the volume to the first client; decrypting and verifying the second set of data at the first client; and writing the second set of data to a file in a local filesystem of the first client. 15. The computer-implemented method of claim 14 , further comprising: upon detecting an existing version of the file on the local filesystem: opening the existing version with exclusive write access; obtaining one or more file attributes for the existing version; if the one or more file attributes have not changed, replacing the existing version with the second set of data; and if the one or more file attributes have changed, placing the download back in the download queue. 16. A computer-implemented method for synchronizing data, comprising: obtaining, from a first client, a commit record of data uploaded to a volume on a cloud storage system, wherein the commit record comprises: a hash-based message authentication code (HMAC) of a path associated with the data, a previous state of the data; a current state of the data; metadata for the data; a digital signature from the first client; and a timestamp; using the digital signature in the commit record to verify access to the volume by the first client; including the commit record in a change set; signing the change set; and providing the change set for use in synchronizing the upload with a second client associated with the volume. 17. The computer-implemented method of claim 16 , further comprising: notifying the first client of a conflict between the uploaded data and existing data in the volume. 18. The computer-implemented method of claim 16 , wherein the change set comprises: a set of signed commit records; an identifier for the volume; a change set identifier; a digital signature from the synchronization server; and a timestamp. 19. A non-transitory computer-readable storage medium storing instructions that when executed by a computer cause the computer to perform a method for processing data, the method comprising: encrypting a first set of data on a first client; uploading the encrypted first set of data from the first client to a volume on a cloud storage system; creating a commit record of the upload, wherein the commit record co

Assignees

Inventors

Classifications

  • for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS] · CPC title

  • using certificates (cryptographic mechanisms or cryptographic arrangements for entity authentication involving certificates H04L9/3263) · CPC title

  • wherein the data content is protected, e.g. by encrypting or encapsulating the payload · CPC title

  • Replication or mirroring of data, e.g. scheduling or transport for data synchronisation between network nodes · CPC title

  • Techniques for file synchronisation in file systems · CPC title

Patent family

Related publications grouped by family.

External sources

Frequently asked questions

Answers are generated from the same data shown on this page.

What does patent US9390281B2 cover?
The disclosed embodiments provide a system that processes data. The system includes a first client that encrypts a first set of data, uploads the encrypted first set of data to a volume on a cloud storage system, and creates a commit record of the upload. The system also includes a synchronization server that verifies access to the volume by the first client and includes the commit record in a …
Who is the assignee on this patent?
Open Invention Network Llc
What technology area does this patent fall under?
Primary CPC classification G06F21/6218. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Jul 12 2016 00:00:00 GMT+0000 (Coordinated Universal Time) (B2). Legal status and post-grant events are not shown on this page.
What related patents are in patentsdb?
We list 8 related publications on this page (citations in our corpus or others sharing the same primary CPC).