Graph-based data models for partitioned data

US10740319B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-10740319-B2
Application numberUS-201816039651-A
CountryUS
Kind codeB2
Filing dateJul 19, 2018
Priority dateSep 12, 2013
Publication dateAug 11, 2020
Grant dateAug 11, 2020

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.

A method and system for managing access to data. A plurality of data items is stored across a plurality of partitions according to a graph-based data model. The data model associates each data item with an identifier of a source entity pertaining to the data item, an identifier of a destination entity pertaining to the data item, and an identifier of a type of directed relationship pertaining to the data item from the source entity to the destination entity. When a lookup request is received identifying a source entity and a type of directed relationship from the source entity, a particular partition is identified based on the source entity identifier. A response to the lookup request is then returned that includes data item(s) from the identified partition that are associated in the partition with both the identified source entity identifier and the identified directed relationship type.

First claim

Opening claim text (preview).

The invention claimed is: 1. A method of managing access to data, comprising: at one or more computer systems comprising processors, memory, and storage: storing a plurality of data items across a plurality of partitions of a database of the plurality of data items; wherein the storing is according to a graph-based data model that associates each data item of the plurality of data items with an identifier of a source entity pertaining to the data item, an identifier of a destination entity pertaining to the data item, and an identifier of a type of directed relationship pertaining to the data item from the source entity to the destination entity; wherein the plurality of partitions is stored across a plurality of physical machines; wherein each partition of the plurality of partitions comprises a respective subset of data items of the plurality of data items; receiving a lookup request specifying an identifier of a particular source entity and an identifier of a particular type of directed relationship from the particular source entity; based on the identifier of the particular source entity specified in the lookup request, identifying a particular partition of the plurality of partitions; and returning a response to the lookup request, the response comprising data items, of the plurality of data items stored across the plurality of partitions, each of the data items of the response both: (a) stored in the particular partition; and (b) associated in the particular partition, according to the graph-based data model, with both: (b1) the identifier of the particular source entity and (b2) the identifier of the particular type of directed relationship. 2. The method of claim 1 , wherein the particular source entity is a user having a user account with an online content management system; and wherein each data item, of the data items returned in the response, identifies a different collection of content items, under management of the online content management system, to which the user having the user account has permission to access. 3. The method of claim 1 , wherein the particular source entity is a collection of content items under management of an online content management system; and wherein each data item, of the data items returned in the response, identifies a different user having a user account, with the online content management system, that has permission to access the collection of content items. 4. The method of claim 1 , wherein each data item, of the data items returned in the response, represents permissions that a particular user having a user account with an online content management system has with respect to a different collection of content items under management of the online content management system, the particular user identified by the identifier of the particular source entity, the different collection of content items identified by the each data item. 5. The method of claim 1 , wherein each data item, of the data items returned in the response, represents permissions that a different user having a user account with an online content management system has with respect to a particular collection of content items under management of the online content management system, the particular collection of content items identified by the identifier of the particular source entity, the different user having a user account identified by the each data item. 6. The method of claim 1 , wherein: the lookup request is a first lookup request; the response is a first response; the method further comprises: receiving a second lookup request specifying the identifier of the particular source entity, an identifier of a particular destination entity, and the identifier of the particular type of directed relationship; responsive to receiving the second lookup request, identifying, based on the identifier of the particular source entity specified in the second lookup request, the particular partition of the plurality of partitions; and returning a second response to the second lookup request, the second response comprising a particular data item that is both: (a) stored in the particular partition; and (b) associated in the particular partition, according to the graph-based data model, with all of: (b1) the identifier of the particular source entity, (b2) the identifier of the destination entity, and (b3) the identifier of the type of directed relationship. 7. The method of claim 1 , wherein the particular source entity corresponds to a node in the graph-based data model and the particular type of directed relationship corresponds to a directed edge from the node in the graph-based data model. 8. The method of claim 1 , wherein at least one data item of the data items returned in the response is obtained from a cache of data items. 9. The method of claim 1 , further comprising: storing a plurality of slave partitions corresponding to the plurality of partitions. 10. An online content management system comprising: one or more processors; one or more computer-readable media storing one or more computers programs, the one or more computer programs configured for: storing a plurality of data items across a plurality of partitions of a database of the plurality of data items; wherein the storing the plurality of data items is according to a graph-based data model that associates each data item of the plurality of data items with an identifier of a source entity pertaining to the data item, an identifier of a destination entity pertaining to the data item, and an identifier of a type of directed relationship pertaining to the data item from the source entity to the destination entity; wherein the plurality of partitions is stored across a plurality of physical machines; wherein each partition of the plurality of partitions comprises a respective subset of data items of the plurality of data items; receiving a first lookup request specifying an identifier of a particular source entity, an identifier of a particular destination entity, and an identifier of a particular type of directed relationship from the particular source entity to the particular destination entity; based on the identifier of the particular source entity specified in the first lookup request, identifying a particular partition of the plurality of partitions; returning a first response to the first lookup request, the first response comprising a particular data item that is both: (a) stored in the particular partition; and (b) associated, according to the graph-based data model, with all of: (b1) the identifier of the particular source entity, (b2) the identifier of the particular destination entity, and (b3) the identifier of the particular type of directed relationship; receiving a second lookup request specifying the identifier of the particular source entity and the identifier of the particular type of directed relationship; based on the identifier of the particular source entity specified in the second lookup request, identifying the partition of the plurality of partitions; and returning a second response to the second lookup request, the second response comprising data items, of the plurality of data items stored across the plurality of partitions, each of the data items of the second response both: (a) stored in the particular partition; and (b) associated, according to the graph-based data model, with at least both: (b1) the identifier of the particular source entity and (b2) the identifier of the particular type of directed relationship. 11. A system for managing access to data, the system comprising: one or more processors; one of more computer-readable media storing one or more sets of instructions configu

Assignees

Inventors

Classifications

  • G06F16/278Primary

    Data partitioning, e.g. horizontal or vertical partitioning · CPC title

  • Locking methods, e.g. distributed locking or locking implementation details · CPC title

  • Graphs; Linked lists (G06F16/9027 takes precedence) · CPC title

  • Indexing; Data structures therefor; Storage structures · CPC title

  • Database cache management · 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 US10740319B2 cover?
A method and system for managing access to data. A plurality of data items is stored across a plurality of partitions according to a graph-based data model. The data model associates each data item with an identifier of a source entity pertaining to the data item, an identifier of a destination entity pertaining to the data item, and an identifier of a type of directed relationship pertaining t…
Who is the assignee on this patent?
Dropbox Inc
What technology area does this patent fall under?
Primary CPC classification G06F16/278. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Aug 11 2020 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 2 related publications on this page (citations in our corpus or others sharing the same primary CPC).