Apparatus and method for managing peer-to-peer connections between different service providers

US9667713B2 · US · B2

Patent metadata
FieldValue
Publication numberUS-9667713-B2
Application numberUS-201213410232-A
CountryUS
Kind codeB2
Filing dateMar 1, 2012
Priority dateMar 21, 2011
Publication dateMay 30, 2017
Grant dateMay 30, 2017

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 one embodiment of the invention, service providers generate bloom filters with the user ID codes of registered users and exchange the bloom filters with one another. In response to a request to locate a first user, a first service provider will query its own registration database to determine if the first user is registered with the first service provider. If the first user is not registered with the first service provider, then the first service provider will query its bloom filters to identify other service providers with which the first user may be registered. A positive response from a bloom filter indicates that the first user may or may not be registered with the service provider associated with that bloom filter, and a negative response indicates with certainty that the first user is not registered with the service provider associated with that bloom filter.

First claim

Opening claim text (preview).

We claim: 1. A computer-implemented method performed by a physical device, comprising: receiving and storing, by a first service provider, a bloom filter from a second service provider; receiving, by the first service provider, a request to connect to a first user, the request including an alphanumeric identification (ID) code corresponding to the first user; establishing a connection with the first user based at least in part on a determined compatibility with a network address translation (NAT) type of the first user, wherein the establishing the connection comprises establishing a peer-to-peer (P2P) connection with the first user upon determining that the NAT type of the first user is compatible and opening a relay connection with the first user using a relay service upon determining that the NAT type of the first user is incompatible; and in response to the received connection request: querying a registration database maintained by the first service provider to determine whether the first user is registered with the first service provider; responsive to determining that the first user is not registered with the first service provider, for the bloom filter received from the second service provider: executing a bloom filter function with the bloom filter and the alphanumeric ID code; and responsive to receiving a positive response from executing the bloom filter function, transmitting a connection invitation to the second service provider; and receiving, from the second service provider, an acceptance of the connection invitation, the acceptance indicating that the first user is registered with the second service provider. 2. The computer-implemented method as in claim 1 , further comprising: providing network connection data to a second user for establishing the P2P network connection with the first user, the network connection data identifying the second service provider. 3. The computer-implemented method as in claim 1 , wherein the alphanumeric ID code comprises an email address. 4. The computer-implemented method as in claim 1 , wherein the alphanumeric ID code comprises a telephone number. 5. The computer-implemented method as in claim 1 , further comprising: determining that the first user is registered with the first service provider; and providing network connection data to a second user for establishing the P2P network connection with the first user, the network connection data identifying a network address managed by the first service provider. 6. The computer-implemented method as in claim 5 , wherein the network address comprises a TCP/IP address. 7. The computer-implemented method as in claim 1 , further comprising: determining that the first user is not registered with the first service provider but is registered with the second service provider; and using the second service provider as a proxy to transmit connection data to the first user, the connection data including networking data needed to establish the P2P connection from the first user to a second user which is registered with the first service provider. 8. The computer-implemented method as in claim 7 , further comprising; using the first service provider as a proxy to provide connection data of the first user to the second user, the connection data needed to establish the P2P connection from the second user to the first user. 9. A non-transitory machine-readable medium having program code stored thereon which, when executed by one or more machines, causes the machines to perform the operations of: receiving and storing, by a first service provider, a bloom filter from a second service provider; receiving, by the first service provider, a request to connect to a first user, the request including an alphanumeric identification (ID) code corresponding to the first user; establishing a connection with the first user based at least in part on a determined compatibility with a network address translation (NAT) type of the first user, wherein the establishing the connection comprises establishing a peer-to-peer (P2P) connection with the first user upon determining that the NAT type of the first user is compatible and opening a relay connection with the first user using a relay service upon determining that the NAT type of the first user is incompatible; and in response to the received connection request: querying a registration database maintained by the first service provider to determine if the first user is registered with the first service provider; responsive to determining that the first user is not registered with the first service provider, for the bloom filter received from the second service provider: executing a bloom filter function with the bloom filter and the alphanumeric ID code; and responsive to receiving a positive response from executing the bloom filter function, transmitting a connection invitation to the second service provider; and receiving, from the second service provider, an acceptance of the connection invitation, the acceptance indicating that the first user is registered with the second service provider. 10. The machine-readable medium as in claim 9 , comprising program code executed by the one or more machines to perform the additional operations of: providing network connection data to a second user for establishing the P2P network connection with the first user, the network connection data identifying the second service provider. 11. The machine-readable medium as in claim 9 , wherein the alphanumeric ID code comprises an email address. 12. The machine-readable medium as in claim 9 , wherein the alphanumeric ID code comprises a telephone number. 13. The machine-readable medium as in claim 9 , comprising program code executed by the one or more machines to perform the additional operations of: determining that the first user is registered with the first service provider, and providing network connection data to a second user for establishing the P2P network connection with the first user, the network connection data identifying a network address managed by the first service provider. 14. The machine-readable medium as in claim 9 , comprising program code executed by the one or more machines to perform the additional operations of: determining that the first user is not registered with the first service provider but is registered with the second service provider, and using the second service provider as a proxy to transmit connection data to the first user, the connection data including networking data needed to establish the P2P connection from the first user to a second user which is registered with the first service provider. 15. The machine-readable medium as in claim 14 , comprising program code executed by the one or more machines to perform the additional operations of: using the first service provider as a proxy to provide connection data of the first user to the second user, the connection data needed to establish the P2P connection from the second user to the first user. 16. The machine-readable medium as in claim 13 , wherein the network address comprises a TCP/IP address. 17. A computer-implemented method performed by a physical device, comprising: receiving and storing, at a first service provider, over a time period, a plurality of bloom filters from a plurality of service providers, wherein each of the bloom filters: is generated from alphanumeric identification (ID) codes of all users registered with one of the service providers; and is usable by the first service provider to determine with certainty that certain al

Assignees

Inventors

Classifications

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 US9667713B2 cover?
In one embodiment of the invention, service providers generate bloom filters with the user ID codes of registered users and exchange the bloom filters with one another. In response to a request to locate a first user, a first service provider will query its own registration database to determine if the first user is registered with the first service provider. If the first user is not registered…
Who is the assignee on this patent?
Vyrros Andrew H, Wood Justin N, Adler Mitch, and 5 more
What technology area does this patent fall under?
Primary CPC classification H04L67/104. Mapped technology areas include Electricity.
When was this patent published?
Publication date Tue May 30 2017 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).