Data clean rooms using defined access in trusted execution environment

US12235992B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-12235992-B2
Application numberUS-202218060504-A
CountryUS
Kind codeB2
Filing dateNov 30, 2022
Priority dateJun 13, 2022
Publication dateFeb 25, 2025
Grant dateFeb 25, 2025

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.

In an embodiment, an application is created on a data-provider platform. The application includes one or more application programming interfaces (APIs) corresponding to one or more underlying code blocks. Provider data is shared with the application on the data-provider platform. An application instance of the application is installed in a trusted execution environment (TEE). The application instance includes one or more APIs corresponding to the one or more APIs in the application on the data-provider platform. Consumer data is shared with the application instance from a data-consumer platform. One or more of the APIs of the application instance are invoked to execute, on the TEE, respective associated underlying code blocks that are not visible on the TEE. The output of the one or more respective associated underlying code blocks is saved to the data-consumer platform.

First claim

Opening claim text (preview).

What is claimed is: 1. A method performed by executing instructions on at least one hardware processor, the method comprising: creating an application on a data-provider platform, the application comprising one or more application programming interfaces (APIs) corresponding to one or more underlying code blocks; sharing provider data with the application on the data-provider platform; installing, in a trusted execution environment (TEE), an application instance of the application, the application instance comprising one or more APIs corresponding to the one or more APIs in the application on the data-provider platform; sharing consumer data with the application instance from a data-consumer platform; invoking one or more of the APIs of the application instance to execute respective associated underlying code blocks on the TEE, the respective associated underlying code blocks not being visible on the TEE; and saving output of the one or more respective associated underlying code blocks to the data-consumer platform. 2. The method of claim 1 , wherein the application instance is, by default, not authorized to exfiltrate consumer data from the data-consumer platform. 3. The method of claim 1 , wherein the respective associated underlying code blocks not being visible on the TEE comprises a source code of the respective associated underlying code blocks not being visible on the TEE. 4. The method of claim 1 , wherein the saved output comprises aggregated output data. 5. The method of claim 4 , wherein the saved output does not include any of the shared provider data. 6. The method of claim 1 , wherein the saved output comprises a relation. 7. The method of claim 6 , wherein the relation includes only a subset of the consumer data that was shared with the application instance. 8. A computer system comprising: at least one hardware processor; and one or more non-transitory computer readable storage media containing instructions that, when executed by the at least one hardware processor, cause the computer system to perform operations comprising: creating an application on a data-provider platform, the application comprising one or more application programming interfaces (APIs) corresponding to one or more underlying code blocks; sharing provider data with the application on the data-provider platform; installing, in a trusted execution environment (TEE), an application instance of the application, the application instance comprising one or more APIs corresponding to the one or more APIs in the application on the data-provider platform; sharing consumer data with the application instance from a data-consumer platform; invoking one or more of the APIs of the application instance to execute respective associated underlying code blocks on the TEE, the respective associated underlying code blocks not being visible on the TEE; and saving output of the one or more respective associated underlying code blocks to the data-consumer platform. 9. The computer system of claim 8 , wherein the application instance is, by default, not authorized to exfiltrate consumer data from the data-consumer platform. 10. The computer system of claim 8 , wherein the respective associated underlying code blocks not being visible on the TEE comprises a source code of the respective associated underlying code blocks not being visible on the TEE. 11. The computer system of claim 8 , wherein the saved output comprises aggregated output data. 12. The computer system of claim 11 , wherein the saved output does not include any of the shared provider data. 13. The computer system of claim 8 , wherein the saved output comprises a relation. 14. The computer system of claim 13 , wherein the relation includes only a subset of the consumer data that was shared with the application instance. 15. One or more non-transitory computer readable storage media containing instructions that, when executed by at least one hardware processor of a computer system, cause the computer system to perform operations comprising: creating an application on a data-provider platform, the application comprising one or more application programming interfaces (APIs) corresponding to one or more underlying code blocks; sharing provider data with the application on the data-provider platform; installing, in a trusted execution environment (TEE), an application instance of the application, the application instance comprising one or more APIs corresponding to the one or more APIs in the application on the data-provider platform; sharing consumer data with the application instance from a data-consumer platform; invoking one or more of the APIs of the application instance to execute respective associated underlying code blocks on the TEE, the respective associated underlying code blocks not being visible on the TEE; and saving output of the one or more respective associated underlying code blocks to the data-consumer platform. 16. The one or more non-transitory computer readable storage media of claim 15 , wherein the application instance is, by default, not authorized to exfiltrate consumer data from the data-consumer platform. 17. The one or more non-transitory computer readable storage media of claim 15 , wherein the respective associated underlying code blocks not being visible on the TEE comprises a source code of the respective associated underlying code blocks not being visible on the TEE. 18. The one or more non-transitory computer readable storage media of claim 15 , wherein the saved output comprises aggregated output data. 19. The one or more non-transitory computer readable storage media of claim 18 , wherein the saved output does not include any of the shared provider data. 20. The one or more non-transitory computer readable storage media of claim 15 , wherein the saved output comprises a relation. 21. The one or more non-transitory computer readable storage media of claim 20 , wherein the relation includes only a subset of the consumer data that was shared with the application instance.

Assignees

Inventors

Classifications

  • by anonymising data, e.g. decorrelating personal data from the owner's identification · CPC title

  • Remote procedure calls [RPC]; Web services · CPC title

  • via adapters, e.g. between incompatible applications · CPC title

  • Join operations · CPC title

  • Protect output to user by software means · 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 US12235992B2 cover?
In an embodiment, an application is created on a data-provider platform. The application includes one or more application programming interfaces (APIs) corresponding to one or more underlying code blocks. Provider data is shared with the application on the data-provider platform. An application instance of the application is installed in a trusted execution environment (TEE). The application in…
Who is the assignee on this patent?
Snowflake Inc
What technology area does this patent fall under?
Primary CPC classification G06F21/6245. Mapped technology areas include Physics.
When was this patent published?
Publication date Tue Feb 25 2025 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 12 related publications on this page (citations in our corpus or others sharing the same primary CPC).